get_commonserviceitem_list
Retrieve a list of common service items like DNS and Simple Monitor within Sakura Cloud MCP Server to manage infrastructure components efficiently.
Instructions
Get list of common service items (DNS, Simple Monitor, etc.)
Input Schema
TableJSON Schema
| Name | Required | Description | Default |
|---|---|---|---|
No arguments | |||
Implementation Reference
- src/server.ts:2039-2056 (handler)The execution handler for the 'get_commonserviceitem_list' tool within the CallToolRequestSchema handler. It validates credentials, fetches common service items from Sakura Cloud API endpoint '/commonserviceitem', and returns the JSON-formatted response.} else if (request.params.name === 'get_commonserviceitem_list') { try { validateCredentials(); const commonServiceItemList = await fetchFromSakuraCloud(`/commonserviceitem`); return { content: [ { type: 'text', text: JSON.stringify(commonServiceItemList, null, 2) } ] }; } catch (error) { console.error('Error calling tool:', error); throw error; }
- src/server.ts:1107-1115 (registration)Registration of the 'get_commonserviceitem_list' tool in the ListToolsRequestSchema response, including its name, description, and empty input schema (no parameters required).{ name: 'get_commonserviceitem_list', description: 'Get list of common service items (DNS, Simple Monitor, etc.)', inputSchema: { type: 'object', properties: { }, } },
- src/server.ts:1110-1114 (schema)Input schema definition for the 'get_commonserviceitem_list' tool, specifying an empty object (no required parameters).inputSchema: { type: 'object', properties: { }, }
- src/server.ts:20-72 (helper)Helper function 'fetchFromSakuraCloud' used by the tool handler to perform authenticated HTTPS GET requests to the Sakura Cloud API, specifically called with path '/commonserviceitem'.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(); }); }