Skip to main content
Glama

MCP Starter for Puch AI

by TurboML-Inc
utils.ts3.05 kB
/** * Constructs an authorization URL for an upstream service. * * @param {Object} options * @param {string} options.upstream_url - The base URL of the upstream service. * @param {string} options.client_id - The client ID of the application. * @param {string} options.redirect_uri - The redirect URI of the application. * @param {string} [options.state] - The state parameter. * @param {string} [options.hosted_domain] - The hosted domain parameter. * * @returns {string} The authorization URL. */ export function getUpstreamAuthorizeUrl({ upstreamUrl, clientId, scope, redirectUri, state, hostedDomain, }: { upstreamUrl: string; clientId: string; scope: string; redirectUri: string; state?: string; hostedDomain?: string; }) { const upstream = new URL(upstreamUrl); upstream.searchParams.set("client_id", clientId); upstream.searchParams.set("redirect_uri", redirectUri); upstream.searchParams.set("scope", scope); upstream.searchParams.set("response_type", "code"); if (state) upstream.searchParams.set("state", state); if (hostedDomain) upstream.searchParams.set("hd", hostedDomain); return upstream.href; } /** * Fetches an authorization token from an upstream service. * * @param {Object} options * @param {string} options.client_id - The client ID of the application. * @param {string} options.client_secret - The client secret of the application. * @param {string} options.code - The authorization code. * @param {string} options.redirect_uri - The redirect URI of the application. * @param {string} options.upstream_url - The token endpoint URL of the upstream service. * @param {string} options.grant_type - The grant type. * * @returns {Promise<[string, null] | [null, Response]>} A promise that resolves to an array containing the access token or an error response. */ export async function fetchUpstreamAuthToken({ clientId, clientSecret, code, redirectUri, upstreamUrl, grantType, }: { code: string | undefined; upstreamUrl: string; clientSecret: string; redirectUri: string; clientId: string; grantType: string; }): Promise<[string, null] | [null, Response]> { if (!code) { return [null, new Response("Missing code", { status: 400 })]; } const resp = await fetch(upstreamUrl, { body: new URLSearchParams({ clientId, clientSecret, code, grantType, redirectUri, }).toString(), headers: { "Content-Type": "application/x-www-form-urlencoded", }, method: "POST", }); if (!resp.ok) { console.log(await resp.text()); return [null, new Response("Failed to fetch access token", { status: 500 })]; } interface authTokenResponse { access_token: string; } const body = (await resp.json()) as authTokenResponse; if (!body.access_token) { return [null, new Response("Missing access token", { status: 400 })]; } return [body.access_token, null]; } // Context from the auth process, encrypted & stored in the auth token // and provided to the MyMCP as this.props export type Props = { name: string; email: string; accessToken: string; };

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/TurboML-Inc/mcp-starter'

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