@zhouzhengchang/token-party 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/config.example.yaml +34 -0
  2. package/dashboard/assets/index-BOghvbFW.js +131 -0
  3. package/dashboard/assets/index-CEcLJoXS.css +1 -0
  4. package/dashboard/index.html +13 -0
  5. package/dist/adapters/anthropic-to-openai.d.ts +35 -0
  6. package/dist/adapters/anthropic-to-openai.d.ts.map +1 -0
  7. package/dist/adapters/anthropic-to-openai.js +62 -0
  8. package/dist/adapters/anthropic-to-openai.js.map +1 -0
  9. package/dist/adapters/openai-to-anthropic.d.ts +42 -0
  10. package/dist/adapters/openai-to-anthropic.d.ts.map +1 -0
  11. package/dist/adapters/openai-to-anthropic.js +75 -0
  12. package/dist/adapters/openai-to-anthropic.js.map +1 -0
  13. package/dist/cli.d.ts +3 -0
  14. package/dist/cli.d.ts.map +1 -0
  15. package/dist/cli.js +77 -0
  16. package/dist/cli.js.map +1 -0
  17. package/dist/config.d.ts +6 -0
  18. package/dist/config.d.ts.map +1 -0
  19. package/dist/config.js +69 -0
  20. package/dist/config.js.map +1 -0
  21. package/dist/index.d.ts +2 -0
  22. package/dist/index.d.ts.map +1 -0
  23. package/dist/index.js +17 -0
  24. package/dist/index.js.map +1 -0
  25. package/dist/metrics/collector.d.ts +14 -0
  26. package/dist/metrics/collector.d.ts.map +1 -0
  27. package/dist/metrics/collector.js +20 -0
  28. package/dist/metrics/collector.js.map +1 -0
  29. package/dist/proxy/auth.d.ts +6 -0
  30. package/dist/proxy/auth.d.ts.map +1 -0
  31. package/dist/proxy/auth.js +16 -0
  32. package/dist/proxy/auth.js.map +1 -0
  33. package/dist/proxy/forwarder.d.ts +6 -0
  34. package/dist/proxy/forwarder.d.ts.map +1 -0
  35. package/dist/proxy/forwarder.js +443 -0
  36. package/dist/proxy/forwarder.js.map +1 -0
  37. package/dist/proxy/router.d.ts +9 -0
  38. package/dist/proxy/router.d.ts.map +1 -0
  39. package/dist/proxy/router.js +29 -0
  40. package/dist/proxy/router.js.map +1 -0
  41. package/dist/routes/anthropic.d.ts +4 -0
  42. package/dist/routes/anthropic.d.ts.map +1 -0
  43. package/dist/routes/anthropic.js +37 -0
  44. package/dist/routes/anthropic.js.map +1 -0
  45. package/dist/routes/api.d.ts +3 -0
  46. package/dist/routes/api.d.ts.map +1 -0
  47. package/dist/routes/api.js +157 -0
  48. package/dist/routes/api.js.map +1 -0
  49. package/dist/routes/openai.d.ts +4 -0
  50. package/dist/routes/openai.d.ts.map +1 -0
  51. package/dist/routes/openai.js +49 -0
  52. package/dist/routes/openai.js.map +1 -0
  53. package/dist/server.d.ts +3 -0
  54. package/dist/server.d.ts.map +1 -0
  55. package/dist/server.js +38 -0
  56. package/dist/server.js.map +1 -0
  57. package/dist/store/db.d.ts +4 -0
  58. package/dist/store/db.d.ts.map +1 -0
  59. package/dist/store/db.js +49 -0
  60. package/dist/store/db.js.map +1 -0
  61. package/dist/store/log-writer.d.ts +17 -0
  62. package/dist/store/log-writer.d.ts.map +1 -0
  63. package/dist/store/log-writer.js +29 -0
  64. package/dist/store/log-writer.js.map +1 -0
  65. package/dist/types/config.d.ts +157 -0
  66. package/dist/types/config.d.ts.map +1 -0
  67. package/dist/types/config.js +28 -0
  68. package/dist/types/config.js.map +1 -0
  69. package/dist/types/env.d.ts +7 -0
  70. package/dist/types/env.d.ts.map +1 -0
  71. package/dist/types/env.js +2 -0
  72. package/dist/types/env.js.map +1 -0
  73. package/package.json +37 -0
