index.ts•5.35 kB
import { HOST, PORT } from '@src/constants.js';
import { globalOptions } from '@src/globalOptions.js';
import type { Argv } from 'yargs';
/**
 * Serve command group entry point.
 *
 * Starts the 1mcp server with various transport options and configurations.
 */
// Define server options that should be available for serve commands and default command
export const serverOptions = {
  transport: {
    alias: 't',
    describe: 'Transport type to use (stdio or http, sse is deprecated)',
    type: 'string' as const,
    choices: ['stdio', 'http', 'sse'] as const,
    default: 'http',
  },
  port: {
    alias: 'P',
    describe: 'HTTP port to listen on, applicable when transport is http',
    type: 'number' as const,
    default: PORT,
  },
  host: {
    alias: 'H',
    describe: 'HTTP host to listen on, applicable when transport is http',
    type: 'string' as const,
    default: HOST,
  },
  'external-url': {
    alias: 'u',
    describe: 'External URL for the server (used for OAuth callbacks and public URLs)',
    type: 'string' as const,
    default: undefined,
  },
  filter: {
    alias: 'f',
    describe: 'Filter expression for server selection (supports simple comma-separated or advanced boolean logic)',
    type: 'string' as const,
    default: undefined,
  },
  pagination: {
    alias: 'p',
    describe: 'Enable pagination',
    type: 'boolean' as const,
    default: false,
  },
  auth: {
    describe: 'Enable authentication (OAuth 2.1) - deprecated, use --enable-auth',
    type: 'boolean' as const,
    default: false,
  },
  'enable-auth': {
    describe: 'Enable authentication (OAuth 2.1)',
    type: 'boolean' as const,
    default: false,
  },
  'enable-scope-validation': {
    describe: 'Enable tag-based scope validation',
    type: 'boolean' as const,
    default: true,
  },
  'enable-enhanced-security': {
    describe: 'Enable enhanced security middleware',
    type: 'boolean' as const,
    default: false,
  },
  'session-ttl': {
    describe: 'Session expiry time in minutes',
    type: 'number' as const,
    default: 24 * 60, // 24 hours
  },
  'session-storage-path': {
    describe: 'Custom session storage directory path',
    type: 'string' as const,
    default: undefined,
  },
  'rate-limit-window': {
    describe: 'OAuth rate limit window in minutes',
    type: 'number' as const,
    default: 15,
  },
  'rate-limit-max': {
    describe: 'Maximum requests per OAuth rate limit window',
    type: 'number' as const,
    default: 100,
  },
  'trust-proxy': {
    describe:
      'Trust proxy configuration for Express.js (boolean, IP address, subnet, or preset: loopback, linklocal, uniquelocal)',
    type: 'string' as const,
    default: 'loopback',
  },
  'health-info-level': {
    describe: 'Health endpoint information detail level (full, basic, minimal)',
    type: 'string' as const,
    choices: ['full', 'basic', 'minimal'] as const,
    default: 'minimal',
  },
  'enable-async-loading': {
    describe: 'Enable asynchronous MCP server loading with listChanged notifications',
    type: 'boolean' as const,
    default: false,
  },
  'instructions-template': {
    alias: 'T',
    describe:
      'Path to custom instructions template file (Handlebars format). Defaults to instructions-template.md in config directory',
    type: 'string' as const,
    default: undefined,
  },
};
/**
 * Register serve command
 */
export function setupServeCommand(yargs: Argv): Argv {
  return yargs.command(
    'serve',
    'Start the 1mcp server',
    (yargs) => {
      return yargs
        .options(globalOptions || {})
        .options(serverOptions)
        .example([
          ['$0 serve', 'Start server with HTTP transport (default)'],
          ['$0 serve --transport=stdio', 'Start server with stdio transport'],
          ['$0 serve --port=3000', 'Start HTTP server on port 3000'],
          ['$0 serve --filter="web,api"', 'Start server with filtered MCP servers'],
          ['$0 serve --enable-auth', 'Start server with OAuth authentication enabled'],
          ['$0 serve --instructions-template=./custom-template.md', 'Use custom instructions template'],
        ]).epilogue(`
TRANSPORT OPTIONS:
  stdio: Use stdin/stdout for communication (for programmatic use)
  http:  Use HTTP server with SSE for web-based clients (default)
FILTERING:
  Use --filter to limit which MCP servers are exposed:
  • Simple: "web,api,database" (OR logic)
  • Advanced: "web AND database" or "(web OR api) AND database"
AUTHENTICATION:
  Use --enable-auth to enable OAuth 2.1 authentication with scope validation.
  Configure OAuth providers in your MCP configuration file.
CUSTOM TEMPLATES:
  Use --instructions-template to customize the instructions template sent to clients.
  Template files use Handlebars syntax with variables like {{serverCount}}, {{serverList}}, etc.
  Defaults to instructions-template.md in your config directory.
For more information: https://github.com/1mcp-app/agent
        `);
    },
    async (argv) => {
      const { configureGlobalLogger } = await import('@src/logger/configureGlobalLogger.js');
      const { serveCommand } = await import('./serve.js');
      // Configure logger with global options and transport awareness
      configureGlobalLogger(argv, argv.transport);
      // Execute serve command
      await serveCommand(argv);
    },
  );
}