Skip to main content
Glama
phxdev1

People Data Labs MCP Server

search_job_titles

Search for job titles using SQL-like queries to find specific roles. Retrieve relevant results up to a maximum of 100, enabling precise filtering and matching for job title data.

Instructions

Search for job titles matching specific criteria

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
queryYesSQL-like query to search for job titles
sizeNoNumber of results to return (max 100)

Implementation Reference

  • Core handler function that performs the API call to People Data Labs for searching job titles (dataType='job_title'). Validates input, constructs query params, makes GET request to /job_title/search, and returns formatted JSON response.
    private async handleSearch(dataType: string, args: any) { if (!isValidSearchArgs(args)) { throw new McpError( ErrorCode.InvalidParams, `Invalid search parameters. Must provide a query string.` ); } const params: Record<string, any> = { sql: args.query, size: args.size || 10, }; const response = await pdlApi.get(`/${dataType}/search`, { params }); return { content: [ { type: 'text', text: JSON.stringify(response.data, null, 2), }, ], }; }
  • src/index.ts:321-339 (registration)
    Registers the 'search_job_titles' tool with the MCP server in the ListTools response, including name, description, and input schema definition.
    name: 'search_job_titles', description: 'Search for job titles matching specific criteria', inputSchema: { type: 'object', properties: { query: { type: 'string', description: 'SQL-like query to search for job titles', }, size: { type: 'number', description: 'Number of results to return (max 100)', minimum: 1, maximum: 100, }, }, required: ['query'], }, },
  • Dispatch logic in the CallToolRequest handler that maps 'search_job_titles' tool invocations to handleSearch('job_title', arguments).
    case 'search_job_titles': return await this.handleSearch('job_title', request.params.arguments);
  • Input validation helper used by the search_job_titles handler to ensure query is provided and size is within bounds.
    const isValidSearchArgs = (args: any): args is { query: string; size?: number; } => { return typeof args === 'object' && args !== null && typeof args.query === 'string' && (args.size === undefined || (typeof args.size === 'number' && args.size > 0 && args.size <= 100)); };

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/phxdev1/peopledatalabs-mcp'

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