Skip to main content
Glama
runpod

RunPod MCP Server

Official
by runpod

delete-template

Remove unused or obsolete templates from your RunPod server by specifying the template ID, helping maintain a clean and organized template library.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
templateIdYesID of the template to delete

Implementation Reference

  • The async handler function for the 'delete-template' tool. It sends a DELETE request to the RunPod API endpoint `/templates/{templateId}` using the shared runpodRequest helper and returns the JSON-formatted result.
    async (params) => {
      const result = await runpodRequest(
        `/templates/${params.templateId}`,
        'DELETE'
      );
    
      return {
        content: [
          {
            type: 'text',
            text: JSON.stringify(result, null, 2),
          },
        ],
      };
    }
  • Zod input schema for the 'delete-template' tool, requiring a 'templateId' string parameter.
    {
      templateId: z.string().describe('ID of the template to delete'),
    },
  • src/index.ts:603-623 (registration)
    Registration of the 'delete-template' tool on the MCP server via server.tool(), including inline schema and handler.
    server.tool(
      'delete-template',
      {
        templateId: z.string().describe('ID of the template to delete'),
      },
      async (params) => {
        const result = await runpodRequest(
          `/templates/${params.templateId}`,
          'DELETE'
        );
    
        return {
          content: [
            {
              type: 'text',
              text: JSON.stringify(result, null, 2),
            },
          ],
        };
      }
    );
  • Shared helper function runpodRequest used by the delete-template handler (and other tools) to make authenticated HTTP requests to the RunPod API.
    async function runpodRequest(
      endpoint: string,
      method: string = 'GET',
      body?: Record<string, unknown>
    ) {
      const url = `${API_BASE_URL}${endpoint}`;
      const headers = {
        Authorization: `Bearer ${API_KEY}`,
        'Content-Type': 'application/json',
      };
    
      const options: NodeFetchRequestInit = {
        method,
        headers,
      };
    
      if (body && (method === 'POST' || method === 'PATCH')) {
        options.body = JSON.stringify(body);
      }
    
      try {
        const response = await fetch(url, options);
    
        if (!response.ok) {
          const errorText = await response.text();
          throw new Error(`RunPod API Error: ${response.status} - ${errorText}`);
        }
    
        // Some endpoints might not return JSON
        const contentType = response.headers.get('content-type');
        if (contentType && contentType.includes('application/json')) {
          return await response.json();
        }
    
        return { success: true, status: response.status };
      } catch (error) {
        console.error('Error calling RunPod API:', error);
        throw error;
      }
    }

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/runpod/runpod-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server