@grislabs/agentmeter 0.1.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.
@@ -0,0 +1,86 @@
1
+ import type { TraceTags, LLMCallEvent, ToolCallEvent, PaymentEvent, BudgetRule, CostType } from "./types.js";
2
+ type EmittableEvent = LLMCallEvent | ToolCallEvent | PaymentEvent;
3
+ export declare class TraceContext {
4
+ readonly traceId: string;
5
+ readonly workflow: string;
6
+ readonly tags: TraceTags;
7
+ readonly startTime: number;
8
+ private _llmCost;
9
+ private _toolCost;
10
+ private _paymentCost;
11
+ private _totalInputTokens;
12
+ private _totalOutputTokens;
13
+ private _llmCalls;
14
+ private _toolCalls;
15
+ private _payments;
16
+ private _budgetRule;
17
+ private _emitEvent;
18
+ constructor(workflow: string, tags: TraceTags, budgetRule: BudgetRule | undefined, emitEvent: (event: EmittableEvent) => void);
19
+ get totalCost(): number;
20
+ get llmCost(): number;
21
+ get toolCost(): number;
22
+ get paymentCost(): number;
23
+ get totalInputTokens(): number;
24
+ get totalOutputTokens(): number;
25
+ get llmCallCount(): number;
26
+ get toolCallCount(): number;
27
+ get paymentCount(): number;
28
+ get durationMs(): number;
29
+ trackLLM(params: {
30
+ model: string;
31
+ inputTokens: number;
32
+ outputTokens: number;
33
+ cachedInputTokens?: number;
34
+ durationMs: number;
35
+ success?: boolean;
36
+ error?: string;
37
+ }): void;
38
+ trackTool(params: {
39
+ toolName: string;
40
+ durationMs: number;
41
+ cost?: number;
42
+ costType?: CostType;
43
+ success?: boolean;
44
+ error?: string;
45
+ }): void;
46
+ trackPayment(params: {
47
+ provider: PaymentEvent["provider"];
48
+ amount: number;
49
+ currency?: string;
50
+ description: string;
51
+ recipient?: string;
52
+ transactionId?: string;
53
+ durationMs: number;
54
+ success?: boolean;
55
+ error?: string;
56
+ }): void;
57
+ /**
58
+ * Convenience: wrap an async LLM call, auto-tracking duration and extracting usage.
59
+ */
60
+ llm<T>(call: Promise<T>, extract: (response: T) => {
61
+ model: string;
62
+ inputTokens: number;
63
+ outputTokens: number;
64
+ cachedInputTokens?: number;
65
+ }): Promise<T>;
66
+ /**
67
+ * Convenience: wrap an async tool call with optional cost.
68
+ */
69
+ tool<T>(toolName: string, call: Promise<T>, opts?: {
70
+ cost?: number;
71
+ costType?: CostType;
72
+ }): Promise<T>;
73
+ /**
74
+ * Convenience: wrap an async payment call.
75
+ */
76
+ payment<T>(params: {
77
+ provider: PaymentEvent["provider"];
78
+ amount: number;
79
+ currency?: string;
80
+ description: string;
81
+ recipient?: string;
82
+ }, call: Promise<T>): Promise<T>;
83
+ private _checkBudget;
84
+ }
85
+ export {};
86
+ //# sourceMappingURL=trace-context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trace-context.d.ts","sourceRoot":"","sources":["../src/trace-context.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,216 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TraceContext = void 0;
4
+ const node_crypto_1 = require("node:crypto");
5
+ const pricing_js_1 = require("./pricing.js");
6
+ class TraceContext {
7
+ traceId;
8
+ workflow;
9
+ tags;
10
+ startTime;
11
+ _llmCost = 0;
12
+ _toolCost = 0;
13
+ _paymentCost = 0;
14
+ _totalInputTokens = 0;
15
+ _totalOutputTokens = 0;
16
+ _llmCalls = 0;
17
+ _toolCalls = 0;
18
+ _payments = 0;
19
+ _budgetRule;
20
+ _emitEvent;
21
+ constructor(workflow, tags, budgetRule, emitEvent) {
22
+ this.traceId = (0, node_crypto_1.randomUUID)();
23
+ this.workflow = workflow;
24
+ this.tags = tags;
25
+ this.startTime = Date.now();
26
+ this._budgetRule = budgetRule;
27
+ this._emitEvent = emitEvent;
28
+ }
29
+ get totalCost() {
30
+ return this._llmCost + this._toolCost + this._paymentCost;
31
+ }
32
+ get llmCost() {
33
+ return this._llmCost;
34
+ }
35
+ get toolCost() {
36
+ return this._toolCost;
37
+ }
38
+ get paymentCost() {
39
+ return this._paymentCost;
40
+ }
41
+ get totalInputTokens() {
42
+ return this._totalInputTokens;
43
+ }
44
+ get totalOutputTokens() {
45
+ return this._totalOutputTokens;
46
+ }
47
+ get llmCallCount() {
48
+ return this._llmCalls;
49
+ }
50
+ get toolCallCount() {
51
+ return this._toolCalls;
52
+ }
53
+ get paymentCount() {
54
+ return this._payments;
55
+ }
56
+ get durationMs() {
57
+ return Date.now() - this.startTime;
58
+ }
59
+ trackLLM(params) {
60
+ const cost = (0, pricing_js_1.calculateCost)(params.model, params.inputTokens, params.outputTokens, params.cachedInputTokens ?? 0);
61
+ this._llmCost += cost;
62
+ this._totalInputTokens += params.inputTokens;
63
+ this._totalOutputTokens += params.outputTokens;
64
+ this._llmCalls++;
65
+ this._emitEvent({
66
+ type: "llm",
67
+ traceId: this.traceId,
68
+ workflow: this.workflow,
69
+ tags: this.tags,
70
+ model: params.model,
71
+ inputTokens: params.inputTokens,
72
+ outputTokens: params.outputTokens,
73
+ cachedInputTokens: params.cachedInputTokens ?? 0,
74
+ cost,
75
+ durationMs: params.durationMs,
76
+ success: params.success ?? true,
77
+ error: params.error,
78
+ timestamp: Date.now(),
79
+ });
80
+ this._checkBudget();
81
+ }
82
+ trackTool(params) {
83
+ const cost = params.cost ?? 0;
84
+ this._toolCost += cost;
85
+ this._toolCalls++;
86
+ this._emitEvent({
87
+ type: "tool",
88
+ traceId: this.traceId,
89
+ workflow: this.workflow,
90
+ tags: this.tags,
91
+ toolName: params.toolName,
92
+ cost,
93
+ costType: params.costType,
94
+ durationMs: params.durationMs,
95
+ success: params.success ?? true,
96
+ error: params.error,
97
+ timestamp: Date.now(),
98
+ });
99
+ if (cost > 0)
100
+ this._checkBudget();
101
+ }
102
+ trackPayment(params) {
103
+ const amount = params.success !== false ? params.amount : 0;
104
+ this._paymentCost += amount;
105
+ this._payments++;
106
+ this._emitEvent({
107
+ type: "payment",
108
+ traceId: this.traceId,
109
+ workflow: this.workflow,
110
+ tags: this.tags,
111
+ provider: params.provider,
112
+ amount: params.amount,
113
+ currency: params.currency ?? "usd",
114
+ description: params.description,
115
+ recipient: params.recipient,
116
+ transactionId: params.transactionId,
117
+ durationMs: params.durationMs,
118
+ success: params.success ?? true,
119
+ error: params.error,
120
+ timestamp: Date.now(),
121
+ });
122
+ if (amount > 0)
123
+ this._checkBudget();
124
+ }
125
+ /**
126
+ * Convenience: wrap an async LLM call, auto-tracking duration and extracting usage.
127
+ */
128
+ async llm(call, extract) {
129
+ const start = Date.now();
130
+ try {
131
+ const response = await call;
132
+ const usage = extract(response);
133
+ this.trackLLM({ ...usage, durationMs: Date.now() - start });
134
+ return response;
135
+ }
136
+ catch (err) {
137
+ this.trackLLM({
138
+ model: "unknown",
139
+ inputTokens: 0,
140
+ outputTokens: 0,
141
+ durationMs: Date.now() - start,
142
+ success: false,
143
+ error: err instanceof Error ? err.message : String(err),
144
+ });
145
+ throw err;
146
+ }
147
+ }
148
+ /**
149
+ * Convenience: wrap an async tool call with optional cost.
150
+ */
151
+ async tool(toolName, call, opts) {
152
+ const start = Date.now();
153
+ try {
154
+ const result = await call;
155
+ this.trackTool({
156
+ toolName,
157
+ durationMs: Date.now() - start,
158
+ cost: opts?.cost,
159
+ costType: opts?.costType,
160
+ });
161
+ return result;
162
+ }
163
+ catch (err) {
164
+ this.trackTool({
165
+ toolName,
166
+ durationMs: Date.now() - start,
167
+ cost: opts?.cost,
168
+ costType: opts?.costType,
169
+ success: false,
170
+ error: err instanceof Error ? err.message : String(err),
171
+ });
172
+ throw err;
173
+ }
174
+ }
175
+ /**
176
+ * Convenience: wrap an async payment call.
177
+ */
178
+ async payment(params, call) {
179
+ const start = Date.now();
180
+ try {
181
+ const result = await call;
182
+ this.trackPayment({ ...params, durationMs: Date.now() - start });
183
+ return result;
184
+ }
185
+ catch (err) {
186
+ this.trackPayment({
187
+ ...params,
188
+ durationMs: Date.now() - start,
189
+ success: false,
190
+ error: err instanceof Error ? err.message : String(err),
191
+ });
192
+ throw err;
193
+ }
194
+ }
195
+ _checkBudget() {
196
+ if (!this._budgetRule)
197
+ return;
198
+ const { perRun, onExceeded } = this._budgetRule;
199
+ if (perRun && this.totalCost > perRun) {
200
+ const err = new Error(`AgentMeter: budget exceeded for workflow "${this.workflow}". ` +
201
+ `Cost $${this.totalCost.toFixed(4)} (LLM: $${this._llmCost.toFixed(4)}, ` +
202
+ `Tools: $${this._toolCost.toFixed(4)}, Payments: $${this._paymentCost.toFixed(4)}) ` +
203
+ `exceeds per-run limit $${perRun}. Action: ${onExceeded}`);
204
+ err.code = "BUDGET_EXCEEDED";
205
+ err.workflow = this.workflow;
206
+ err.traceId = this.traceId;
207
+ err.currentCost = this.totalCost;
208
+ err.limit = perRun;
209
+ err.limitType = "perRun";
210
+ if (onExceeded === "kill")
211
+ throw err;
212
+ }
213
+ }
214
+ }
215
+ exports.TraceContext = TraceContext;
216
+ //# sourceMappingURL=trace-context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trace-context.js","sourceRoot":"","sources":["../src/trace-context.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,102 @@
1
+ export interface AgentMeterConfig {
2
+ apiKey?: string;
3
+ endpoint?: string;
4
+ /** Flush events every N ms (default: 10000) */
5
+ flushIntervalMs?: number;
6
+ /** Flush when buffer reaches N events (default: 100) */
7
+ flushSize?: number;
8
+ /** Enable local-only mode (no API calls, just console output) */
9
+ local?: boolean;
10
+ /** Custom model pricing overrides */
11
+ pricing?: Record<string, {
12
+ input: number;
13
+ output: number;
14
+ cachedInput?: number;
15
+ }>;
16
+ }
17
+ export interface TraceTags {
18
+ customerId?: string;
19
+ feature?: string;
20
+ userId?: string;
21
+ environment?: string;
22
+ [key: string]: string | undefined;
23
+ }
24
+ export type CostType = "mcp" | "api" | "compute" | "other";
25
+ export interface LLMCallEvent {
26
+ type: "llm";
27
+ traceId: string;
28
+ workflow: string;
29
+ tags: TraceTags;
30
+ model: string;
31
+ inputTokens: number;
32
+ outputTokens: number;
33
+ cachedInputTokens: number;
34
+ cost: number;
35
+ durationMs: number;
36
+ success: boolean;
37
+ error?: string;
38
+ timestamp: number;
39
+ }
40
+ export interface ToolCallEvent {
41
+ type: "tool";
42
+ traceId: string;
43
+ workflow: string;
44
+ tags: TraceTags;
45
+ toolName: string;
46
+ cost: number;
47
+ costType?: CostType;
48
+ durationMs: number;
49
+ success: boolean;
50
+ error?: string;
51
+ timestamp: number;
52
+ }
53
+ export interface PaymentEvent {
54
+ type: "payment";
55
+ traceId: string;
56
+ workflow: string;
57
+ tags: TraceTags;
58
+ provider: "stripe_mpp" | "x402" | "ap2" | "custom";
59
+ amount: number;
60
+ currency: string;
61
+ description: string;
62
+ recipient?: string;
63
+ transactionId?: string;
64
+ durationMs: number;
65
+ success: boolean;
66
+ error?: string;
67
+ timestamp: number;
68
+ }
69
+ export interface TraceCompleteEvent {
70
+ type: "trace_complete";
71
+ traceId: string;
72
+ workflow: string;
73
+ tags: TraceTags;
74
+ totalCost: number;
75
+ llmCost: number;
76
+ toolCost: number;
77
+ paymentCost: number;
78
+ totalInputTokens: number;
79
+ totalOutputTokens: number;
80
+ llmCalls: number;
81
+ toolCalls: number;
82
+ payments: number;
83
+ durationMs: number;
84
+ success: boolean;
85
+ error?: string;
86
+ timestamp: number;
87
+ }
88
+ export type AgentMeterEvent = LLMCallEvent | ToolCallEvent | PaymentEvent | TraceCompleteEvent;
89
+ export interface BudgetRule {
90
+ perRun?: number;
91
+ daily?: number;
92
+ monthly?: number;
93
+ onExceeded: "alert" | "kill" | "downgrade-model";
94
+ }
95
+ export interface BudgetExceededError extends Error {
96
+ workflow: string;
97
+ traceId: string;
98
+ currentCost: number;
99
+ limit: number;
100
+ limitType: "perRun" | "daily" | "monthly";
101
+ }
102
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
package/package.json ADDED
@@ -0,0 +1,50 @@
1
+ {
2
+ "name": "@grislabs/agentmeter",
3
+ "publishConfig": {
4
+ "access": "public"
5
+ },
6
+ "version": "0.1.0",
7
+ "description": "Cost intelligence for AI agents. Track per-task, per-workflow, per-customer costs.",
8
+ "main": "dist/index.js",
9
+ "types": "dist/index.d.ts",
10
+ "exports": {
11
+ ".": {
12
+ "types": "./dist/index.d.ts",
13
+ "default": "./dist/index.js"
14
+ },
15
+ "./mcp": {
16
+ "types": "./dist/mcp.d.ts",
17
+ "default": "./dist/mcp.js"
18
+ }
19
+ },
20
+ "bin": {
21
+ "agentmeter": "dist/cli.js"
22
+ },
23
+ "files": [
24
+ "dist",
25
+ "!dist/__tests__"
26
+ ],
27
+ "scripts": {
28
+ "build": "tsc",
29
+ "dev": "tsc --watch",
30
+ "test": "vitest"
31
+ },
32
+ "keywords": [
33
+ "ai",
34
+ "agent",
35
+ "cost",
36
+ "finops",
37
+ "llm",
38
+ "observability",
39
+ "anthropic",
40
+ "openai",
41
+ "langchain",
42
+ "mcp"
43
+ ],
44
+ "license": "MIT",
45
+ "devDependencies": {
46
+ "@types/node": "^25.5.0",
47
+ "typescript": "^5.7.0",
48
+ "vitest": "^3.0.0"
49
+ }
50
+ }