Skip to main content
Glama
cswkim

Discogs MCP Server

by cswkim

get_master_release_versions

Retrieve a list of releases linked to a specific master by providing master ID, format, label, release date, country, and sorting options for organized results.

Instructions

Retrieves a list of all Releases that are versions of this master

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
countryNo
formatNo
labelNo
master_idYes
pageNo
per_pageNo
releasedNo
sortNo
sort_orderNo

Implementation Reference

  • MCP tool handler definition for get_master_release_versions, which delegates to MasterReleaseService.getVersions().
    export const getMasterReleaseVersionsTool: Tool< FastMCPSessionAuth, typeof MasterReleaseVersionsParamSchema > = { name: 'get_master_release_versions', description: 'Retrieves a list of all Releases that are versions of this master', parameters: MasterReleaseVersionsParamSchema, execute: async (args) => { try { const masterReleaseService = new MasterReleaseService(); const masterReleaseVersions = await masterReleaseService.getVersions(args); return JSON.stringify(masterReleaseVersions); } catch (error) { throw formatDiscogsError(error); } }, };
  • Zod schemas defining the input parameters for the tool: base MasterReleaseIdParamSchema and extended MasterReleaseVersionsParamSchema.
    export const MasterReleaseIdParamSchema = z.object({ master_id: z.number().int(), }); /** * Schema for a master release versions parameter */ export const MasterReleaseVersionsParamSchema = MasterReleaseIdParamSchema.extend({ format: z.string().optional(), label: z.string().optional(), released: z.string().optional(), country: z.string().optional(), }).merge(QueryParamsSchema(['released', 'title', 'format', 'label', 'catno', 'country']));
  • Core service method getVersions() that performs the API request to Discogs /masters/{master_id}/versions endpoint.
    async getVersions({ master_id, ...options }: MasterReleaseVersionsParam): Promise<MasterReleaseVersionsResponse> { try { const response = await this.request<MasterReleaseVersionsResponse>(`/${master_id}/versions`, { params: options, }); const validatedResponse = MasterReleaseVersionsResponseSchema.parse(response); return validatedResponse; } catch (error) { if (isDiscogsError(error)) { throw error; } throw new Error(`Failed to get master release versions: ${String(error)}`); } }
  • Registration function for database tools, including server.addTool(getMasterReleaseVersionsTool).
    export function registerDatabaseTools(server: FastMCP): void { server.addTool(getReleaseTool); server.addTool(getReleaseRatingTool); server.addTool(editReleaseRatingTool); server.addTool(deleteReleaseRatingTool); server.addTool(getReleaseCommunityRatingTool); server.addTool(getMasterReleaseTool); server.addTool(getMasterReleaseVersionsTool); server.addTool(getArtistTool); server.addTool(getArtistReleasesTool); server.addTool(getLabelTool); server.addTool(getLabelReleasesTool); server.addTool(searchTool); }
  • Top-level tool registration function that invokes registerDatabaseTools(server), indirectly registering the tool.
    export function registerTools(server: FastMCP): void { registerDatabaseTools(server); registerMarketplaceTools(server); registerInventoryExportTool(server); registerUserIdentityTools(server); registerUserCollectionTools(server); registerUserWantlistTools(server); registerUserListsTools(server); registerMediaTools(server); }

Other Tools

Related Tools

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/cswkim/discogs-mcp-server'

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