Skip to main content
Glama

atlas-mcp-server

requestContext.ts4.03 kB
/** * @fileoverview Utilities for creating and managing request contexts. * A request context is an object carrying a unique ID, timestamp, and other * relevant data for logging, tracing, and processing. It also defines * configuration and operational context structures. * @module src/utils/internal/requestContext */ import { generateUUID } from "../index.js"; import { logger } from "./logger.js"; /** * Defines the core structure for context information associated with a request or operation. * This is fundamental for logging, tracing, and passing operational data. */ export interface RequestContext { /** * Unique ID for the context instance. * Used for log correlation and request tracing. */ requestId: string; /** * ISO 8601 timestamp indicating when the context was created. */ timestamp: string; /** * Allows arbitrary key-value pairs for specific context needs. * Using `unknown` promotes type-safe access. * Consumers must type-check/assert when accessing extended properties. */ [key: string]: unknown; } /** * Configuration for the {@link requestContextService}. * Allows for future extensibility of service-wide settings. */ export interface ContextConfig { /** Custom configuration properties. Allows for arbitrary key-value pairs. */ [key: string]: unknown; } /** * Represents a broader context for a specific operation or task. * It can optionally include a base {@link RequestContext} and other custom properties * relevant to the operation. */ export interface OperationContext { /** Optional base request context data, adhering to the `RequestContext` structure. */ requestContext?: RequestContext; /** Allows for additional, custom properties specific to the operation. */ [key: string]: unknown; } /** * Singleton-like service object for managing request context operations. * @private */ const requestContextServiceInstance = { /** * Internal configuration store for the service. */ config: {} as ContextConfig, /** * Configures the request context service with new settings. * Merges the provided partial configuration with existing settings. * * @param config - A partial `ContextConfig` object containing settings to update or add. * @returns A shallow copy of the newly updated configuration. */ configure(config: Partial<ContextConfig>): ContextConfig { this.config = { ...this.config, ...config, }; const logContext = this.createRequestContext({ operation: "RequestContextService.configure", newConfigState: { ...this.config }, }); logger.debug("RequestContextService configuration updated", logContext); return { ...this.config }; }, /** * Retrieves a shallow copy of the current service configuration. * This prevents direct mutation of the internal configuration state. * * @returns A shallow copy of the current `ContextConfig`. */ getConfig(): ContextConfig { return { ...this.config }; }, /** * Creates a new {@link RequestContext} instance. * Each context is assigned a unique `requestId` (UUID) and a current `timestamp` (ISO 8601). * Additional custom properties can be merged into the context. * * @param additionalContext - An optional record of key-value pairs to be * included in the created request context. * @returns A new `RequestContext` object. */ createRequestContext( additionalContext: Record<string, unknown> = {}, ): RequestContext { const requestId = generateUUID(); const timestamp = new Date().toISOString(); const context: RequestContext = { requestId, timestamp, ...additionalContext, }; return context; }, }; /** * Primary export for request context functionalities. * This service provides methods to create and manage {@link RequestContext} instances, * which are essential for logging, tracing, and correlating operations. */ export const requestContextService = requestContextServiceInstance;

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/cyanheads/atlas-mcp-server'

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