Skip to main content
Glama

get-contest-details

Retrieve contest information from LeetCode using the contest URL slug to access details about programming competitions.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
contestSlugYesThe URL slug of the contest

Implementation Reference

  • Primary registration of the 'get-contest-details' tool, including input schema (contestSlug: string) and inline handler that fetches data from LeetCodeService and returns formatted JSON response or error.
    server.tool(
      "get-contest-details",
      {
        contestSlug: z.string().describe("The URL slug of the contest")
      },
      async ({ contestSlug }) => {
        try {
          const data = await leetcodeService.fetchContestDetails(contestSlug);
          return {
            content: [{ 
              type: "text", 
              text: JSON.stringify(data, null, 2)
            }]
          };
        } catch (error: unknown) {
          const errorMessage = error instanceof Error ? error.message : String(error);
          return {
            content: [{ type: "text", text: `Error: ${errorMessage}` }],
            isError: true
          };
        }
      }
    );
  • src/index.ts:24-24 (registration)
    Top-level registration call that invokes registerContestTools to add the get-contest-details tool (among others) to the MCP server.
    registerContestTools(server, leetcodeService);
  • Supporting service method in LeetCodeService that executes the GraphQL query to fetch contest details by slug.
    async fetchContestDetails(contestSlug: string) {
      return this.executeQuery(contestDetailsQuery, { contestSlug });
    }
  • GraphQL query definition used to fetch detailed contest information including title, description, timing, and participating questions.
    export const contestDetailsQuery = `
      query contestData($contestSlug: String!) {
        contest(titleSlug: $contestSlug) {
          title
          titleSlug
          description
          startTime
          duration
          originStartTime
          isVirtual
          questions {
            questionId
            title
            titleSlug
            difficulty
          }
        }
      }
    `;
  • Inline handler function within the tool registration that processes the input, calls the service, and structures the MCP-compatible response.
    async ({ contestSlug }) => {
      try {
        const data = await leetcodeService.fetchContestDetails(contestSlug);
        return {
          content: [{ 
            type: "text", 
            text: JSON.stringify(data, null, 2)
          }]
        };
      } catch (error: unknown) {
        const errorMessage = error instanceof Error ? error.message : String(error);
        return {
          content: [{ type: "text", text: `Error: ${errorMessage}` }],
          isError: true
        };
      }
    }

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/doggybee/mcp-server-leetcode'

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