import express from 'express'; import pino from 'pino'; import pinoHttp from 'pino-http'; import { requestContext } from './middleware/request-context.js'; import { errorHandler, notFoundHandler } from './middleware/error-handler.js'; import { healthRouter } from './routes/health.js'; import { createCommandsRouter } from './routes/commands.js'; const logger = pino({ level: process.env.LOG_LEVEL || 'info' }); export function createApp(options = {}) { const app = express(); app.use(requestContext); app.use( pinoHttp({ logger, customProps: (req) => ({ requestId: req.requestId }), }) ); app.use(express.json({ limit: '2mb' })); app.use(healthRouter); app.use('/commands', createCommandsRouter(options.commandHandlers)); app.use(notFoundHandler); app.use(errorHandler); return app; }