#!/usr/bin/env node
import { logger } from './utils/logger.js';
import { cache } from './services/cache.js';
import ComposerPackageReadmeMcpServer from './server.js';
async function main(): Promise<void> {
let server: ComposerPackageReadmeMcpServer | null = null;
try {
logger.info('Initializing composer-package-readme-mcp server');
// Create and start the server
server = new ComposerPackageReadmeMcpServer();
await server.run();
} catch (error) {
logger.error('Failed to start server', { error });
process.exit(1);
}
// Handle graceful shutdown
const handleShutdown = async (signal: string) => {
logger.info(`Received ${signal}, shutting down gracefully`);
try {
if (server) {
await server.stop();
}
// Clean up cache
cache.destroy();
logger.info('Server shutdown complete');
process.exit(0);
} catch (error) {
logger.error('Error during shutdown', { error });
process.exit(1);
}
};
// Register signal handlers
process.on('SIGINT', () => handleShutdown('SIGINT'));
process.on('SIGTERM', () => handleShutdown('SIGTERM'));
// Handle uncaught exceptions and rejections
process.on('uncaughtException', (error) => {
logger.error('Uncaught exception', { error });
process.exit(1);
});
process.on('unhandledRejection', (reason, promise) => {
logger.error('Unhandled rejection', { reason, promise });
process.exit(1);
});
}
// Run the server
main().catch((error) => {
logger.error('Failed to start application', { error });
process.exit(1);
});