devchain-cli 0.15.0 → 0.16.0
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.
- package/README.md +5 -4
- package/dist/cli.js +14 -5
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js +1 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-client.service.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.d.ts +3 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js +17 -4
- package/dist/server/modules/cloud-tunnel/services/tunnel-handler.service.js.map +1 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.d.ts +5 -1
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js +12 -2
- package/dist/server/modules/cloud-tunnel/services/tunnel-rpc-crypto.service.js.map +1 -1
- package/dist/server/modules/core/core-normal.module.js +2 -9
- package/dist/server/modules/core/core-normal.module.js.map +1 -1
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.d.ts +2 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.js +21 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.module.js.map +1 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.d.ts +21 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.js +249 -0
- package/dist/server/modules/core/services/antigravity-trusted-workspaces.service.js.map +1 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.d.ts +2 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.js +21 -0
- package/dist/server/modules/core/services/copilot-auth-probe.module.js.map +1 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.d.ts +7 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.js +63 -0
- package/dist/server/modules/core/services/copilot-auth-probe.service.js.map +1 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.module.d.ts +2 -0
- package/dist/server/modules/core/services/{gemini-trusted-folders.module.js → copilot-trusted-folders.module.js} +9 -9
- package/dist/server/modules/core/services/copilot-trusted-folders.module.js.map +1 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.d.ts +22 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.js +228 -0
- package/dist/server/modules/core/services/copilot-trusted-folders.service.js.map +1 -0
- package/dist/server/modules/core/services/preflight.service.d.ts +1 -0
- package/dist/server/modules/core/services/preflight.service.js +35 -3
- package/dist/server/modules/core/services/preflight.service.js.map +1 -1
- package/dist/server/modules/core/services/trust-folders-logic.d.ts +11 -0
- package/dist/server/modules/core/services/trust-folders-logic.js +33 -0
- package/dist/server/modules/core/services/trust-folders-logic.js.map +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.d.ts +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js +1 -0
- package/dist/server/modules/e2ee/controllers/e2ee-pairing.controller.js.map +1 -1
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.d.ts +8 -1
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.js +31 -4
- package/dist/server/modules/e2ee/services/e2ee-device-store.service.js.map +1 -1
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.d.ts +1 -0
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.js +2 -1
- package/dist/server/modules/e2ee/services/e2ee-pairing.service.js.map +1 -1
- package/dist/server/modules/e2ee/services/e2ee-trust.service.d.ts +1 -1
- package/dist/server/modules/e2ee/services/e2ee-trust.service.js +5 -2
- package/dist/server/modules/e2ee/services/e2ee-trust.service.js.map +1 -1
- package/dist/server/modules/events/catalog/claude.hooks.session.started.d.ts +6 -0
- package/dist/server/modules/events/catalog/claude.hooks.session.started.js +2 -0
- package/dist/server/modules/events/catalog/claude.hooks.session.started.js.map +1 -1
- package/dist/server/modules/events/catalog/index.d.ts +16 -10
- package/dist/server/modules/events/catalog/session.activity.changed.d.ts +2 -2
- package/dist/server/modules/events/catalog/session.transcript.discovered.d.ts +2 -2
- package/dist/server/modules/events/catalog/session.transcript.ended.d.ts +2 -2
- package/dist/server/modules/events/catalog/session.transcript.updated.d.ts +2 -2
- package/dist/server/modules/events/catalog/terminal.watcher.triggered.d.ts +2 -2
- package/dist/server/modules/hooks/dtos/hook-event.dto.d.ts +126 -10
- package/dist/server/modules/hooks/dtos/hook-event.dto.js +22 -6
- package/dist/server/modules/hooks/dtos/hook-event.dto.js.map +1 -1
- package/dist/server/modules/hooks/hooks.module.js +13 -2
- package/dist/server/modules/hooks/hooks.module.js.map +1 -1
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.d.ts +13 -0
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.js +185 -0
- package/dist/server/modules/hooks/services/copilot-hooks-config.service.js.map +1 -0
- package/dist/server/modules/hooks/services/hooks.service.d.ts +1 -0
- package/dist/server/modules/hooks/services/hooks.service.js +18 -1
- package/dist/server/modules/hooks/services/hooks.service.js.map +1 -1
- package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +2 -2
- package/dist/server/modules/orchestrator/docker/services/docker.service.js +16 -3
- package/dist/server/modules/orchestrator/docker/services/docker.service.js.map +1 -1
- package/dist/server/modules/providers/adapters/antigravity.adapter.d.ts +22 -0
- package/dist/server/modules/providers/adapters/antigravity.adapter.js +81 -0
- package/dist/server/modules/providers/adapters/antigravity.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/capabilities/index.d.ts +2 -2
- package/dist/server/modules/providers/adapters/capabilities/index.js +3 -1
- package/dist/server/modules/providers/adapters/capabilities/index.js.map +1 -1
- package/dist/server/modules/providers/adapters/capabilities/type-guards.d.ts +16 -1
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js +8 -0
- package/dist/server/modules/providers/adapters/capabilities/type-guards.js.map +1 -1
- package/dist/server/modules/providers/adapters/codex.adapter.d.ts +1 -0
- package/dist/server/modules/providers/adapters/codex.adapter.js +10 -4
- package/dist/server/modules/providers/adapters/codex.adapter.js.map +1 -1
- package/dist/server/modules/providers/adapters/copilot.adapter.d.ts +31 -0
- package/dist/server/modules/providers/adapters/copilot.adapter.js +122 -0
- package/dist/server/modules/providers/adapters/copilot.adapter.js.map +1 -0
- package/dist/server/modules/providers/adapters/index.d.ts +1 -1
- package/dist/server/modules/providers/adapters/index.js +1 -1
- package/dist/server/modules/providers/adapters/index.js.map +1 -1
- package/dist/server/modules/providers/adapters/provider-adapter.factory.d.ts +3 -2
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js +8 -5
- package/dist/server/modules/providers/adapters/provider-adapter.factory.js.map +1 -1
- package/dist/server/modules/providers/adapters/provider-adapter.interface.d.ts +4 -0
- package/dist/server/modules/providers/adapters/provider-adapters.module.js +19 -4
- package/dist/server/modules/providers/adapters/provider-adapters.module.js.map +1 -1
- package/dist/server/modules/providers/controllers/provider-models.controller.js +3 -2
- package/dist/server/modules/providers/controllers/provider-models.controller.js.map +1 -1
- package/dist/server/modules/providers/providers.module.js +1 -0
- package/dist/server/modules/providers/providers.module.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.d.ts +17 -0
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.js +264 -0
- package/dist/server/modules/providers/services/mcp-registration/antigravity-mcp-registration.adapter.js.map +1 -0
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js +5 -6
- package/dist/server/modules/providers/services/mcp-registration/cli-mcp-registration.adapter.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/index.d.ts +1 -0
- package/dist/server/modules/providers/services/mcp-registration/index.js +3 -1
- package/dist/server/modules/providers/services/mcp-registration/index.js.map +1 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.d.ts +3 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js +6 -1
- package/dist/server/modules/providers/services/mcp-registration/mcp-registration.port.js.map +1 -1
- package/dist/server/modules/seeders/seeders/0009_seed_remove_gemini_provider.d.ts +3 -0
- package/dist/server/modules/seeders/seeders/0009_seed_remove_gemini_provider.js +64 -0
- package/dist/server/modules/seeders/seeders/0009_seed_remove_gemini_provider.js.map +1 -0
- package/dist/server/modules/seeders/services/data-seeder.service.js +2 -0
- package/dist/server/modules/seeders/services/data-seeder.service.js.map +1 -1
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.d.ts +12 -0
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.js +41 -0
- package/dist/server/modules/session-reader/__fixtures__/antigravity-fixture-db.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/antigravity-session-reader.adapter.d.ts +30 -0
- package/dist/server/modules/session-reader/adapters/antigravity-session-reader.adapter.js +268 -0
- package/dist/server/modules/session-reader/adapters/antigravity-session-reader.adapter.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/{gemini-session-reader.adapter.d.ts → copilot-session-reader.adapter.d.ts} +4 -5
- package/dist/server/modules/session-reader/adapters/{gemini-session-reader.adapter.js → copilot-session-reader.adapter.js} +35 -68
- package/dist/server/modules/session-reader/adapters/copilot-session-reader.adapter.js.map +1 -0
- package/dist/server/modules/session-reader/adapters/session-reader-adapter.factory.js.map +1 -1
- package/dist/server/modules/session-reader/data/pricing.json +126 -10
- package/dist/server/modules/session-reader/dtos/unified-session.types.d.ts +6 -0
- package/dist/server/modules/session-reader/dtos/unified-session.types.js.map +1 -1
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.d.ts +16 -0
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.js +307 -0
- package/dist/server/modules/session-reader/parsers/antigravity-jsonl.parser.js.map +1 -0
- package/dist/server/modules/session-reader/parsers/{gemini-json.parser.d.ts → copilot-jsonl.parser.d.ts} +4 -3
- package/dist/server/modules/session-reader/parsers/copilot-jsonl.parser.js +432 -0
- package/dist/server/modules/session-reader/parsers/copilot-jsonl.parser.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.d.ts +25 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.js +142 -0
- package/dist/server/modules/session-reader/readers/antigravity-metrics.reader.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.d.ts +6 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.js +35 -0
- package/dist/server/modules/session-reader/readers/antigravity-model-pricing.js.map +1 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.d.ts +24 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.js +80 -0
- package/dist/server/modules/session-reader/readers/antigravity-transcript.reader.js.map +1 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.d.ts +10 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.js +37 -0
- package/dist/server/modules/session-reader/readers/copilot-model-pricing.js.map +1 -0
- package/dist/server/modules/session-reader/readers/protobuf-wire.d.ts +13 -0
- package/dist/server/modules/session-reader/readers/protobuf-wire.js +94 -0
- package/dist/server/modules/session-reader/readers/protobuf-wire.js.map +1 -0
- package/dist/server/modules/session-reader/services/transcript-path-validator.service.js +2 -1
- package/dist/server/modules/session-reader/services/transcript-path-validator.service.js.map +1 -1
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.d.ts +1 -0
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js +40 -8
- package/dist/server/modules/session-reader/services/transcript-persistence.listener.js.map +1 -1
- package/dist/server/modules/session-reader/session-reader.module.d.ts +5 -3
- package/dist/server/modules/session-reader/session-reader.module.js +14 -8
- package/dist/server/modules/session-reader/session-reader.module.js.map +1 -1
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.d.ts +2 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js +13 -0
- package/dist/server/modules/sessions/services/provider-launch-config/provider-launch-config.service.js.map +1 -1
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.d.ts +8 -0
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js +8 -1
- package/dist/server/modules/sessions/services/session-runtime/__test-utils__/pipeline-harness.js.map +1 -1
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.d.ts +5 -1
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js +42 -5
- package/dist/server/modules/sessions/services/session-runtime/session-launch-pipeline.service.js.map +1 -1
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js +1 -0
- package/dist/server/modules/sessions/services/session-runtime/session-restore-pipeline.service.js.map +1 -1
- package/dist/server/modules/subscribers/events/event-fields-catalog.js +5 -3
- package/dist/server/modules/subscribers/events/event-fields-catalog.js.map +1 -1
- package/dist/server/templates/3-agents-dev.json +172 -139
- package/dist/server/templates/teams-dev.json +271 -183
- package/dist/server/tsconfig.tsbuildinfo +1 -1
- package/dist/server/ui/assets/{ReviewDetailPage-BpPjTAgL.js → ReviewDetailPage-BDisSE9l.js} +1 -1
- package/dist/server/ui/assets/{ReviewsPage-CAs14WVx.js → ReviewsPage-3puoJiOQ.js} +1 -1
- package/dist/server/ui/assets/{index-DhGz-UAr.js → index-zlQ1ekQ2.js} +43 -40
- package/dist/server/ui/assets/{useReviewSubscription-CscSQD7B.js → useReviewSubscription-wTrdkdi0.js} +1 -1
- package/dist/server/ui/index.html +1 -1
- package/dist/templates/3-agents-dev.json +172 -139
- package/dist/templates/teams-dev.json +271 -183
- package/package.json +9 -1
- package/dist/server/modules/core/services/gemini-trusted-folders.module.d.ts +0 -2
- package/dist/server/modules/core/services/gemini-trusted-folders.module.js.map +0 -1
- package/dist/server/modules/core/services/gemini-trusted-folders.service.d.ts +0 -26
- package/dist/server/modules/core/services/gemini-trusted-folders.service.js +0 -181
- package/dist/server/modules/core/services/gemini-trusted-folders.service.js.map +0 -1
- package/dist/server/modules/providers/adapters/gemini.adapter.d.ts +0 -27
- package/dist/server/modules/providers/adapters/gemini.adapter.js +0 -119
- package/dist/server/modules/providers/adapters/gemini.adapter.js.map +0 -1
- package/dist/server/modules/session-reader/adapters/gemini-session-reader.adapter.js.map +0 -1
- package/dist/server/modules/session-reader/parsers/gemini-json.parser.js +0 -380
- package/dist/server/modules/session-reader/parsers/gemini-json.parser.js.map +0 -1
|
@@ -0,0 +1,432 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.parseCopilotJsonl = parseCopilotJsonl;
|
|
37
|
+
const fs = __importStar(require("node:fs"));
|
|
38
|
+
const readline = __importStar(require("node:readline"));
|
|
39
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
40
|
+
const estimate_content_tokens_1 = require("../adapters/utils/estimate-content-tokens");
|
|
41
|
+
const copilot_model_pricing_1 = require("../readers/copilot-model-pricing");
|
|
42
|
+
const logger = (0, logger_1.createLogger)('CopilotJsonlParser');
|
|
43
|
+
const MAX_LINE_BYTES = 10 * 1024 * 1024;
|
|
44
|
+
function numOr(v) {
|
|
45
|
+
return typeof v === 'number' && Number.isFinite(v) ? v : undefined;
|
|
46
|
+
}
|
|
47
|
+
const stubPricing = {
|
|
48
|
+
calculateMessageCost: () => 0,
|
|
49
|
+
getContextWindowSize: () => 200_000,
|
|
50
|
+
};
|
|
51
|
+
async function parseCopilotJsonl(filePath, options) {
|
|
52
|
+
const byteOffset = options?.byteOffset ?? 0;
|
|
53
|
+
const maxMessages = options?.maxMessages;
|
|
54
|
+
const includeToolCalls = options?.includeToolCalls ?? true;
|
|
55
|
+
const pricing = options?.pricingService;
|
|
56
|
+
const messages = [];
|
|
57
|
+
let messageIndex = 0;
|
|
58
|
+
let sessionId;
|
|
59
|
+
let primaryModel = '';
|
|
60
|
+
const modelsSet = new Set();
|
|
61
|
+
const authUsageByModel = new Map();
|
|
62
|
+
let nativeCredits = 0;
|
|
63
|
+
let seenShutdown = false;
|
|
64
|
+
let lastContextTokens = 0;
|
|
65
|
+
let lastContextBreakdown;
|
|
66
|
+
let liveOutputTokens = 0;
|
|
67
|
+
let firstTimestamp;
|
|
68
|
+
let lastTimestamp;
|
|
69
|
+
let visibleContextTokens = 0;
|
|
70
|
+
let assistantBuffer = null;
|
|
71
|
+
let oversizedLineCount = 0;
|
|
72
|
+
let bytesRead = byteOffset;
|
|
73
|
+
const stream = fs.createReadStream(filePath, {
|
|
74
|
+
start: byteOffset,
|
|
75
|
+
encoding: 'utf8',
|
|
76
|
+
});
|
|
77
|
+
const rl = readline.createInterface({
|
|
78
|
+
input: stream,
|
|
79
|
+
crlfDelay: Infinity,
|
|
80
|
+
});
|
|
81
|
+
function trackTimestamp(ts) {
|
|
82
|
+
if (!firstTimestamp || ts < firstTimestamp)
|
|
83
|
+
firstTimestamp = ts;
|
|
84
|
+
if (!lastTimestamp || ts > lastTimestamp)
|
|
85
|
+
lastTimestamp = ts;
|
|
86
|
+
}
|
|
87
|
+
function flushAssistantBuffer() {
|
|
88
|
+
if (!assistantBuffer)
|
|
89
|
+
return;
|
|
90
|
+
const buf = assistantBuffer;
|
|
91
|
+
assistantBuffer = null;
|
|
92
|
+
if (buf.content.length === 0 && buf.toolCalls.length === 0 && buf.toolResults.length === 0) {
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
const msg = {
|
|
96
|
+
id: `copilot-asst-${messageIndex++}`,
|
|
97
|
+
parentId: messages.length > 0 ? messages[messages.length - 1].id : null,
|
|
98
|
+
role: 'assistant',
|
|
99
|
+
timestamp: buf.timestamp,
|
|
100
|
+
content: buf.content,
|
|
101
|
+
model: buf.model || undefined,
|
|
102
|
+
toolCalls: buf.toolCalls,
|
|
103
|
+
toolResults: buf.toolResults,
|
|
104
|
+
usage: { input: 0, output: buf.outputTokens, cacheRead: 0, cacheCreation: 0 },
|
|
105
|
+
isMeta: false,
|
|
106
|
+
isSidechain: false,
|
|
107
|
+
stopReason: 'end_turn',
|
|
108
|
+
};
|
|
109
|
+
messages.push(msg);
|
|
110
|
+
visibleContextTokens += (0, estimate_content_tokens_1.estimateMessageTokens)(msg.content);
|
|
111
|
+
}
|
|
112
|
+
function ensureAssistantBuffer(ts, model) {
|
|
113
|
+
if (!assistantBuffer) {
|
|
114
|
+
assistantBuffer = {
|
|
115
|
+
timestamp: ts,
|
|
116
|
+
model,
|
|
117
|
+
content: [],
|
|
118
|
+
toolCalls: [],
|
|
119
|
+
toolResults: [],
|
|
120
|
+
outputTokens: 0,
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
else if (model) {
|
|
124
|
+
assistantBuffer.model = model;
|
|
125
|
+
}
|
|
126
|
+
return assistantBuffer;
|
|
127
|
+
}
|
|
128
|
+
function attachToolResult(block, resultEntry, ts) {
|
|
129
|
+
if (assistantBuffer) {
|
|
130
|
+
assistantBuffer.content.push(block);
|
|
131
|
+
assistantBuffer.toolResults.push(resultEntry);
|
|
132
|
+
return;
|
|
133
|
+
}
|
|
134
|
+
const last = messages.length > 0 ? messages[messages.length - 1] : null;
|
|
135
|
+
if (last && last.role === 'assistant') {
|
|
136
|
+
last.content.push(block);
|
|
137
|
+
last.toolResults.push(resultEntry);
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
const msg = {
|
|
141
|
+
id: `copilot-toolresult-${messageIndex++}`,
|
|
142
|
+
parentId: messages.length > 0 ? messages[messages.length - 1].id : null,
|
|
143
|
+
role: 'user',
|
|
144
|
+
timestamp: ts,
|
|
145
|
+
content: [block],
|
|
146
|
+
toolCalls: [],
|
|
147
|
+
toolResults: [resultEntry],
|
|
148
|
+
isMeta: true,
|
|
149
|
+
isSidechain: false,
|
|
150
|
+
};
|
|
151
|
+
messages.push(msg);
|
|
152
|
+
}
|
|
153
|
+
try {
|
|
154
|
+
for await (const line of rl) {
|
|
155
|
+
const lineBytes = Buffer.byteLength(line, 'utf8') + 1;
|
|
156
|
+
bytesRead += lineBytes;
|
|
157
|
+
if (!line.trim())
|
|
158
|
+
continue;
|
|
159
|
+
if (lineBytes > MAX_LINE_BYTES) {
|
|
160
|
+
logger.warn({ filePath, lineBytes, byteOffset: bytesRead - lineBytes, snippet: line.slice(0, 200) }, 'Skipping oversized JSONL line (>10MB)');
|
|
161
|
+
oversizedLineCount++;
|
|
162
|
+
continue;
|
|
163
|
+
}
|
|
164
|
+
let entry;
|
|
165
|
+
try {
|
|
166
|
+
entry = JSON.parse(line);
|
|
167
|
+
}
|
|
168
|
+
catch {
|
|
169
|
+
logger.warn({ filePath }, 'Skipping malformed JSONL line');
|
|
170
|
+
continue;
|
|
171
|
+
}
|
|
172
|
+
if (!entry.type)
|
|
173
|
+
continue;
|
|
174
|
+
const data = entry.data ?? {};
|
|
175
|
+
const ts = entry.timestamp ? new Date(entry.timestamp) : new Date();
|
|
176
|
+
trackTimestamp(ts);
|
|
177
|
+
switch (entry.type) {
|
|
178
|
+
case 'session.start': {
|
|
179
|
+
const sid = data.sessionId;
|
|
180
|
+
if (typeof sid === 'string')
|
|
181
|
+
sessionId = sid;
|
|
182
|
+
break;
|
|
183
|
+
}
|
|
184
|
+
case 'session.resume': {
|
|
185
|
+
break;
|
|
186
|
+
}
|
|
187
|
+
case 'session.model_change': {
|
|
188
|
+
const newModel = data.newModel;
|
|
189
|
+
if (typeof newModel === 'string' && newModel !== 'auto') {
|
|
190
|
+
primaryModel = newModel;
|
|
191
|
+
modelsSet.add(newModel);
|
|
192
|
+
}
|
|
193
|
+
break;
|
|
194
|
+
}
|
|
195
|
+
case 'session.info': {
|
|
196
|
+
break;
|
|
197
|
+
}
|
|
198
|
+
case 'session.shutdown': {
|
|
199
|
+
flushAssistantBuffer();
|
|
200
|
+
seenShutdown = true;
|
|
201
|
+
const shutdown = data;
|
|
202
|
+
const mm = shutdown.modelMetrics ?? {};
|
|
203
|
+
for (const model of Object.keys(mm)) {
|
|
204
|
+
modelsSet.add(model);
|
|
205
|
+
const u = mm[model]?.usage ?? {};
|
|
206
|
+
const prev = authUsageByModel.get(model) ?? {
|
|
207
|
+
input: 0,
|
|
208
|
+
output: 0,
|
|
209
|
+
cacheRead: 0,
|
|
210
|
+
cacheWrite: 0,
|
|
211
|
+
reasoning: 0,
|
|
212
|
+
};
|
|
213
|
+
prev.input += u.inputTokens ?? 0;
|
|
214
|
+
prev.output += u.outputTokens ?? 0;
|
|
215
|
+
prev.cacheRead += u.cacheReadTokens ?? 0;
|
|
216
|
+
prev.cacheWrite += u.cacheWriteTokens ?? 0;
|
|
217
|
+
prev.reasoning += u.reasoningTokens ?? 0;
|
|
218
|
+
authUsageByModel.set(model, prev);
|
|
219
|
+
nativeCredits += mm[model]?.requests?.cost ?? 0;
|
|
220
|
+
}
|
|
221
|
+
if (typeof shutdown.currentModel === 'string' && shutdown.currentModel !== 'auto') {
|
|
222
|
+
primaryModel = shutdown.currentModel;
|
|
223
|
+
modelsSet.add(shutdown.currentModel);
|
|
224
|
+
}
|
|
225
|
+
if (typeof shutdown.currentTokens === 'number')
|
|
226
|
+
lastContextTokens = shutdown.currentTokens;
|
|
227
|
+
const sys = numOr(shutdown.systemTokens);
|
|
228
|
+
const conv = numOr(shutdown.conversationTokens);
|
|
229
|
+
const tools = numOr(shutdown.toolDefinitionsTokens);
|
|
230
|
+
if (sys !== undefined || conv !== undefined || tools !== undefined) {
|
|
231
|
+
lastContextBreakdown = {
|
|
232
|
+
system: sys ?? 0,
|
|
233
|
+
conversation: conv ?? 0,
|
|
234
|
+
toolDefinitions: tools ?? 0,
|
|
235
|
+
};
|
|
236
|
+
}
|
|
237
|
+
break;
|
|
238
|
+
}
|
|
239
|
+
case 'system.message': {
|
|
240
|
+
break;
|
|
241
|
+
}
|
|
242
|
+
case 'user.message': {
|
|
243
|
+
flushAssistantBuffer();
|
|
244
|
+
const content = typeof data.content === 'string' ? data.content : '';
|
|
245
|
+
if (!content)
|
|
246
|
+
break;
|
|
247
|
+
const msg = {
|
|
248
|
+
id: `copilot-user-${messageIndex++}`,
|
|
249
|
+
parentId: messages.length > 0 ? messages[messages.length - 1].id : null,
|
|
250
|
+
role: 'user',
|
|
251
|
+
timestamp: ts,
|
|
252
|
+
content: [{ type: 'text', text: content }],
|
|
253
|
+
toolCalls: [],
|
|
254
|
+
toolResults: [],
|
|
255
|
+
isMeta: false,
|
|
256
|
+
isSidechain: false,
|
|
257
|
+
};
|
|
258
|
+
messages.push(msg);
|
|
259
|
+
visibleContextTokens += (0, estimate_content_tokens_1.estimateMessageTokens)(msg.content);
|
|
260
|
+
break;
|
|
261
|
+
}
|
|
262
|
+
case 'assistant.turn_start': {
|
|
263
|
+
break;
|
|
264
|
+
}
|
|
265
|
+
case 'assistant.message': {
|
|
266
|
+
const model = typeof data.model === 'string' ? data.model : '';
|
|
267
|
+
if (model) {
|
|
268
|
+
primaryModel = model;
|
|
269
|
+
modelsSet.add(model);
|
|
270
|
+
}
|
|
271
|
+
const buf = ensureAssistantBuffer(ts, model);
|
|
272
|
+
const reasoningText = data.reasoningText;
|
|
273
|
+
if (typeof reasoningText === 'string' && reasoningText) {
|
|
274
|
+
buf.content.push({ type: 'thinking', thinking: reasoningText });
|
|
275
|
+
}
|
|
276
|
+
const text = data.content;
|
|
277
|
+
if (typeof text === 'string' && text) {
|
|
278
|
+
buf.content.push({ type: 'text', text });
|
|
279
|
+
}
|
|
280
|
+
if (includeToolCalls && Array.isArray(data.toolRequests)) {
|
|
281
|
+
for (const tr of data.toolRequests) {
|
|
282
|
+
const callId = tr.toolCallId;
|
|
283
|
+
const name = tr.name;
|
|
284
|
+
if (!callId || !name)
|
|
285
|
+
continue;
|
|
286
|
+
const input = tr.arguments ?? {};
|
|
287
|
+
buf.content.push({ type: 'tool_call', toolCallId: callId, toolName: name, input });
|
|
288
|
+
buf.toolCalls.push({
|
|
289
|
+
id: callId,
|
|
290
|
+
name,
|
|
291
|
+
input,
|
|
292
|
+
isTask: name === 'Task',
|
|
293
|
+
});
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
const out = typeof data.outputTokens === 'number' ? data.outputTokens : 0;
|
|
297
|
+
buf.outputTokens += out;
|
|
298
|
+
liveOutputTokens += out;
|
|
299
|
+
break;
|
|
300
|
+
}
|
|
301
|
+
case 'assistant.turn_end': {
|
|
302
|
+
break;
|
|
303
|
+
}
|
|
304
|
+
case 'tool.execution_start': {
|
|
305
|
+
break;
|
|
306
|
+
}
|
|
307
|
+
case 'tool.execution_complete': {
|
|
308
|
+
if (!includeToolCalls)
|
|
309
|
+
break;
|
|
310
|
+
const callId = typeof data.toolCallId === 'string' ? data.toolCallId : '';
|
|
311
|
+
if (!callId)
|
|
312
|
+
break;
|
|
313
|
+
const result = data.result ?? {};
|
|
314
|
+
const rawContent = result.content;
|
|
315
|
+
const resultContent = typeof rawContent === 'string' ? rawContent : JSON.stringify(rawContent ?? '');
|
|
316
|
+
const isError = data.success === false;
|
|
317
|
+
const block = {
|
|
318
|
+
type: 'tool_result',
|
|
319
|
+
toolCallId: callId,
|
|
320
|
+
content: resultContent,
|
|
321
|
+
isError,
|
|
322
|
+
};
|
|
323
|
+
const resultEntry = {
|
|
324
|
+
toolCallId: callId,
|
|
325
|
+
content: resultContent,
|
|
326
|
+
isError,
|
|
327
|
+
};
|
|
328
|
+
attachToolResult(block, resultEntry, ts);
|
|
329
|
+
break;
|
|
330
|
+
}
|
|
331
|
+
case 'hook.start':
|
|
332
|
+
case 'hook.end': {
|
|
333
|
+
break;
|
|
334
|
+
}
|
|
335
|
+
default:
|
|
336
|
+
logger.debug({ type: entry.type }, 'Skipping unknown Copilot event type');
|
|
337
|
+
break;
|
|
338
|
+
}
|
|
339
|
+
if (maxMessages && messages.length >= maxMessages)
|
|
340
|
+
break;
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
finally {
|
|
344
|
+
rl.close();
|
|
345
|
+
stream.destroy();
|
|
346
|
+
}
|
|
347
|
+
flushAssistantBuffer();
|
|
348
|
+
const warnings = [];
|
|
349
|
+
let inputTokens = 0;
|
|
350
|
+
let outputTokens = 0;
|
|
351
|
+
let cacheReadTokens = 0;
|
|
352
|
+
let cacheCreationTokens = 0;
|
|
353
|
+
let costUsd = 0;
|
|
354
|
+
let totalContextTokens = 0;
|
|
355
|
+
let contextBreakdown;
|
|
356
|
+
let nativeCost;
|
|
357
|
+
if (seenShutdown) {
|
|
358
|
+
for (const [model, u] of authUsageByModel) {
|
|
359
|
+
inputTokens += u.input;
|
|
360
|
+
outputTokens += u.output;
|
|
361
|
+
cacheReadTokens += u.cacheRead;
|
|
362
|
+
cacheCreationTokens += u.cacheWrite;
|
|
363
|
+
costUsd += (0, copilot_model_pricing_1.calculateCopilotMessageCost)(model, {
|
|
364
|
+
inputTokens: u.input,
|
|
365
|
+
outputTokens: u.output,
|
|
366
|
+
cacheReadTokens: u.cacheRead,
|
|
367
|
+
cacheCreationTokens: u.cacheWrite,
|
|
368
|
+
}, pricing ?? stubPricing);
|
|
369
|
+
}
|
|
370
|
+
totalContextTokens = lastContextTokens;
|
|
371
|
+
contextBreakdown = lastContextBreakdown;
|
|
372
|
+
nativeCost = nativeCredits;
|
|
373
|
+
}
|
|
374
|
+
else {
|
|
375
|
+
outputTokens = liveOutputTokens;
|
|
376
|
+
costUsd =
|
|
377
|
+
liveOutputTokens > 0 && primaryModel
|
|
378
|
+
? (0, copilot_model_pricing_1.calculateCopilotMessageCost)(primaryModel, {
|
|
379
|
+
inputTokens: 0,
|
|
380
|
+
outputTokens: liveOutputTokens,
|
|
381
|
+
cacheReadTokens: 0,
|
|
382
|
+
cacheCreationTokens: 0,
|
|
383
|
+
}, pricing ?? stubPricing)
|
|
384
|
+
: 0;
|
|
385
|
+
warnings.push('Partial metrics — session.shutdown not yet observed; input/cache/reasoning/cost pending (showing per-turn outputTokens + output-only lower-bound cost).');
|
|
386
|
+
}
|
|
387
|
+
const durationMs = firstTimestamp && lastTimestamp ? lastTimestamp.getTime() - firstTimestamp.getTime() : 0;
|
|
388
|
+
const isOngoing = !seenShutdown;
|
|
389
|
+
const contextWindowTokens = pricing && primaryModel ? pricing.getContextWindowSize(primaryModel) : 200_000;
|
|
390
|
+
const modelsUsed = modelsSet.size > 1 ? Array.from(modelsSet) : undefined;
|
|
391
|
+
const phases = [
|
|
392
|
+
{
|
|
393
|
+
phaseNumber: 1,
|
|
394
|
+
contribution: inputTokens + cacheReadTokens,
|
|
395
|
+
peakTokens: inputTokens + cacheReadTokens,
|
|
396
|
+
},
|
|
397
|
+
];
|
|
398
|
+
const totalContextConsumption = phases.reduce((sum, p) => sum + p.contribution, 0);
|
|
399
|
+
const totalTokens = inputTokens + outputTokens + cacheReadTokens + cacheCreationTokens;
|
|
400
|
+
const metrics = {
|
|
401
|
+
inputTokens,
|
|
402
|
+
outputTokens,
|
|
403
|
+
cacheReadTokens,
|
|
404
|
+
cacheCreationTokens,
|
|
405
|
+
totalTokens,
|
|
406
|
+
totalContextConsumption,
|
|
407
|
+
compactionCount: 0,
|
|
408
|
+
phaseBreakdowns: phases,
|
|
409
|
+
visibleContextTokens,
|
|
410
|
+
totalContextTokens,
|
|
411
|
+
contextWindowTokens,
|
|
412
|
+
contextBreakdown,
|
|
413
|
+
costUsd,
|
|
414
|
+
nativeCost,
|
|
415
|
+
primaryModel,
|
|
416
|
+
modelsUsed,
|
|
417
|
+
durationMs,
|
|
418
|
+
messageCount: messages.length,
|
|
419
|
+
isOngoing,
|
|
420
|
+
};
|
|
421
|
+
if (oversizedLineCount > 0) {
|
|
422
|
+
warnings.push(`Skipped ${oversizedLineCount} oversized line${oversizedLineCount > 1 ? 's' : ''} (>10MB each)`);
|
|
423
|
+
}
|
|
424
|
+
return {
|
|
425
|
+
messages,
|
|
426
|
+
metrics,
|
|
427
|
+
bytesRead,
|
|
428
|
+
sessionId,
|
|
429
|
+
warnings: warnings.length > 0 ? warnings : undefined,
|
|
430
|
+
};
|
|
431
|
+
}
|
|
432
|
+
//# sourceMappingURL=copilot-jsonl.parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"copilot-jsonl.parser.js","sourceRoot":"","sources":["../../../../src/modules/session-reader/parsers/copilot-jsonl.parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface AgyTokenMetrics {
|
|
2
|
+
inputTokens: number;
|
|
3
|
+
outputTokens: number;
|
|
4
|
+
cacheReadTokens: number;
|
|
5
|
+
cacheCreationTokens: number;
|
|
6
|
+
generationCount: number;
|
|
7
|
+
lastContextTokens: number;
|
|
8
|
+
modelId?: string;
|
|
9
|
+
displayName?: string;
|
|
10
|
+
warnings: string[];
|
|
11
|
+
}
|
|
12
|
+
export interface AntigravityMetricsReaderOptions {
|
|
13
|
+
busyTimeoutMs?: number;
|
|
14
|
+
openRetries?: number;
|
|
15
|
+
}
|
|
16
|
+
export declare class AntigravityMetricsReader {
|
|
17
|
+
private readonly busyTimeoutMs;
|
|
18
|
+
private readonly openRetries;
|
|
19
|
+
constructor(options?: AntigravityMetricsReaderOptions);
|
|
20
|
+
decode(dbPath: string, providerSessionId: string): AgyTokenMetrics;
|
|
21
|
+
private decodeRowUsage;
|
|
22
|
+
private withDb;
|
|
23
|
+
private hasTable;
|
|
24
|
+
private sleep;
|
|
25
|
+
}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.AntigravityMetricsReader = void 0;
|
|
7
|
+
const better_sqlite3_1 = __importDefault(require("better-sqlite3"));
|
|
8
|
+
const logger_1 = require("../../../common/logging/logger");
|
|
9
|
+
const protobuf_wire_1 = require("./protobuf-wire");
|
|
10
|
+
const logger = (0, logger_1.createLogger)('AntigravityMetricsReader');
|
|
11
|
+
const DEFAULT_BUSY_TIMEOUT_MS = 5_000;
|
|
12
|
+
const DEFAULT_OPEN_RETRIES = 3;
|
|
13
|
+
const OPEN_RETRY_DELAY_MS = 50;
|
|
14
|
+
const WRAPPER_FIELD = 1;
|
|
15
|
+
const USAGE_FIELD = 4;
|
|
16
|
+
const USAGE_INPUT = 2;
|
|
17
|
+
const USAGE_OUTPUT_TOTAL = 3;
|
|
18
|
+
const MODEL_ID_FIELD = 19;
|
|
19
|
+
const DISPLAY_NAME_FIELD = 21;
|
|
20
|
+
class AntigravityMetricsReader {
|
|
21
|
+
constructor(options) {
|
|
22
|
+
this.busyTimeoutMs = options?.busyTimeoutMs ?? DEFAULT_BUSY_TIMEOUT_MS;
|
|
23
|
+
this.openRetries = options?.openRetries ?? DEFAULT_OPEN_RETRIES;
|
|
24
|
+
}
|
|
25
|
+
decode(dbPath, providerSessionId) {
|
|
26
|
+
const result = emptyMetrics();
|
|
27
|
+
try {
|
|
28
|
+
this.withDb(dbPath, (db) => {
|
|
29
|
+
if (!this.hasTable(db, 'gen_metadata') || !this.hasTable(db, 'trajectory_meta')) {
|
|
30
|
+
result.warnings.push('agy metrics: DB schema drift — gen_metadata/trajectory_meta missing (token usage unavailable)');
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const cascade = db.prepare('SELECT cascade_id FROM trajectory_meta LIMIT 1').get();
|
|
34
|
+
if (cascade?.cascade_id && cascade.cascade_id !== providerSessionId) {
|
|
35
|
+
result.warnings.push(`agy metrics: .db conversation id mismatch (cascade_id=${cascade.cascade_id} ≠ providerSessionId=${providerSessionId}) — token usage NOT trusted`);
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const rows = db
|
|
39
|
+
.prepare('SELECT idx, data FROM gen_metadata ORDER BY idx')
|
|
40
|
+
.all();
|
|
41
|
+
if (rows.length === 0) {
|
|
42
|
+
result.warnings.push('agy metrics: no generation metadata rows — token usage unavailable');
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
let decodedRows = 0;
|
|
46
|
+
for (const row of rows) {
|
|
47
|
+
try {
|
|
48
|
+
const usage = this.decodeRowUsage(row.data, result);
|
|
49
|
+
if (!usage)
|
|
50
|
+
continue;
|
|
51
|
+
result.inputTokens += usage.input;
|
|
52
|
+
result.outputTokens += usage.output;
|
|
53
|
+
result.lastContextTokens = usage.input + usage.output;
|
|
54
|
+
if (usage.modelId)
|
|
55
|
+
result.modelId = usage.modelId;
|
|
56
|
+
if (usage.displayName)
|
|
57
|
+
result.displayName = usage.displayName;
|
|
58
|
+
decodedRows++;
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
if (error instanceof protobuf_wire_1.ProtobufDecodeError) {
|
|
62
|
+
result.warnings.push(`agy metrics: undecodable protobuf at gen_metadata[${row.idx}] (possible version drift): ${error.message}`);
|
|
63
|
+
continue;
|
|
64
|
+
}
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
result.generationCount = decodedRows;
|
|
69
|
+
if (decodedRows === 0 && result.warnings.length === 0) {
|
|
70
|
+
result.warnings.push('agy metrics: no Usage submessage found in any generation — token usage unavailable');
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
catch (error) {
|
|
75
|
+
result.warnings.push(`agy metrics: cannot read .db (${String(error?.message ?? error)})`);
|
|
76
|
+
logger.debug({ dbPath, error }, 'agy metrics decode failed');
|
|
77
|
+
}
|
|
78
|
+
return result;
|
|
79
|
+
}
|
|
80
|
+
decodeRowUsage(data, _result) {
|
|
81
|
+
const top = (0, protobuf_wire_1.decodeMessage)(data);
|
|
82
|
+
const wrapper = (0, protobuf_wire_1.getMessage)(top, WRAPPER_FIELD);
|
|
83
|
+
if (!wrapper)
|
|
84
|
+
return null;
|
|
85
|
+
const usage = (0, protobuf_wire_1.getMessage)(wrapper, USAGE_FIELD);
|
|
86
|
+
if (!usage)
|
|
87
|
+
return null;
|
|
88
|
+
return {
|
|
89
|
+
input: (0, protobuf_wire_1.getVarint)(usage, USAGE_INPUT) ?? 0,
|
|
90
|
+
output: (0, protobuf_wire_1.getVarint)(usage, USAGE_OUTPUT_TOTAL) ?? 0,
|
|
91
|
+
modelId: (0, protobuf_wire_1.getString)(wrapper, MODEL_ID_FIELD),
|
|
92
|
+
displayName: (0, protobuf_wire_1.getString)(wrapper, DISPLAY_NAME_FIELD),
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
withDb(dbPath, fn) {
|
|
96
|
+
let lastError;
|
|
97
|
+
for (let attempt = 0; attempt <= this.openRetries; attempt++) {
|
|
98
|
+
let db;
|
|
99
|
+
try {
|
|
100
|
+
db = new better_sqlite3_1.default(dbPath, { readonly: true, fileMustExist: true });
|
|
101
|
+
db.pragma(`busy_timeout = ${this.busyTimeoutMs}`);
|
|
102
|
+
return fn(db);
|
|
103
|
+
}
|
|
104
|
+
catch (error) {
|
|
105
|
+
lastError = error;
|
|
106
|
+
const code = error?.code;
|
|
107
|
+
const transient = code === 'SQLITE_BUSY' || code === 'SQLITE_LOCKED';
|
|
108
|
+
if (!transient || attempt === this.openRetries)
|
|
109
|
+
throw error;
|
|
110
|
+
this.sleep(OPEN_RETRY_DELAY_MS * (attempt + 1));
|
|
111
|
+
}
|
|
112
|
+
finally {
|
|
113
|
+
db?.close();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
throw lastError;
|
|
117
|
+
}
|
|
118
|
+
hasTable(db, name) {
|
|
119
|
+
const row = db
|
|
120
|
+
.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name = ?")
|
|
121
|
+
.get(name);
|
|
122
|
+
return row !== undefined;
|
|
123
|
+
}
|
|
124
|
+
sleep(ms) {
|
|
125
|
+
const end = Date.now() + ms;
|
|
126
|
+
while (Date.now() < end) {
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
exports.AntigravityMetricsReader = AntigravityMetricsReader;
|
|
131
|
+
function emptyMetrics() {
|
|
132
|
+
return {
|
|
133
|
+
inputTokens: 0,
|
|
134
|
+
outputTokens: 0,
|
|
135
|
+
cacheReadTokens: 0,
|
|
136
|
+
cacheCreationTokens: 0,
|
|
137
|
+
generationCount: 0,
|
|
138
|
+
lastContextTokens: 0,
|
|
139
|
+
warnings: [],
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
//# sourceMappingURL=antigravity-metrics.reader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"antigravity-metrics.reader.js","sourceRoot":"","sources":["../../../../src/modules/session-reader/readers/antigravity-metrics.reader.ts"],"names":[],"mappings":"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"}
|