@@ -0,0 +1,157 @@
1
+ import { Hono } from "hono";
2
+ import { getConfig, updateConfig } from "../config.js";
3
+ import { getDb } from "../store/db.js";
4
+ import { readLog } from "../store/log-writer.js";
5
+ import { nanoid } from "nanoid";
6
+ export const apiRoutes = new Hono();
7
+ // --- Models ---
8
+ apiRoutes.get("/models", (c) => {
9
+ const config = getConfig();
10
+ const models = [];
11
+ for (const p of config.providers) {
12
+ if (!p.enabled)
13
+ continue;
14
+ for (const m of p.models) {
15
+ const existing = models.find((x) => x.id === m);
16
+ if (existing) {
17
+ existing.providers.push(p.id);
18
+ }
19
+ else {
20
+ models.push({ id: m, providers: [p.id] });
21
+ }
22
+ }
23
+ }
24
+ return c.json(models);
25
+ });
26
+ // --- Providers ---
27
+ apiRoutes.get("/providers", (c) => {
28
+ const config = getConfig();
29
+ const providers = config.providers.map((p) => ({
30
+ ...p,
31
+ apiKey: maskKey(p.apiKey),
32
+ }));
33
+ return c.json(providers);
34
+ });
35
+ apiRoutes.post("/providers", async (c) => {
36
+ const body = await c.req.json();
37
+ const newProvider = { id: body.id ?? nanoid(8), ...body, enabled: body.enabled ?? true };
38
+ updateConfig((raw) => {
39
+ raw.providers.push(newProvider);
40
+ });
41
+ return c.json(newProvider, 201);
42
+ });
43
+ apiRoutes.put("/providers/:id", async (c) => {
44
+ const id = c.req.param("id");
45
+ const body = await c.req.json();
46
+ if (body.apiKey && body.apiKey.includes("****")) {
47
+ delete body.apiKey;
48
+ }
49
+ updateConfig((raw) => {
50
+ const providers = raw.providers;
51
+ const idx = providers.findIndex((p) => p.id === id);
52
+ if (idx === -1)
53
+ throw new Error("Provider not found");
54
+ providers[idx] = { ...providers[idx], ...body };
55
+ });
56
+ return c.json({ ok: true });
57
+ });
58
+ apiRoutes.delete("/providers/:id", async (c) => {
59
+ const id = c.req.param("id");
60
+ updateConfig((raw) => {
61
+ raw.providers = raw.providers.filter((p) => p.id !== id);
62
+ });
63
+ return c.json({ ok: true });
64
+ });
65
+ // --- Tokens (Keys) ---
66
+ apiRoutes.get("/keys", (c) => {
67
+ const config = getConfig();
68
+ return c.json(config.tokens);
69
+ });
70
+ apiRoutes.post("/keys", async (c) => {
71
+ const body = await c.req.json();
72
+ const newToken = {
73
+ key: body.key ?? `tp-${nanoid(16)}`,
74
+ name: body.name,
75
+ allowedProviders: body.allowedProviders ?? [],
76
+ rateLimit: body.rateLimit ?? null,
77
+ enabled: body.enabled ?? true,
78
+ };
79
+ updateConfig((raw) => {
80
+ raw.tokens.push(newToken);
81
+ });
82
+ return c.json(newToken, 201);
83
+ });
84
+ apiRoutes.put("/keys/:key", async (c) => {
85
+ const key = c.req.param("key");
86
+ const body = await c.req.json();
87
+ updateConfig((raw) => {
88
+ const tokens = raw.tokens;
89
+ const idx = tokens.findIndex((t) => t.key === key);
90
+ if (idx === -1)
91
+ throw new Error("Token not found");
92
+ tokens[idx] = { ...tokens[idx], ...body };
93
+ });
94
+ return c.json({ ok: true });
95
+ });
96
+ apiRoutes.delete("/keys/:key", async (c) => {
97
+ const key = c.req.param("key");
98
+ updateConfig((raw) => {
99
+ raw.tokens = raw.tokens.filter((t) => t.key !== key);
100
+ });
101
+ return c.json({ ok: true });
102
+ });
103
+ // --- Stats ---
104
+ apiRoutes.get("/stats", (c) => {
105
+ const db = getDb();
106
+ const days = Number(c.req.query("days") ?? 7);
107
+ const tokenId = c.req.query("token_id");
108
+ let query = `SELECT * FROM usage_daily WHERE date >= date('now', '-${days} days')`;
109
+ const params = [];
110
+ if (tokenId) {
111
+ query += ` AND token_id = ?`;
112
+ params.push(tokenId);
113
+ }
114
+ query += ` ORDER BY date DESC`;
115
+ const rows = db.prepare(query).all(...params);
116
+ return c.json(rows);
117
+ });
118
+ // --- Requests ---
119
+ apiRoutes.get("/requests", (c) => {
120
+ const db = getDb();
121
+ const limit = Math.min(Number(c.req.query("limit") ?? 50), 200);
122
+ const offset = Number(c.req.query("offset") ?? 0);
123
+ const tokenId = c.req.query("token_id");
124
+ const providerId = c.req.query("provider_id");
125
+ let query = `SELECT * FROM request_index WHERE 1=1`;
126
+ const params = [];
127
+ if (tokenId) {
128
+ query += ` AND token_id = ?`;
129
+ params.push(tokenId);
130
+ }
131
+ if (providerId) {
132
+ query += ` AND provider_id = ?`;
133
+ params.push(providerId);
134
+ }
135
+ query += ` ORDER BY timestamp DESC LIMIT ? OFFSET ?`;
136
+ params.push(limit, offset);
137
+ const rows = db.prepare(query).all(...params);
138
+ const total = db.prepare(`SELECT COUNT(*) as count FROM request_index`).get();
139
+ return c.json({ data: rows, total: total.count });
140
+ });
141
+ apiRoutes.get("/requests/:id", (c) => {
142
+ const id = c.req.param("id");
143
+ const db = getDb();
144
+ const row = db.prepare(`SELECT * FROM request_index WHERE id = ?`).get(id);
145
+ if (!row)
146
+ return c.json({ error: "Not found" }, 404);
147
+ const logs = readLog(row.log_file);
148
+ return c.json({ ...row, logs });
149
+ });
150
+ function maskKey(key) {
151
+ if (key.startsWith("${"))
152
+ return key;
153
+ if (key.length <= 8)
154
+ return "****";
155
+ return key.slice(0, 4) + "****" + key.slice(-4);
156
+ }
157
+ //# sourceMappingURL=api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.js","sourceRoot":"","sources":["../../src/routes/api.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { Hono } from "hono";
2
+ import type { AppEnv } from "../types/env.js";
3
+ export declare const openaiRoutes: Hono<AppEnv, import("hono/types").BlankSchema, "/">;
4
+ //# sourceMappingURL=openai.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/routes/openai.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAK5B,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAE9C,eAAO,MAAM,YAAY,qDAAqB,CAAC"}
@@ -0,0 +1,49 @@
1
+ import { Hono } from "hono";
2
+ import { authMiddleware } from "../proxy/auth.js";
3
+ import { forwardRequest } from "../proxy/forwarder.js";
4
+ import { resolveProvider, listAvailableModels } from "../proxy/router.js";
5
+ import { openaiToAnthropic } from "../adapters/openai-to-anthropic.js";
6
+ export const openaiRoutes = new Hono();
7
+ openaiRoutes.use("/*", authMiddleware);
8
+ openaiRoutes.get("/models", (c) => {
9
+ const token = c.get("authToken");
10
+ const models = listAvailableModels(token);
11
+ return c.json({
12
+ object: "list",
13
+ data: models.map((id) => ({
14
+ id,
15
+ object: "model",
16
+ owned_by: "tokenparty",
17
+ })),
18
+ });
19
+ });
20
+ openaiRoutes.post("/chat/completions", async (c) => {
21
+ const token = c.get("authToken");
22
+ const body = await c.req.json();
23
+ const model = body.model;
24
+ const result = resolveProvider(model, token);
25
+ if ("error" in result) {
26
+ return c.json({ error: result.error }, 400);
27
+ }
28
+ const { provider } = result;
29
+ if (provider.type === "openai") {
30
+ return forwardRequest(c, provider, "/chat/completions", body, "openai");
31
+ }
32
+ const anthropicBody = openaiToAnthropic(body);
33
+ return forwardRequest(c, provider, "/v1/messages", anthropicBody, "openai");
34
+ });
35
+ openaiRoutes.all("/*", async (c) => {
36
+ const token = c.get("authToken");
37
+ const body = await c.req.json().catch(() => ({}));
38
+ const model = body.model ?? "";
39
+ const result = resolveProvider(model, token);
40
+ if ("error" in result) {
41
+ return c.json({ error: result.error }, 400);
42
+ }
43
+ if (result.provider.type !== "openai") {
44
+ return c.json({ error: "This endpoint requires an OpenAI-compatible provider" }, 400);
45
+ }
46
+ const path = new URL(c.req.url).pathname.replace(/^\/v1/, "");
47
+ return forwardRequest(c, result.provider, path, body, "openai");
48
+ });
49
+ //# sourceMappingURL=openai.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/routes/openai.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Hono } from "hono";
2
+ export declare function createServer(): Hono<import("hono/types").BlankEnv, import("hono/types").BlankSchema, "/">;
3
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAoB5B,wBAAgB,YAAY,+EAsB3B"}
package/dist/server.js ADDED
@@ -0,0 +1,38 @@
1
+ import { Hono } from "hono";
2
+ import { cors } from "hono/cors";
3
+ import { serveStatic } from "@hono/node-server/serve-static";
4
+ import path from "node:path";
5
+ import fs from "node:fs";
6
+ import { openaiRoutes } from "./routes/openai.js";
7
+ import { anthropicRoutes } from "./routes/anthropic.js";
8
+ import { apiRoutes } from "./routes/api.js";
9
+ function findDashboardRoot() {
10
+ const candidates = [
11
+ path.resolve(import.meta.dirname, "../dashboard"),
12
+ path.resolve(import.meta.dirname, "../../dashboard/dist"),
13
+ ];
14
+ for (const dir of candidates) {
15
+ if (fs.existsSync(path.join(dir, "index.html")))
16
+ return dir;
17
+ }
18
+ return null;
19
+ }
20
+ export function createServer() {
21
+ const app = new Hono();
22
+ app.use("/*", cors());
23
+ app.get("/health", (c) => c.json({ status: "ok", service: "tokenparty" }));
24
+ app.route("/v1", openaiRoutes);
25
+ app.route("/anthropic", anthropicRoutes);
26
+ app.route("/api", apiRoutes);
27
+ const dashboardRoot = findDashboardRoot();
28
+ if (dashboardRoot) {
29
+ app.use("/assets/*", serveStatic({ root: dashboardRoot }));
30
+ app.get("*", (c) => {
31
+ const filePath = path.join(dashboardRoot, "index.html");
32
+ const html = fs.readFileSync(filePath, "utf-8");
33
+ return c.html(html);
34
+ });
35
+ }
36
+ return app;
37
+ }
38
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,SAAS,iBAAiB;IACxB,MAAM,UAAU,GAAG;QACjB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,cAAc,CAAC;QACjD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,sBAAsB,CAAC;KAC1D,CAAC;IACF,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAC7B,IAAI,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;YAAE,OAAO,GAAG,CAAC;IAC9D,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,YAAY;IAC1B,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IAEvB,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;IAEtB,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IAE3E,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;IAC/B,GAAG,CAAC,KAAK,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;IACzC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAE7B,MAAM,aAAa,GAAG,iBAAiB,EAAE,CAAC;IAC1C,IAAI,aAAa,EAAE,CAAC;QAClB,GAAG,CAAC,GAAG,CAAC,WAAW,EAAE,WAAW,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;QAC3D,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE;YACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YAChD,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,GAAG,CAAC;AACb,CAAC"}
@@ -0,0 +1,4 @@
1
+ import Database from "better-sqlite3";
2
+ export declare function initDb(): Database.Database;
3
+ export declare function getDb(): Database.Database;
4
+ //# sourceMappingURL=db.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.d.ts","sourceRoot":"","sources":["../../src/store/db.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAMtC,wBAAgB,MAAM,IAAI,QAAQ,CAAC,QAAQ,CAQ1C;AAED,wBAAgB,KAAK,IAAI,QAAQ,CAAC,QAAQ,CAEzC"}
@@ -0,0 +1,49 @@
1
+ import Database from "better-sqlite3";
2
+ import path from "node:path";
3
+ import { getConfig } from "../config.js";
4
+ let db;
5
+ export function initDb() {
6
+ const config = getConfig();
7
+ const dbPath = path.resolve(process.cwd(), config.server.dataDir, "tokenparty.db");
8
+ db = new Database(dbPath);
9
+ db.pragma("journal_mode = WAL");
10
+ db.pragma("busy_timeout = 5000");
11
+ runMigrations(db);
12
+ return db;
13
+ }
14
+ export function getDb() {
15
+ return db;
16
+ }
17
+ function runMigrations(db) {
18
+ db.exec(`
19
+ CREATE TABLE IF NOT EXISTS usage_daily (
20
+ date TEXT NOT NULL,
21
+ token_id TEXT NOT NULL,
22
+ provider_id TEXT NOT NULL,
23
+ model TEXT NOT NULL,
24
+ request_count INTEGER DEFAULT 0,
25
+ input_tokens INTEGER DEFAULT 0,
26
+ output_tokens INTEGER DEFAULT 0,
27
+ PRIMARY KEY (date, token_id, provider_id, model)
28
+ );
29
+
30
+ CREATE TABLE IF NOT EXISTS request_index (
31
+ id TEXT PRIMARY KEY,
32
+ timestamp INTEGER NOT NULL,
33
+ token_id TEXT,
34
+ provider_id TEXT,
35
+ model TEXT,
36
+ input_tokens INTEGER,
37
+ output_tokens INTEGER,
38
+ latency_ms INTEGER,
39
+ status INTEGER,
40
+ log_file TEXT NOT NULL,
41
+ error TEXT
42
+ );
43
+
44
+ CREATE INDEX IF NOT EXISTS idx_request_timestamp ON request_index(timestamp);
45
+ CREATE INDEX IF NOT EXISTS idx_request_token ON request_index(token_id);
46
+ CREATE INDEX IF NOT EXISTS idx_request_provider ON request_index(provider_id);
47
+ `);
48
+ }
49
+ //# sourceMappingURL=db.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../../src/store/db.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AACtC,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,IAAI,EAAqB,CAAC;AAE1B,MAAM,UAAU,MAAM;IACpB,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IACnF,EAAE,GAAG,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC;IAC1B,EAAE,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAChC,EAAE,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;IACjC,aAAa,CAAC,EAAE,CAAC,CAAC;IAClB,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,MAAM,UAAU,KAAK;IACnB,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,SAAS,aAAa,CAAC,EAAqB;IAC1C,EAAE,CAAC,IAAI,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BP,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,17 @@
1
+ export interface LogEntry {
2
+ type: "request" | "response";
3
+ timestamp: number;
4
+ headers?: Record<string, string>;
5
+ body?: unknown;
6
+ streaming?: boolean;
7
+ streamContent?: string;
8
+ usage?: {
9
+ input_tokens: number;
10
+ output_tokens: number;
11
+ };
12
+ error?: string;
13
+ }
14
+ export declare function writeLog(requestId: string, entry: LogEntry): string;
15
+ export declare function readLog(logFile: string): LogEntry[];
16
+ export declare function headersToRecord(headers: Headers): Record<string, string>;
17
+ //# sourceMappingURL=log-writer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-writer.d.ts","sourceRoot":"","sources":["../../src/store/log-writer.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,SAAS,GAAG,UAAU,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,aAAa,EAAE,MAAM,CAAA;KAAE,CAAC;IACxD,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,QAAQ,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,GAAG,MAAM,CAWnE;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,QAAQ,EAAE,CAMnD;AAED,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAMxE"}
@@ -0,0 +1,29 @@
1
+ import fs from "node:fs";
2
+ import path from "node:path";
3
+ import { getConfig } from "../config.js";
4
+ export function writeLog(requestId, entry) {
5
+ const config = getConfig();
6
+ const date = new Date(entry.timestamp).toISOString().split("T")[0];
7
+ const dir = path.resolve(process.cwd(), config.server.logDir, date);
8
+ fs.mkdirSync(dir, { recursive: true });
9
+ const filename = `${requestId}.jsonl`;
10
+ const filepath = path.join(dir, filename);
11
+ fs.appendFileSync(filepath, JSON.stringify(entry) + "\n");
12
+ return `${date}/${filename}`;
13
+ }
14
+ export function readLog(logFile) {
15
+ const config = getConfig();
16
+ const filepath = path.resolve(process.cwd(), config.server.logDir, logFile);
17
+ if (!fs.existsSync(filepath))
18
+ return [];
19
+ const lines = fs.readFileSync(filepath, "utf-8").trim().split("\n");
20
+ return lines.map((line) => JSON.parse(line));
21
+ }
22
+ export function headersToRecord(headers) {
23
+ const result = {};
24
+ headers.forEach((value, key) => {
25
+ result[key] = value;
26
+ });
27
+ return result;
28
+ }
29
+ //# sourceMappingURL=log-writer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-writer.js","sourceRoot":"","sources":["../../src/store/log-writer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAazC,MAAM,UAAU,QAAQ,CAAC,SAAiB,EAAE,KAAe;IACzD,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACnE,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IACpE,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAEvC,MAAM,QAAQ,GAAG,GAAG,SAAS,QAAQ,CAAC;IACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC1C,EAAE,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;IAE1D,OAAO,GAAG,IAAI,IAAI,QAAQ,EAAE,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,OAAe;IACrC,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC5E,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC;QAAE,OAAO,EAAE,CAAC;IACxC,MAAM,KAAK,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACpE,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,OAAgB;IAC9C,MAAM,MAAM,GAA2B,EAAE,CAAC;IAC1C,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QAC7B,MAAM,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IACtB,CAAC,CAAC,CAAC;IACH,OAAO,MAAM,CAAC;AAChB,CAAC"}
@@ -0,0 +1,157 @@
1
+ import { z } from "zod";
2
+ export declare const ProviderSchema: z.ZodObject<{
3
+ id: z.ZodString;
4
+ type: z.ZodEnum<["openai", "anthropic"]>;
5
+ name: z.ZodString;
6
+ apiKey: z.ZodString;
7
+ baseUrl: z.ZodString;
8
+ models: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
9
+ enabled: z.ZodDefault<z.ZodBoolean>;
10
+ }, "strip", z.ZodTypeAny, {
11
+ id: string;
12
+ type: "openai" | "anthropic";
13
+ name: string;
14
+ apiKey: string;
15
+ baseUrl: string;
16
+ models: string[];
17
+ enabled: boolean;
18
+ }, {
19
+ id: string;
20
+ type: "openai" | "anthropic";
21
+ name: string;
22
+ apiKey: string;
23
+ baseUrl: string;
24
+ models?: string[] | undefined;
25
+ enabled?: boolean | undefined;
26
+ }>;
27
+ export declare const TokenSchema: z.ZodObject<{
28
+ key: z.ZodString;
29
+ name: z.ZodString;
30
+ allowedProviders: z.ZodArray<z.ZodString, "many">;
31
+ rateLimit: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
32
+ enabled: z.ZodDefault<z.ZodBoolean>;
33
+ }, "strip", z.ZodTypeAny, {
34
+ name: string;
35
+ enabled: boolean;
36
+ key: string;
37
+ allowedProviders: string[];
38
+ rateLimit?: number | null | undefined;
39
+ }, {
40
+ name: string;
41
+ key: string;
42
+ allowedProviders: string[];
43
+ enabled?: boolean | undefined;
44
+ rateLimit?: number | null | undefined;
45
+ }>;
46
+ export declare const ConfigSchema: z.ZodObject<{
47
+ server: z.ZodObject<{
48
+ port: z.ZodDefault<z.ZodNumber>;
49
+ host: z.ZodDefault<z.ZodString>;
50
+ logDir: z.ZodDefault<z.ZodString>;
51
+ dataDir: z.ZodDefault<z.ZodString>;
52
+ }, "strip", z.ZodTypeAny, {
53
+ port: number;
54
+ host: string;
55
+ logDir: string;
56
+ dataDir: string;
57
+ }, {
58
+ port?: number | undefined;
59
+ host?: string | undefined;
60
+ logDir?: string | undefined;
61
+ dataDir?: string | undefined;
62
+ }>;
63
+ providers: z.ZodArray<z.ZodObject<{
64
+ id: z.ZodString;
65
+ type: z.ZodEnum<["openai", "anthropic"]>;
66
+ name: z.ZodString;
67
+ apiKey: z.ZodString;
68
+ baseUrl: z.ZodString;
69
+ models: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
70
+ enabled: z.ZodDefault<z.ZodBoolean>;
71
+ }, "strip", z.ZodTypeAny, {
72
+ id: string;
73
+ type: "openai" | "anthropic";
74
+ name: string;
75
+ apiKey: string;
76
+ baseUrl: string;
77
+ models: string[];
78
+ enabled: boolean;
79
+ }, {
80
+ id: string;
81
+ type: "openai" | "anthropic";
82
+ name: string;
83
+ apiKey: string;
84
+ baseUrl: string;
85
+ models?: string[] | undefined;
86
+ enabled?: boolean | undefined;
87
+ }>, "many">;
88
+ tokens: z.ZodArray<z.ZodObject<{
89
+ key: z.ZodString;
90
+ name: z.ZodString;
91
+ allowedProviders: z.ZodArray<z.ZodString, "many">;
92
+ rateLimit: z.ZodOptional<z.ZodNullable<z.ZodNumber>>;
93
+ enabled: z.ZodDefault<z.ZodBoolean>;
94
+ }, "strip", z.ZodTypeAny, {
95
+ name: string;
96
+ enabled: boolean;
97
+ key: string;
98
+ allowedProviders: string[];
99
+ rateLimit?: number | null | undefined;
100
+ }, {
101
+ name: string;
102
+ key: string;
103
+ allowedProviders: string[];
104
+ enabled?: boolean | undefined;
105
+ rateLimit?: number | null | undefined;
106
+ }>, "many">;
107
+ }, "strip", z.ZodTypeAny, {
108
+ server: {
109
+ port: number;
110
+ host: string;
111
+ logDir: string;
112
+ dataDir: string;
113
+ };
114
+ providers: {
115
+ id: string;
116
+ type: "openai" | "anthropic";
117
+ name: string;
118
+ apiKey: string;
119
+ baseUrl: string;
120
+ models: string[];
121
+ enabled: boolean;
122
+ }[];
123
+ tokens: {
124
+ name: string;
125
+ enabled: boolean;
126
+ key: string;
127
+ allowedProviders: string[];
128
+ rateLimit?: number | null | undefined;
129
+ }[];
130
+ }, {
131
+ server: {
132
+ port?: number | undefined;
133
+ host?: string | undefined;
134
+ logDir?: string | undefined;
135
+ dataDir?: string | undefined;
136
+ };
137
+ providers: {
138
+ id: string;
139
+ type: "openai" | "anthropic";
140
+ name: string;
141
+ apiKey: string;
142
+ baseUrl: string;
143
+ models?: string[] | undefined;
144
+ enabled?: boolean | undefined;
145
+ }[];
146
+ tokens: {
147
+ name: string;
148
+ key: string;
149
+ allowedProviders: string[];
150
+ enabled?: boolean | undefined;
151
+ rateLimit?: number | null | undefined;
152
+ }[];
153
+ }>;
154
+ export type Provider = z.infer<typeof ProviderSchema>;
155
+ export type Token = z.infer<typeof TokenSchema>;
156
+ export type Config = z.infer<typeof ConfigSchema>;
157
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/types/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,eAAO,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;EAQzB,CAAC;AAEH,eAAO,MAAM,WAAW;;;;;;;;;;;;;;;;;;EAMtB,CAAC;AAEH,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EASvB,CAAC;AAEH,MAAM,MAAM,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;AACtD,MAAM,MAAM,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,WAAW,CAAC,CAAC;AAChD,MAAM,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,YAAY,CAAC,CAAC"}
@@ -0,0 +1,28 @@
1
+ import { z } from "zod";
2
+ export const ProviderSchema = z.object({
3
+ id: z.string(),
4
+ type: z.enum(["openai", "anthropic"]),
5
+ name: z.string(),
6
+ apiKey: z.string(),
7
+ baseUrl: z.string().url(),
8
+ models: z.array(z.string()).default([]),
9
+ enabled: z.boolean().default(true),
10
+ });
11
+ export const TokenSchema = z.object({
12
+ key: z.string(),
13
+ name: z.string(),
14
+ allowedProviders: z.array(z.string()),
15
+ rateLimit: z.number().nullable().optional(),
16
+ enabled: z.boolean().default(true),
17
+ });
18
+ export const ConfigSchema = z.object({
19
+ server: z.object({
20
+ port: z.number().default(3456),
21
+ host: z.string().default("0.0.0.0"),
22
+ logDir: z.string().default("./logs"),
23
+ dataDir: z.string().default("./data"),
24
+ }),
25
+ providers: z.array(ProviderSchema),
26
+ tokens: z.array(TokenSchema),
27
+ });
28
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/types/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;IACrC,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;IAClB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE;IACzB,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC;IACvC,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;CACnC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,CAAC,MAAM,CAAC;IAClC,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;IACf,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,gBAAgB,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IACrC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE;IAC3C,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;CACnC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,CAAC,MAAM,CAAC;IACnC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC;QACf,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC;QAC9B,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC;QACnC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;QACpC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC;KACtC,CAAC;IACF,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC;IAClC,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC;CAC7B,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { Token } from "./config.js";
2
+ export type AppEnv = {
3
+ Variables: {
4
+ authToken: Token;
5
+ };
6
+ };
7
+ //# sourceMappingURL=env.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.d.ts","sourceRoot":"","sources":["../../src/types/env.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AAEzC,MAAM,MAAM,MAAM,GAAG;IACnB,SAAS,EAAE;QACT,SAAS,EAAE,KAAK,CAAC;KAClB,CAAC;CACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=env.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"env.js","sourceRoot":"","sources":["../../src/types/env.ts"],"names":[],"mappings":""}