get_public_price
Retrieve current pricing details for Sakura Cloud infrastructure services to help users estimate costs and plan deployments.
Instructions
Get public pricing information for Sakura Cloud services
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
No arguments | |||
Implementation Reference
- src/server.ts:2217-2233 (handler)Handler implementation for the 'get_public_price' tool. Fetches public pricing data from Sakura Cloud's public API endpoint '/public/price' using the fetchFromSakuraCloud helper function with isPublicAPI set to true, and returns the JSON stringified response.} else if (request.params.name === 'get_public_price') { try { // No authentication needed for public price API const priceData = await fetchFromSakuraCloud('/public/price', true); return { content: [ { type: 'text', text: JSON.stringify(priceData, null, 2) } ] }; } catch (error) { console.error('Error calling tool:', error); throw error; }
- src/server.ts:1218-1224 (registration)Tool registration in the ListToolsRequestSchema handler, defining the tool name, description, and empty input schema (no parameters required).name: 'get_public_price', description: 'Get public pricing information for Sakura Cloud services', inputSchema: { type: 'object', properties: {} } },
- src/server.ts:1220-1223 (schema)Input schema for the 'get_public_price' tool, specifying an empty object (no input parameters).inputSchema: { type: 'object', properties: {} }
- src/server.ts:20-72 (helper)Helper function fetchFromSakuraCloud used by the tool handler to make HTTPS requests to Sakura Cloud API. For public APIs (isPublicAPI=true), it skips authentication and uses base path '/cloud/api/cloud/1.1'.async function fetchFromSakuraCloud(path: string, isPublicAPI: boolean = false, zone: string = DEFAULT_ZONE, method: string = 'GET', bodyData?: any): Promise<any> { return new Promise((resolve, reject) => { const basePath = isPublicAPI ? '/cloud/api/cloud/1.1' : `/cloud/zone/${zone}/api/cloud/1.1`; const options = { hostname: 'secure.sakura.ad.jp', port: 443, path: `${basePath}${path}`, method: method, headers: { 'Accept': 'application/json', 'Authorization': '', 'Content-Type': 'application/json' } }; // Add authorization for non-public APIs if (!isPublicAPI) { options.headers['Authorization'] = `Basic ${Buffer.from(`${SACLOUD_API_TOKEN}:${SACLOUD_API_SECRET}`).toString('base64')}`; } const req = https.request(options, (res) => { let data = ''; res.on('data', (chunk) => { data += chunk; }); res.on('end', () => { try { if (data) { const parsedData = JSON.parse(data); resolve(parsedData); } else { resolve({}); } } catch (err) { reject(new Error(`Failed to parse response: ${err}`)); } }); }); req.on('error', (error) => { reject(error); }); if (bodyData && (method === 'POST' || method === 'PUT')) { req.write(JSON.stringify(bodyData)); } req.end(); }); }