clawck 0.4.2 → 0.5.2
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 +81 -9
- package/dist/cli/index.js +30 -45
- package/dist/cli/index.js.map +1 -1
- package/dist/core/atp.d.ts +1 -1
- package/dist/core/atp.d.ts.map +1 -1
- package/dist/core/atp.js +1 -1
- package/dist/core/atp.js.map +1 -1
- package/dist/core/clawck.d.ts.map +1 -1
- package/dist/core/clawck.js +14 -0
- package/dist/core/clawck.js.map +1 -1
- package/dist/core/config.d.ts +10 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +58 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/database.d.ts +13 -0
- package/dist/core/database.d.ts.map +1 -1
- package/dist/core/database.js +151 -65
- package/dist/core/database.js.map +1 -1
- package/dist/core/errors.d.ts +19 -0
- package/dist/core/errors.d.ts.map +1 -0
- package/dist/core/errors.js +40 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/logger.d.ts +14 -0
- package/dist/core/logger.d.ts.map +1 -0
- package/dist/core/logger.js +39 -0
- package/dist/core/logger.js.map +1 -0
- package/dist/core/pricing.d.ts +28 -0
- package/dist/core/pricing.d.ts.map +1 -0
- package/dist/core/pricing.js +48 -0
- package/dist/core/pricing.js.map +1 -0
- package/dist/core/runtime.d.ts +9 -0
- package/dist/core/runtime.d.ts.map +1 -1
- package/dist/core/runtime.js +33 -0
- package/dist/core/runtime.js.map +1 -1
- package/dist/core/sync.d.ts.map +1 -1
- package/dist/core/sync.js +3 -0
- package/dist/core/sync.js.map +1 -1
- package/dist/core/types.d.ts +14 -3
- package/dist/core/types.d.ts.map +1 -1
- package/dist/core/types.js +1 -1
- package/dist/core/types.js.map +1 -1
- package/dist/core/webhooks.d.ts.map +1 -1
- package/dist/core/webhooks.js +5 -2
- package/dist/core/webhooks.js.map +1 -1
- package/dist/dashboard/index.js +3 -3
- package/dist/hooks/adapters.d.ts.map +1 -1
- package/dist/hooks/adapters.js +3 -2
- package/dist/hooks/adapters.js.map +1 -1
- package/dist/hooks/handler.d.ts.map +1 -1
- package/dist/hooks/handler.js +7 -5
- package/dist/hooks/handler.js.map +1 -1
- package/dist/hooks/types.d.ts +1 -0
- package/dist/hooks/types.d.ts.map +1 -1
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +12 -1
- package/dist/index.js.map +1 -1
- package/dist/reports/html.d.ts +2 -2
- package/dist/reports/html.d.ts.map +1 -1
- package/dist/reports/html.js +238 -84
- package/dist/reports/html.js.map +1 -1
- package/dist/reports/pdf.d.ts.map +1 -1
- package/dist/reports/pdf.js +5 -4
- package/dist/reports/pdf.js.map +1 -1
- package/dist/server/api.d.ts.map +1 -1
- package/dist/server/api.js +57 -18
- package/dist/server/api.js.map +1 -1
- package/dist/server/mcp.d.ts.map +1 -1
- package/dist/server/mcp.js +3 -3
- package/dist/server/mcp.js.map +1 -1
- package/docs/api-reference.md +380 -0
- package/docs/deployment.md +140 -0
- package/docs/deprecation-policy.md +32 -0
- package/docs/migration-guide.md +78 -0
- package/docs/security.md +70 -0
- package/docs/versioning.md +49 -0
- package/package.json +6 -3
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ⏱️🦀 Clawck — Error Types
|
|
4
|
+
* Typed errors for consistent API error responses.
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.ConfigError = exports.NotFoundError = exports.ValidationError = exports.ClawckError = void 0;
|
|
8
|
+
class ClawckError extends Error {
|
|
9
|
+
code;
|
|
10
|
+
status;
|
|
11
|
+
constructor(message, code, status) {
|
|
12
|
+
super(message);
|
|
13
|
+
this.name = 'ClawckError';
|
|
14
|
+
this.code = code;
|
|
15
|
+
this.status = status;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.ClawckError = ClawckError;
|
|
19
|
+
class ValidationError extends ClawckError {
|
|
20
|
+
constructor(message) {
|
|
21
|
+
super(message, 'VALIDATION_ERROR', 400);
|
|
22
|
+
this.name = 'ValidationError';
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
exports.ValidationError = ValidationError;
|
|
26
|
+
class NotFoundError extends ClawckError {
|
|
27
|
+
constructor(message) {
|
|
28
|
+
super(message, 'NOT_FOUND', 404);
|
|
29
|
+
this.name = 'NotFoundError';
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
exports.NotFoundError = NotFoundError;
|
|
33
|
+
class ConfigError extends ClawckError {
|
|
34
|
+
constructor(message) {
|
|
35
|
+
super(message, 'CONFIG_ERROR', 500);
|
|
36
|
+
this.name = 'ConfigError';
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
exports.ConfigError = ConfigError;
|
|
40
|
+
//# sourceMappingURL=errors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"errors.js","sourceRoot":"","sources":["../../src/core/errors.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,MAAa,WAAY,SAAQ,KAAK;IACpC,IAAI,CAAS;IACb,MAAM,CAAS;IAEf,YAAY,OAAe,EAAE,IAAY,EAAE,MAAc;QACvD,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;CACF;AAVD,kCAUC;AAED,MAAa,eAAgB,SAAQ,WAAW;IAC9C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,kBAAkB,EAAE,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC;IAChC,CAAC;CACF;AALD,0CAKC;AAED,MAAa,aAAc,SAAQ,WAAW;IAC5C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,WAAW,EAAE,GAAG,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;IAC9B,CAAC;CACF;AALD,sCAKC;AAED,MAAa,WAAY,SAAQ,WAAW;IAC1C,YAAY,OAAe;QACzB,KAAK,CAAC,OAAO,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC;IAC5B,CAAC;CACF;AALD,kCAKC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ⏱️🦀 Clawck — Structured Logger
|
|
3
|
+
* Thin wrapper for consistent log output across subsystems.
|
|
4
|
+
*/
|
|
5
|
+
export type LogLevel = 'debug' | 'info' | 'warn' | 'error';
|
|
6
|
+
export type Subsystem = 'api' | 'db' | 'sync' | 'hooks' | 'webhooks' | 'cli' | 'mcp';
|
|
7
|
+
export declare function log(level: LogLevel, subsystem: Subsystem, message: string, data?: Record<string, unknown>): void;
|
|
8
|
+
export declare const logger: {
|
|
9
|
+
debug: (subsystem: Subsystem, message: string, data?: Record<string, unknown>) => void;
|
|
10
|
+
info: (subsystem: Subsystem, message: string, data?: Record<string, unknown>) => void;
|
|
11
|
+
warn: (subsystem: Subsystem, message: string, data?: Record<string, unknown>) => void;
|
|
12
|
+
error: (subsystem: Subsystem, message: string, data?: Record<string, unknown>) => void;
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,MAAM,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;AAC3D,MAAM,MAAM,SAAS,GAAG,KAAK,GAAG,IAAI,GAAG,MAAM,GAAG,OAAO,GAAG,UAAU,GAAG,KAAK,GAAG,KAAK,CAAC;AAUrF,wBAAgB,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAehH;AAED,eAAO,MAAM,MAAM;uBACE,SAAS,WAAW,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;sBAC3D,SAAS,WAAW,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;sBAC1D,SAAS,WAAW,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;uBACzD,SAAS,WAAW,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;CAC9E,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ⏱️🦀 Clawck — Structured Logger
|
|
4
|
+
* Thin wrapper for consistent log output across subsystems.
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.logger = void 0;
|
|
8
|
+
exports.log = log;
|
|
9
|
+
const LEVEL_ORDER = { debug: 0, info: 1, warn: 2, error: 3 };
|
|
10
|
+
function getMinLevel() {
|
|
11
|
+
const env = process.env.LOG_LEVEL?.toLowerCase();
|
|
12
|
+
if (env && env in LEVEL_ORDER)
|
|
13
|
+
return env;
|
|
14
|
+
return 'info';
|
|
15
|
+
}
|
|
16
|
+
function log(level, subsystem, message, data) {
|
|
17
|
+
if (LEVEL_ORDER[level] < LEVEL_ORDER[getMinLevel()])
|
|
18
|
+
return;
|
|
19
|
+
const timestamp = new Date().toISOString();
|
|
20
|
+
const prefix = `[${timestamp}] [${level.toUpperCase()}] [${subsystem}]`;
|
|
21
|
+
const suffix = data ? ' ' + JSON.stringify(data) : '';
|
|
22
|
+
const line = `${prefix} ${message}${suffix}`;
|
|
23
|
+
if (level === 'error') {
|
|
24
|
+
console.error(line);
|
|
25
|
+
}
|
|
26
|
+
else if (level === 'warn') {
|
|
27
|
+
console.warn(line);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
console.log(line);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
exports.logger = {
|
|
34
|
+
debug: (subsystem, message, data) => log('debug', subsystem, message, data),
|
|
35
|
+
info: (subsystem, message, data) => log('info', subsystem, message, data),
|
|
36
|
+
warn: (subsystem, message, data) => log('warn', subsystem, message, data),
|
|
37
|
+
error: (subsystem, message, data) => log('error', subsystem, message, data),
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAaH,kBAeC;AAvBD,MAAM,WAAW,GAA6B,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;AAEvF,SAAS,WAAW;IAClB,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,WAAW,EAAE,CAAC;IACjD,IAAI,GAAG,IAAI,GAAG,IAAI,WAAW;QAAE,OAAO,GAAe,CAAC;IACtD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,SAAgB,GAAG,CAAC,KAAe,EAAE,SAAoB,EAAE,OAAe,EAAE,IAA8B;IACxG,IAAI,WAAW,CAAC,KAAK,CAAC,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC;QAAE,OAAO;IAE5D,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC3C,MAAM,MAAM,GAAG,IAAI,SAAS,MAAM,KAAK,CAAC,WAAW,EAAE,MAAM,SAAS,GAAG,CAAC;IACxE,MAAM,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACtD,MAAM,IAAI,GAAG,GAAG,MAAM,IAAI,OAAO,GAAG,MAAM,EAAE,CAAC;IAE7C,IAAI,KAAK,KAAK,OAAO,EAAE,CAAC;QACtB,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;SAAM,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;QAC5B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC;AACH,CAAC;AAEY,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE,CAAC,SAAoB,EAAE,OAAe,EAAE,IAA8B,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC;IACxH,IAAI,EAAE,CAAC,SAAoB,EAAE,OAAe,EAAE,IAA8B,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC;IACtH,IAAI,EAAE,CAAC,SAAoB,EAAE,OAAe,EAAE,IAA8B,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC;IACtH,KAAK,EAAE,CAAC,SAAoB,EAAE,OAAe,EAAE,IAA8B,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,CAAC;CACzH,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ⏱️🦀 Clawck — Model Pricing
|
|
3
|
+
* Token-based cost estimation when cost_usd is not provided directly.
|
|
4
|
+
*/
|
|
5
|
+
export interface ModelPricing {
|
|
6
|
+
/** Cost per 1M input tokens in USD */
|
|
7
|
+
input_per_1m: number;
|
|
8
|
+
/** Cost per 1M output tokens in USD */
|
|
9
|
+
output_per_1m: number;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Pricing table for known models.
|
|
13
|
+
* Keys are matched as prefixes against the model string.
|
|
14
|
+
*/
|
|
15
|
+
export declare const MODEL_PRICING: Record<string, ModelPricing>;
|
|
16
|
+
/**
|
|
17
|
+
* Look up pricing for a model string. Matches by prefix.
|
|
18
|
+
*/
|
|
19
|
+
export declare function getModelPricing(model: string): ModelPricing | null;
|
|
20
|
+
/** Sensible default pricing (Sonnet-class) for unknown models */
|
|
21
|
+
export declare const DEFAULT_PRICING: ModelPricing;
|
|
22
|
+
/**
|
|
23
|
+
* Estimate cost from token counts and model name.
|
|
24
|
+
* Returns null if model is unknown and useFallback is false.
|
|
25
|
+
* When useFallback is true, uses Sonnet-class default pricing for unknown models.
|
|
26
|
+
*/
|
|
27
|
+
export declare function estimateCost(model: string, tokens_in: number, tokens_out: number, useFallback?: boolean): number | null;
|
|
28
|
+
//# sourceMappingURL=pricing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pricing.d.ts","sourceRoot":"","sources":["../../src/core/pricing.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,YAAY;IAC3B,sCAAsC;IACtC,YAAY,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,aAAa,EAAE,MAAM,CAAC;CACvB;AAED;;;GAGG;AACH,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,YAAY,CAStD,CAAC;AAEF;;GAEG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI,CAKlE;AAED,iEAAiE;AACjE,eAAO,MAAM,eAAe,EAAE,YAAqD,CAAC;AAEpF;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,UAAQ,GAAG,MAAM,GAAG,IAAI,CAKrH"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ⏱️🦀 Clawck — Model Pricing
|
|
4
|
+
* Token-based cost estimation when cost_usd is not provided directly.
|
|
5
|
+
*/
|
|
6
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
+
exports.DEFAULT_PRICING = exports.MODEL_PRICING = void 0;
|
|
8
|
+
exports.getModelPricing = getModelPricing;
|
|
9
|
+
exports.estimateCost = estimateCost;
|
|
10
|
+
/**
|
|
11
|
+
* Pricing table for known models.
|
|
12
|
+
* Keys are matched as prefixes against the model string.
|
|
13
|
+
*/
|
|
14
|
+
exports.MODEL_PRICING = {
|
|
15
|
+
'claude-opus-4': { input_per_1m: 15, output_per_1m: 75 },
|
|
16
|
+
'claude-sonnet-4': { input_per_1m: 3, output_per_1m: 15 },
|
|
17
|
+
'claude-haiku-4': { input_per_1m: 0.80, output_per_1m: 4 },
|
|
18
|
+
'claude-3-5-sonnet': { input_per_1m: 3, output_per_1m: 15 },
|
|
19
|
+
'claude-3-5-haiku': { input_per_1m: 0.80, output_per_1m: 4 },
|
|
20
|
+
'claude-3-opus': { input_per_1m: 15, output_per_1m: 75 },
|
|
21
|
+
'claude-3-sonnet': { input_per_1m: 3, output_per_1m: 15 },
|
|
22
|
+
'claude-3-haiku': { input_per_1m: 0.25, output_per_1m: 1.25 },
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Look up pricing for a model string. Matches by prefix.
|
|
26
|
+
*/
|
|
27
|
+
function getModelPricing(model) {
|
|
28
|
+
for (const [prefix, pricing] of Object.entries(exports.MODEL_PRICING)) {
|
|
29
|
+
if (model.startsWith(prefix))
|
|
30
|
+
return pricing;
|
|
31
|
+
}
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
/** Sensible default pricing (Sonnet-class) for unknown models */
|
|
35
|
+
exports.DEFAULT_PRICING = { input_per_1m: 3, output_per_1m: 15 };
|
|
36
|
+
/**
|
|
37
|
+
* Estimate cost from token counts and model name.
|
|
38
|
+
* Returns null if model is unknown and useFallback is false.
|
|
39
|
+
* When useFallback is true, uses Sonnet-class default pricing for unknown models.
|
|
40
|
+
*/
|
|
41
|
+
function estimateCost(model, tokens_in, tokens_out, useFallback = false) {
|
|
42
|
+
const pricing = getModelPricing(model) || (useFallback ? exports.DEFAULT_PRICING : null);
|
|
43
|
+
if (!pricing)
|
|
44
|
+
return null;
|
|
45
|
+
return (tokens_in / 1_000_000) * pricing.input_per_1m +
|
|
46
|
+
(tokens_out / 1_000_000) * pricing.output_per_1m;
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=pricing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pricing.js","sourceRoot":"","sources":["../../src/core/pricing.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AA2BH,0CAKC;AAUD,oCAKC;AAtCD;;;GAGG;AACU,QAAA,aAAa,GAAiC;IACzD,eAAe,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE;IACxD,iBAAiB,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;IACzD,gBAAgB,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,EAAE;IAC1D,mBAAmB,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;IAC3D,kBAAkB,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,EAAE;IAC5D,eAAe,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,aAAa,EAAE,EAAE,EAAE;IACxD,iBAAiB,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;IACzD,gBAAgB,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE;CAC9D,CAAC;AAEF;;GAEG;AACH,SAAgB,eAAe,CAAC,KAAa;IAC3C,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,qBAAa,CAAC,EAAE,CAAC;QAC9D,IAAI,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;YAAE,OAAO,OAAO,CAAC;IAC/C,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,iEAAiE;AACpD,QAAA,eAAe,GAAiB,EAAE,YAAY,EAAE,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC;AAEpF;;;;GAIG;AACH,SAAgB,YAAY,CAAC,KAAa,EAAE,SAAiB,EAAE,UAAkB,EAAE,WAAW,GAAG,KAAK;IACpG,MAAM,OAAO,GAAG,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,uBAAe,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IACjF,IAAI,CAAC,OAAO;QAAE,OAAO,IAAI,CAAC;IAC1B,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC,GAAG,OAAO,CAAC,YAAY;QAC9C,CAAC,UAAU,GAAG,SAAS,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC;AAC1D,CAAC"}
|
package/dist/core/runtime.d.ts
CHANGED
|
@@ -14,4 +14,13 @@ export declare function estimateAgentRuntime(entry: {
|
|
|
14
14
|
tool_calls: number;
|
|
15
15
|
}, config?: RuntimeEstimatorConfig): number;
|
|
16
16
|
export declare function calculateWallClock(start: string, end: string): number;
|
|
17
|
+
/**
|
|
18
|
+
* Merge overlapping time intervals and return the total merged duration in ms.
|
|
19
|
+
* This reveals parallelization: if 3 agents run concurrently for 30min each,
|
|
20
|
+
* total runtime is 90min but merged runtime is 30min.
|
|
21
|
+
*/
|
|
22
|
+
export declare function computeMergedRuntimeMs(entries: Array<{
|
|
23
|
+
start: string;
|
|
24
|
+
end: string | null;
|
|
25
|
+
}>): number;
|
|
17
26
|
//# sourceMappingURL=runtime.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,sBAAsB;IACrC,uBAAuB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,yBAAyB,EAAE,MAAM,CAAC;IAClC,oBAAoB,EAAE,MAAM,CAAC;CAC9B;AAED,eAAO,MAAM,sBAAsB,EAAE,sBAWpC,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,KAAK,EAAE;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,EAChE,MAAM,GAAE,sBAA+C,GACtD,MAAM,CAKR;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAErE"}
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,sBAAsB;IACrC,uBAAuB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,yBAAyB,EAAE,MAAM,CAAC;IAClC,oBAAoB,EAAE,MAAM,CAAC;CAC9B;AAED,eAAO,MAAM,sBAAsB,EAAE,sBAWpC,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,KAAK,EAAE;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,EAAE,MAAM,CAAA;CAAE,EAChE,MAAM,GAAE,sBAA+C,GACtD,MAAM,CAKR;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAErE;AAED;;;;GAIG;AACH,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,KAAK,CAAC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAAC,GAAG,MAAM,CA4BpG"}
|
package/dist/core/runtime.js
CHANGED
|
@@ -7,6 +7,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
7
7
|
exports.DEFAULT_RUNTIME_CONFIG = void 0;
|
|
8
8
|
exports.estimateAgentRuntime = estimateAgentRuntime;
|
|
9
9
|
exports.calculateWallClock = calculateWallClock;
|
|
10
|
+
exports.computeMergedRuntimeMs = computeMergedRuntimeMs;
|
|
10
11
|
exports.DEFAULT_RUNTIME_CONFIG = {
|
|
11
12
|
model_tokens_per_second: {
|
|
12
13
|
'claude-sonnet-4': 80,
|
|
@@ -28,6 +29,38 @@ function estimateAgentRuntime(entry, config = exports.DEFAULT_RUNTIME_CONFIG) {
|
|
|
28
29
|
function calculateWallClock(start, end) {
|
|
29
30
|
return new Date(end).getTime() - new Date(start).getTime();
|
|
30
31
|
}
|
|
32
|
+
/**
|
|
33
|
+
* Merge overlapping time intervals and return the total merged duration in ms.
|
|
34
|
+
* This reveals parallelization: if 3 agents run concurrently for 30min each,
|
|
35
|
+
* total runtime is 90min but merged runtime is 30min.
|
|
36
|
+
*/
|
|
37
|
+
function computeMergedRuntimeMs(entries) {
|
|
38
|
+
if (entries.length === 0)
|
|
39
|
+
return 0;
|
|
40
|
+
// Convert to [startMs, endMs] intervals
|
|
41
|
+
const intervals = entries.map(e => {
|
|
42
|
+
const startMs = new Date(e.start).getTime();
|
|
43
|
+
const endMs = e.end ? new Date(e.end).getTime() : Date.now();
|
|
44
|
+
return [startMs, endMs];
|
|
45
|
+
});
|
|
46
|
+
// Sort by start time
|
|
47
|
+
intervals.sort((a, b) => a[0] - b[0]);
|
|
48
|
+
// Merge overlapping intervals
|
|
49
|
+
const merged = [intervals[0]];
|
|
50
|
+
for (let i = 1; i < intervals.length; i++) {
|
|
51
|
+
const last = merged[merged.length - 1];
|
|
52
|
+
const curr = intervals[i];
|
|
53
|
+
if (curr[0] <= last[1]) {
|
|
54
|
+
// Overlapping — extend the end
|
|
55
|
+
last[1] = Math.max(last[1], curr[1]);
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
merged.push(curr);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
// Sum merged interval durations
|
|
62
|
+
return merged.reduce((sum, [start, end]) => sum + (end - start), 0);
|
|
63
|
+
}
|
|
31
64
|
function findModelSpeed(model, config) {
|
|
32
65
|
// Exact match first
|
|
33
66
|
if (config.model_tokens_per_second[model]) {
|
package/dist/core/runtime.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAqBH,oDAQC;AAED,gDAEC;
|
|
1
|
+
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":"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"}
|
package/dist/core/sync.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/core/sync.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,SAAS,EAAe,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"sync.d.ts","sourceRoot":"","sources":["../../src/core/sync.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,SAAS,EAAe,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAGtC,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,EAAE,CAAW;IACrB,OAAO,CAAC,QAAQ,CAA+C;gBAEnD,MAAM,EAAE,YAAY,EAAE,EAAE,EAAE,QAAQ;IAK9C,KAAK,IAAI,IAAI;IAOb,IAAI,IAAI,IAAI;IAON,OAAO,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;IAc/B,OAAO,CAAC,MAAM,EAAE,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC;IAiDvD,SAAS,IAAI,SAAS,EAAE;CAGzB"}
|
package/dist/core/sync.js
CHANGED
|
@@ -4,6 +4,7 @@
|
|
|
4
4
|
*/
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.SyncManager = void 0;
|
|
7
|
+
const logger_1 = require("./logger");
|
|
7
8
|
class SyncManager {
|
|
8
9
|
config;
|
|
9
10
|
db;
|
|
@@ -62,6 +63,7 @@ class SyncManager {
|
|
|
62
63
|
}
|
|
63
64
|
const entries = await response.json();
|
|
64
65
|
const count = this.db.bulkUpsert(entries);
|
|
66
|
+
logger_1.logger.info('sync', `Synced ${count} entries from ${source.name}`);
|
|
65
67
|
const state = {
|
|
66
68
|
source_name: source.name,
|
|
67
69
|
last_sync_at: new Date().toISOString(),
|
|
@@ -72,6 +74,7 @@ class SyncManager {
|
|
|
72
74
|
return state;
|
|
73
75
|
}
|
|
74
76
|
catch (err) {
|
|
77
|
+
logger_1.logger.error('sync', `Sync failed for ${source.name}`, { error: err.message || String(err) });
|
|
75
78
|
const state = {
|
|
76
79
|
source_name: source.name,
|
|
77
80
|
last_sync_at: new Date().toISOString(),
|
package/dist/core/sync.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/core/sync.ts"],"names":[],"mappings":";AAAA;;GAEG;;;
|
|
1
|
+
{"version":3,"file":"sync.js","sourceRoot":"","sources":["../../src/core/sync.ts"],"names":[],"mappings":"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"}
|
package/dist/core/types.d.ts
CHANGED
|
@@ -60,7 +60,7 @@ export interface EntryComparison {
|
|
|
60
60
|
industry_benchmark_minutes?: number;
|
|
61
61
|
industry_source?: string;
|
|
62
62
|
personal_benchmark_minutes?: number;
|
|
63
|
-
|
|
63
|
+
agent_total_runtime_minutes: number;
|
|
64
64
|
wall_clock_minutes: number;
|
|
65
65
|
}
|
|
66
66
|
export interface HumanEquivalent {
|
|
@@ -106,6 +106,8 @@ export interface ClawckConfig {
|
|
|
106
106
|
};
|
|
107
107
|
/** Use industry benchmarks for human-equiv calculations (default: true) */
|
|
108
108
|
use_industry_benchmarks?: boolean;
|
|
109
|
+
/** CORS origin(s) — true for all origins (default), string or string[] to restrict */
|
|
110
|
+
cors_origin?: string | string[] | boolean;
|
|
109
111
|
/** Your personal hourly rate for savings calculations */
|
|
110
112
|
personal_rate_usd?: number;
|
|
111
113
|
}
|
|
@@ -139,19 +141,24 @@ export interface WebhookConfig {
|
|
|
139
141
|
}
|
|
140
142
|
export interface TimesheetRow {
|
|
141
143
|
date: string;
|
|
144
|
+
start_time: string;
|
|
145
|
+
end_time: string | null;
|
|
142
146
|
agent: string;
|
|
143
147
|
client: string;
|
|
144
148
|
project: string;
|
|
145
149
|
task: string;
|
|
146
150
|
category: TaskCategory;
|
|
147
151
|
duration_minutes: number;
|
|
152
|
+
tokens_in: number;
|
|
153
|
+
tokens_out: number;
|
|
148
154
|
tokens_total: number;
|
|
149
155
|
cost_usd: number;
|
|
150
156
|
human_equiv_hours: number;
|
|
151
157
|
human_equiv_cost_saved: number;
|
|
158
|
+
time_saved_hours: number;
|
|
152
159
|
status: EntryStatus;
|
|
153
160
|
approved: boolean;
|
|
154
|
-
|
|
161
|
+
agent_total_runtime_minutes?: number;
|
|
155
162
|
wall_clock_minutes?: number;
|
|
156
163
|
}
|
|
157
164
|
export interface TimesheetSummary {
|
|
@@ -163,11 +170,15 @@ export interface TimesheetSummary {
|
|
|
163
170
|
total_cost_usd: number;
|
|
164
171
|
total_savings_usd: number;
|
|
165
172
|
total_tokens: number;
|
|
173
|
+
total_tokens_in: number;
|
|
174
|
+
total_tokens_out: number;
|
|
175
|
+
total_time_saved_hours: number;
|
|
166
176
|
by_client: ClientSummary[];
|
|
167
177
|
by_agent: AgentSummary[];
|
|
168
178
|
by_project: ProjectSummary[];
|
|
169
179
|
by_category: CategorySummary[];
|
|
170
180
|
entries: TimesheetRow[];
|
|
181
|
+
total_agent_merged_runtime_hours: number;
|
|
171
182
|
total_personal_equiv_hours?: number;
|
|
172
183
|
total_personal_savings_usd?: number;
|
|
173
184
|
}
|
|
@@ -264,7 +275,7 @@ export interface ClawckLogInput {
|
|
|
264
275
|
tags?: string[];
|
|
265
276
|
}
|
|
266
277
|
export declare const SPEC_VERSION = "0.2.0";
|
|
267
|
-
export declare const APP_VERSION = "0.
|
|
278
|
+
export declare const APP_VERSION = "0.5.2";
|
|
268
279
|
/**
|
|
269
280
|
* Default human-equivalent multipliers.
|
|
270
281
|
* These are configurable starting estimates, NOT researched benchmarks.
|
package/dist/core/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,MAAM,WAAW,GAAG,SAAS,GAAG,WAAW,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAExE,MAAM,MAAM,YAAY,GACpB,UAAU,GACV,SAAS,GACT,MAAM,GACN,YAAY,GACZ,QAAQ,GACR,eAAe,GACf,UAAU,GACV,SAAS,GACT,UAAU,GACV,OAAO,CAAC;AAEZ,MAAM,WAAW,WAAW;IAC1B,yCAAyC;IACzC,EAAE,EAAE,MAAM,CAAC;IAEX,mDAAmD;IACnD,KAAK,EAAE,MAAM,CAAC;IAEd,wDAAwD;IACxD,KAAK,EAAE,MAAM,CAAC;IAEd,wBAAwB;IACxB,MAAM,EAAE,MAAM,CAAC;IAEf,yBAAyB;IACzB,OAAO,EAAE,MAAM,CAAC;IAEhB,sCAAsC;IACtC,IAAI,EAAE,MAAM,CAAC;IAEb,mDAAmD;IACnD,QAAQ,EAAE,YAAY,CAAC;IAEvB,+BAA+B;IAC/B,KAAK,EAAE,MAAM,CAAC;IAEd,qDAAqD;IACrD,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IAEnB,mBAAmB;IACnB,MAAM,EAAE,WAAW,CAAC;IAEpB,4BAA4B;IAC5B,SAAS,EAAE,MAAM,CAAC;IAElB,8BAA8B;IAC9B,UAAU,EAAE,MAAM,CAAC;IAEnB,4BAA4B;IAC5B,QAAQ,EAAE,MAAM,CAAC;IAEjB,kDAAkD;IAClD,UAAU,EAAE,MAAM,CAAC;IAEnB,2CAA2C;IAC3C,OAAO,EAAE,MAAM,CAAC;IAEhB,mCAAmC;IACnC,IAAI,EAAE,MAAM,EAAE,CAAC;IAEf,oDAAoD;IACpD,MAAM,EAAE,MAAM,CAAC;IAEf,yBAAyB;IACzB,YAAY,EAAE,MAAM,CAAC;IAErB,kCAAkC;IAClC,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,sCAAsC;IACtC,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,2CAA2C;IAC3C,QAAQ,CAAC,EAAE,OAAO,CAAC;IAEnB,sDAAsD;IACtD,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAEjC,oDAAoD;IACpD,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAE9B,+BAA+B;IAC/B,UAAU,CAAC,EAAE,eAAe,CAAC;CAC9B;AAID,MAAM,WAAW,eAAe;IAC9B,0BAA0B,CAAC,EAAE,MAAM,CAAC;IACpC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,0BAA0B,CAAC,EAAE,MAAM,CAAC;IACpC,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":"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"}
|
package/dist/core/types.js
CHANGED
|
@@ -9,7 +9,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
9
9
|
exports.TASK_CATEGORIES = exports.DEFAULT_CONFIG = exports.DEFAULT_HUMAN_EQUIVALENTS = exports.APP_VERSION = exports.SPEC_VERSION = void 0;
|
|
10
10
|
// ─── Defaults ────────────────────────────────────────────
|
|
11
11
|
exports.SPEC_VERSION = '0.2.0';
|
|
12
|
-
exports.APP_VERSION = '0.
|
|
12
|
+
exports.APP_VERSION = '0.5.2';
|
|
13
13
|
/**
|
|
14
14
|
* Default human-equivalent multipliers.
|
|
15
15
|
* These are configurable starting estimates, NOT researched benchmarks.
|
package/dist/core/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/core/types.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAqWH,4DAA4D;AAE/C,QAAA,YAAY,GAAG,OAAO,CAAC;AACvB,QAAA,WAAW,GAAG,OAAO,CAAC;AAEnC;;;;;GAKG;AACU,QAAA,yBAAyB,GAA0C;IAC9E,QAAQ,EAAQ,EAAE,UAAU,EAAE,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE;IACtD,OAAO,EAAS,EAAE,UAAU,EAAE,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE;IACtD,IAAI,EAAY,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;IACtD,UAAU,EAAM,EAAE,UAAU,EAAE,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE;IACtD,MAAM,EAAU,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;IACtD,aAAa,EAAG,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;IACtD,QAAQ,EAAQ,EAAE,UAAU,EAAE,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE;IACtD,OAAO,EAAS,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;IACtD,QAAQ,EAAQ,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;IACtD,KAAK,EAAW,EAAE,UAAU,EAAE,CAAC,EAAG,cAAc,EAAE,EAAE,EAAE;CACvD,CAAC;AAEW,QAAA,cAAc,GAAiB;IAC1C,IAAI,EAAE,IAAI;IACV,QAAQ,EAAE,SAAS;IACnB,iBAAiB,EAAE,iCAAyB;IAC5C,aAAa,EAAE,EAAE;CAClB,CAAC;AAEW,QAAA,eAAe,GAAmB;IAC7C,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,QAAQ;IACrD,eAAe,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,OAAO;CAC5D,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webhooks.d.ts","sourceRoot":"","sources":["../../src/core/webhooks.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"webhooks.d.ts","sourceRoot":"","sources":["../../src/core/webhooks.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAClE,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAGtC,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,YAAY,CAAC;IACpB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,SAAS,CAA+C;IAChE,OAAO,CAAC,SAAS,CAAS;gBAEd,MAAM,EAAE,YAAY;IAIhC,IAAI,CAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI;IA8BjE,gBAAgB,CAAC,EAAE,EAAE,QAAQ,GAAG,IAAI;IAwBpC,eAAe,IAAI,IAAI;CAMxB"}
|
package/dist/core/webhooks.js
CHANGED
|
@@ -5,6 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
7
|
exports.WebhookManager = void 0;
|
|
8
|
+
const logger_1 = require("./logger");
|
|
8
9
|
class WebhookManager {
|
|
9
10
|
config;
|
|
10
11
|
idleTimer = null;
|
|
@@ -32,8 +33,10 @@ class WebhookManager {
|
|
|
32
33
|
method: 'POST',
|
|
33
34
|
headers,
|
|
34
35
|
body: JSON.stringify(fullPayload),
|
|
35
|
-
}).
|
|
36
|
-
|
|
36
|
+
}).then(() => {
|
|
37
|
+
logger_1.logger.debug('webhooks', `Delivered ${event} to ${wh.url}`);
|
|
38
|
+
}).catch((err) => {
|
|
39
|
+
logger_1.logger.warn('webhooks', `Failed to deliver ${event} to ${wh.url}`, { error: err.message });
|
|
37
40
|
});
|
|
38
41
|
}
|
|
39
42
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"webhooks.js","sourceRoot":"","sources":["../../src/core/webhooks.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;
|
|
1
|
+
{"version":3,"file":"webhooks.js","sourceRoot":"","sources":["../../src/core/webhooks.ts"],"names":[],"mappings":"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"}
|
package/dist/dashboard/index.js
CHANGED
|
@@ -439,9 +439,9 @@ function render() {
|
|
|
439
439
|
const statsHTML = \`
|
|
440
440
|
<div class="stats-grid">
|
|
441
441
|
<div class="stat-card">
|
|
442
|
-
<div class="stat-label">
|
|
443
|
-
<div class="stat-value stat-accent">\${ts.total_agent_hours.toFixed(1)}</div>
|
|
444
|
-
<div class="stat-sub"
|
|
442
|
+
<div class="stat-label">Total Runtime</div>
|
|
443
|
+
<div class="stat-value stat-accent">\${ts.total_agent_hours.toFixed(1)}h</div>
|
|
444
|
+
<div class="stat-sub">Merged: \${(ts.total_agent_merged_runtime_hours || 0).toFixed(1)}h\${ts.total_agent_merged_runtime_hours > 0 && ts.total_agent_merged_runtime_hours < ts.total_agent_hours ? ' (' + (ts.total_agent_hours / ts.total_agent_merged_runtime_hours).toFixed(1) + 'x parallel)' : ''}</div>
|
|
445
445
|
</div>
|
|
446
446
|
<div class="stat-card">
|
|
447
447
|
<div class="stat-label">Human Equiv Hours</div>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapters.d.ts","sourceRoot":"","sources":["../../src/hooks/adapters.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAIhD,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAQtE;
|
|
1
|
+
{"version":3,"file":"adapters.d.ts","sourceRoot":"","sources":["../../src/hooks/adapters.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAIhD,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAQtE;AAmID,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,QAAQ,CAAC,EAAE,QAAQ,GAAG,WAAW,CAGzF"}
|
package/dist/hooks/adapters.js
CHANGED
|
@@ -33,8 +33,9 @@ function normalizeClaude(json) {
|
|
|
33
33
|
agent: 'claude-code',
|
|
34
34
|
model: str(json.model),
|
|
35
35
|
cwd: str(json.cwd),
|
|
36
|
-
tokens_in: num(json.tokens_in),
|
|
37
|
-
tokens_out: num(json.tokens_out),
|
|
36
|
+
tokens_in: num(json.tokens_in) ?? num(json.total_input_tokens),
|
|
37
|
+
tokens_out: num(json.tokens_out) ?? num(json.total_output_tokens),
|
|
38
|
+
cost_usd: num(json.cost_usd) ?? num(json.total_cost_usd),
|
|
38
39
|
tool_calls: num(json.tool_calls) ?? num(json.num_tool_calls),
|
|
39
40
|
raw: json,
|
|
40
41
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../src/hooks/adapters.ts"],"names":[],"mappings":";AAAA;;;GAGG;;AAMH,wCAQC;
|
|
1
|
+
{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../src/hooks/adapters.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../src/hooks/handler.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"handler.d.ts","sourceRoot":"","sources":["../../src/hooks/handler.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE7C,OAAO,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAkBtC,wBAAsB,eAAe,CAAC,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAiC/F;AAED,wBAAsB,cAAc,CAAC,MAAM,EAAE,YAAY,EAAE,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC,CAmC9F"}
|
package/dist/hooks/handler.js
CHANGED
|
@@ -11,6 +11,7 @@ exports.handleHookStart = handleHookStart;
|
|
|
11
11
|
exports.handleHookStop = handleHookStop;
|
|
12
12
|
const clawck_1 = require("../core/clawck");
|
|
13
13
|
const session_1 = require("./session");
|
|
14
|
+
const logger_1 = require("../core/logger");
|
|
14
15
|
const fs_1 = __importDefault(require("fs"));
|
|
15
16
|
const path_1 = __importDefault(require("path"));
|
|
16
17
|
function logError(dataDir, message) {
|
|
@@ -43,7 +44,7 @@ async function handleHookStart(config, context) {
|
|
|
43
44
|
started_at: entry.start,
|
|
44
45
|
session_id: context.session_id,
|
|
45
46
|
});
|
|
46
|
-
|
|
47
|
+
logger_1.logger.info('hooks', `Started ${entry.id.slice(0, 8)} (${context.platform})`);
|
|
47
48
|
// Opportunistic cleanup of stale sessions
|
|
48
49
|
(0, session_1.cleanStaleSessions)(config.data_dir);
|
|
49
50
|
}
|
|
@@ -53,7 +54,7 @@ async function handleHookStart(config, context) {
|
|
|
53
54
|
}
|
|
54
55
|
catch (err) {
|
|
55
56
|
const msg = err instanceof Error ? err.message : String(err);
|
|
56
|
-
|
|
57
|
+
logger_1.logger.error('hooks', `Hook start error: ${msg}`);
|
|
57
58
|
logError(config.data_dir, `start error: ${msg}`);
|
|
58
59
|
}
|
|
59
60
|
}
|
|
@@ -61,7 +62,7 @@ async function handleHookStop(config, context) {
|
|
|
61
62
|
try {
|
|
62
63
|
const session = (0, session_1.loadSession)(config.data_dir, context.session_id);
|
|
63
64
|
if (!session) {
|
|
64
|
-
|
|
65
|
+
logger_1.logger.debug('hooks', 'Stop skipped — session already stopped or not started');
|
|
65
66
|
return;
|
|
66
67
|
}
|
|
67
68
|
const clawck = await new clawck_1.Clawck(config).ready();
|
|
@@ -71,13 +72,14 @@ async function handleHookStop(config, context) {
|
|
|
71
72
|
status: 'completed',
|
|
72
73
|
tokens_in: context.tokens_in,
|
|
73
74
|
tokens_out: context.tokens_out,
|
|
75
|
+
cost_usd: context.cost_usd,
|
|
74
76
|
tool_calls: context.tool_calls,
|
|
75
77
|
});
|
|
76
78
|
(0, session_1.clearSession)(config.data_dir, context.session_id);
|
|
77
79
|
if (entry && entry.end) {
|
|
78
80
|
const durationMs = new Date(entry.end).getTime() - new Date(entry.start).getTime();
|
|
79
81
|
const durationMin = (durationMs / 60000).toFixed(1);
|
|
80
|
-
|
|
82
|
+
logger_1.logger.info('hooks', `Stopped ${entry.id.slice(0, 8)} (${durationMin}m)`);
|
|
81
83
|
}
|
|
82
84
|
}
|
|
83
85
|
finally {
|
|
@@ -86,7 +88,7 @@ async function handleHookStop(config, context) {
|
|
|
86
88
|
}
|
|
87
89
|
catch (err) {
|
|
88
90
|
const msg = err instanceof Error ? err.message : String(err);
|
|
89
|
-
|
|
91
|
+
logger_1.logger.error('hooks', `Hook stop error: ${msg}`);
|
|
90
92
|
logError(config.data_dir, `stop error: ${msg}`);
|
|
91
93
|
}
|
|
92
94
|
}
|