Skip to main content
Glama

PostOrdersIdTransferDecline

Decline an order transfer request initiated via the Admin API, ensuring control over order management within the Medusa MCP Server. Use this to reject pending transfers efficiently.

Instructions

Decline an order transfer previously requested, typically by the admin user using the Request Order Transfer Admin API route.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
fieldsNo
idNo

Implementation Reference

  • Handler logic for the PostOrdersIdTransferDecline tool: constructs query/body from input parameters and performs the SDK fetch to the Medusa store API endpoint.
    handler: async ( input: InferToolHandlerInput<any, ZodTypeAny> ): Promise<any> => { const query = new URLSearchParams(input); const body = Object.entries(input).reduce( (acc, [key, value]) => { if ( parameters.find( (p) => p.name === key && p.in === "body" ) ) { acc[key] = value; } return acc; }, {} as Record<string, any> ); if (method === "get") { console.error( `Fetching ${refPath} with GET ${query.toString()}` ); const response = await this.sdk.client.fetch(refPath, { method: method, headers: { "Content-Type": "application/json", "Accept": "application/json", "Authorization": `Bearer ${process.env.PUBLISHABLE_KEY}` }, query: query }); return response; } else { const response = await this.sdk.client.fetch(refPath, { method: method, headers: { "Content-Type": "application/json", "Accept": "application/json", "Authorization": `Bearer ${process.env.PUBLISHABLE_KEY}` }, body: JSON.stringify(body) }); return response; } } };
  • Dynamic Zod input schema generation for the tool based on OpenAPI parameters from store.json.
    inputSchema: { ...parameters .filter((p) => p.in != "header") .reduce((acc, param) => { switch (param.schema.type) { case "string": acc[param.name] = z.string().optional(); break; case "number": acc[param.name] = z.number().optional(); break; case "boolean": acc[param.name] = z.boolean().optional(); break; case "array": acc[param.name] = z .array(z.string()) .optional(); break; case "object": acc[param.name] = z.object({}).optional(); break; default: acc[param.name] = z.string().optional(); } return acc; }, {} as any) },
  • src/index.ts:35-42 (registration)
    Registers the PostOrdersIdTransferDecline tool (among others from medusaStoreService) with the MCP server.
    tools.forEach((tool) => { server.tool( tool.name, tool.description, tool.inputSchema, tool.handler ); });
  • src/index.ts:15-17 (registration)
    Calls defineTools() on MedusaStoreService, which generates and returns the PostOrdersIdTransferDecline tool definition.
    ...medusaStoreService.defineTools(), ...medusaAdminService.defineTools() ];
  • Helper function used to define and wrap each tool handler with error handling and MCP response formatting.
    export const defineTool = ( cb: (zod: typeof z) => ToolDefinition<any, ZodAny, any> ) => { const tool = cb(z); const wrappedHandler = async ( input: InferToolHandlerInput<Zod.ZodAny, Zod.ZodAny>, _: RequestHandlerExtra ): Promise<{ content: CallToolResult["content"]; isError?: boolean; statusCode?: number; }> => { try { const result = await tool.handler(input); return { content: [ { type: "text", text: JSON.stringify(result, null, 2) } ] }; } catch (error) { return { content: [ { type: "text", text: `Error: ${ error instanceof Error ? error.message : String(error) }` } ], isError: true }; } }; return { ...tool, handler: wrappedHandler }; };

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/SGFGOV/medusa-mcp'

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