- 新增 pino/pino-pretty/pino-roll 依赖,实现结构化日志(console pretty + file JSONL rolling) - 新增 Logger 接口及 PinoLoggerWrapper/ConsoleFallbackLogger/NoopLogger/MemoryLogger 实现 - 新增 src/pino-roll.d.ts 类型声明 - 新增 server.storage.dataDir 配置(默认 ./data,相对路径基于配置文件目录) - 新增 server.logging 配置(level/console/file/rotation,支持变量引用) - 配置文件从可选改为必填,parseRuntimeArgs 无参数时抛错 - bootstrap 创建 logger、确保 dataDir、shutdown flush、失败路径 fallback - startServer 接收 logger 并输出结构化监听日志 - ESLint 新增 no-restricted-syntax 禁止 src/server 直接 console.*(排除 logger.ts) - 更新 config.example.yaml、README.md、DEVELOPMENT.md 同步配置和日志文档 - 完善测试覆盖:logger、config、schema、bootstrap 共 150 个测试通过
50 lines
1.5 KiB
TypeScript
50 lines
1.5 KiB
TypeScript
import type { RuntimeMode } from "../shared/api";
|
|
import type { Logger } from "./logger";
|
|
import type { StaticAssets } from "./static";
|
|
|
|
import { createApiError, jsonResponse } from "./helpers";
|
|
import { handleMeta } from "./routes/meta";
|
|
import { serveStaticAsset } from "./static";
|
|
import { readAppVersion } from "./version";
|
|
|
|
export interface StartServerOptions {
|
|
config: { host: string; port: number };
|
|
logger: Logger;
|
|
mode: RuntimeMode;
|
|
staticAssets?: StaticAssets;
|
|
version?: string;
|
|
}
|
|
|
|
export function startServer(options: StartServerOptions) {
|
|
const { config, logger, mode, staticAssets, version } = options;
|
|
|
|
const resolveVersion = (): Promise<string> => {
|
|
if (version) return Promise.resolve(version);
|
|
return readAppVersion();
|
|
};
|
|
|
|
const server = Bun.serve({
|
|
fetch(req) {
|
|
if (staticAssets) {
|
|
return serveStaticAsset(new URL(req.url).pathname, staticAssets);
|
|
}
|
|
return new Response("Frontend is served by Vite dev server on :5173", { status: 404 });
|
|
},
|
|
hostname: config.host,
|
|
port: config.port,
|
|
routes: {
|
|
"/api/*": () => jsonResponse(createApiError("API route not found", 404), { mode, status: 404 }),
|
|
"/api/meta": {
|
|
GET: async () => {
|
|
const resolvedVersion = await resolveVersion();
|
|
return handleMeta(mode, resolvedVersion);
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
logger.info({ host: config.host, port: config.port, url: server.url.toString() }, "服务启动");
|
|
|
|
return server;
|
|
}
|