Skip to main content
Glama

list_products

Retrieve a paginated list of products from Printify's print-on-demand platform. Specify page number and limit to filter results for efficient product management.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
limitNoNumber of products per page
pageNoPage number

Implementation Reference

  • The core handler function that implements the list_products tool logic: validates shop selection, fetches paginated products from Printify API, handles errors, and formats success/error responses.
    export async function listProducts(
      printifyClient: PrintifyAPI,
      options: {
        limit?: number;
        page?: number;
      } = {}
    ) {
      try {
        // Validate shop is selected
        const currentShop = printifyClient.getCurrentShop();
        if (!currentShop) {
          throw new Error('No shop is currently selected. Use the list-shops and switch-shop tools to select a shop.');
        }
    
        // Set default options
        const limit = options.limit || 10;
        const page = options.page || 1;
    
        // Get products
        const products = await printifyClient.getProducts(limit, page);
    
        return {
          success: true,
          products,
          response: formatSuccessResponse(
            'Products Retrieved Successfully',
            {
              Count: products.length,
              Page: page,
              Limit: limit,
              Shop: currentShop
            }
          )
        };
      } catch (error: any) {
        console.error('Error listing products:', error);
    
        return {
          success: false,
          error,
          errorResponse: formatErrorResponse(
            error,
            'List Products',
            {
              Shop: printifyClient.getCurrentShop(),
              Limit: options.limit,
              Page: options.page
            },
            [
              'Check that your Printify API key is valid',
              'Ensure your Printify account is properly connected',
              'Make sure you have selected a shop'
            ]
          )
        };
      }
    }
  • src/index.ts:184-215 (registration)
    MCP server registration of the 'list_products' tool, including input schema validation with Zod, dynamic import of the handler, client checks, and response formatting.
    server.tool(
      "list_products",
      {
        page: z.number().optional().default(1).describe("Page number"),
        limit: z.number().optional().default(10).describe("Number of products per page")
      },
      async ({ page, limit }): Promise<{ content: any[], isError?: boolean }> => {
        // Import the printify products service
        const { listProducts } = await import('./services/printify-products.js');
    
        // Check if client is initialized
        if (!printifyClient) {
          return {
            content: [{
              type: "text",
              text: "Printify API client is not initialized. The PRINTIFY_API_KEY environment variable may not be set."
            }],
            isError: true
          };
        }
    
        // Call the service
        const result = await listProducts(printifyClient, { page, limit });
    
        // Return the result
        if (result.success) {
          return result.response as { content: any[], isError?: boolean };
        } else {
          return result.errorResponse as { content: any[], isError: boolean };
        }
      }
    );
  • Zod input schema for the list_products tool defining optional page and limit parameters with defaults and descriptions.
      page: z.number().optional().default(1).describe("Page number"),
      limit: z.number().optional().default(10).describe("Number of products per page")
    },

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/TSavo/printify-mcp'

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