agent-relay 1.0.21 → 1.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.
- package/dist/bridge/shadow-cli.d.ts +17 -0
- package/dist/bridge/shadow-cli.d.ts.map +1 -0
- package/dist/bridge/shadow-cli.js +75 -0
- package/dist/bridge/shadow-cli.js.map +1 -0
- package/dist/bridge/shadow-config.d.ts +87 -0
- package/dist/bridge/shadow-config.d.ts.map +1 -0
- package/dist/bridge/shadow-config.js +134 -0
- package/dist/bridge/shadow-config.js.map +1 -0
- package/dist/bridge/spawner.d.ts +15 -1
- package/dist/bridge/spawner.d.ts.map +1 -1
- package/dist/bridge/spawner.js +164 -4
- package/dist/bridge/spawner.js.map +1 -1
- package/dist/bridge/types.d.ts +55 -0
- package/dist/bridge/types.d.ts.map +1 -1
- package/dist/cli/index.js +796 -11
- package/dist/cli/index.js.map +1 -1
- package/dist/cloud/api/auth.d.ts +19 -0
- package/dist/cloud/api/auth.d.ts.map +1 -0
- package/dist/cloud/api/auth.js +216 -0
- package/dist/cloud/api/auth.js.map +1 -0
- package/dist/cloud/api/billing.d.ts +17 -0
- package/dist/cloud/api/billing.d.ts.map +1 -0
- package/dist/cloud/api/billing.js +353 -0
- package/dist/cloud/api/billing.js.map +1 -0
- package/dist/cloud/api/coordinators.d.ts +8 -0
- package/dist/cloud/api/coordinators.d.ts.map +1 -0
- package/dist/cloud/api/coordinators.js +347 -0
- package/dist/cloud/api/coordinators.js.map +1 -0
- package/dist/cloud/api/daemons.d.ts +12 -0
- package/dist/cloud/api/daemons.d.ts.map +1 -0
- package/dist/cloud/api/daemons.js +320 -0
- package/dist/cloud/api/daemons.js.map +1 -0
- package/dist/cloud/api/middleware/planLimits.d.ts +36 -0
- package/dist/cloud/api/middleware/planLimits.d.ts.map +1 -0
- package/dist/cloud/api/middleware/planLimits.js +164 -0
- package/dist/cloud/api/middleware/planLimits.js.map +1 -0
- package/dist/cloud/api/onboarding.d.ts +8 -0
- package/dist/cloud/api/onboarding.d.ts.map +1 -0
- package/dist/cloud/api/onboarding.js +407 -0
- package/dist/cloud/api/onboarding.js.map +1 -0
- package/dist/cloud/api/providers.d.ts +7 -0
- package/dist/cloud/api/providers.d.ts.map +1 -0
- package/dist/cloud/api/providers.js +435 -0
- package/dist/cloud/api/providers.js.map +1 -0
- package/dist/cloud/api/repos.d.ts +7 -0
- package/dist/cloud/api/repos.d.ts.map +1 -0
- package/dist/cloud/api/repos.js +314 -0
- package/dist/cloud/api/repos.js.map +1 -0
- package/dist/cloud/api/teams.d.ts +7 -0
- package/dist/cloud/api/teams.d.ts.map +1 -0
- package/dist/cloud/api/teams.js +279 -0
- package/dist/cloud/api/teams.js.map +1 -0
- package/dist/cloud/api/usage.d.ts +7 -0
- package/dist/cloud/api/usage.d.ts.map +1 -0
- package/dist/cloud/api/usage.js +98 -0
- package/dist/cloud/api/usage.js.map +1 -0
- package/dist/cloud/api/workspaces.d.ts +7 -0
- package/dist/cloud/api/workspaces.d.ts.map +1 -0
- package/dist/cloud/api/workspaces.js +510 -0
- package/dist/cloud/api/workspaces.js.map +1 -0
- package/dist/cloud/billing/index.d.ts +9 -0
- package/dist/cloud/billing/index.d.ts.map +1 -0
- package/dist/cloud/billing/index.js +9 -0
- package/dist/cloud/billing/index.js.map +1 -0
- package/dist/cloud/billing/plans.d.ts +39 -0
- package/dist/cloud/billing/plans.d.ts.map +1 -0
- package/dist/cloud/billing/plans.js +232 -0
- package/dist/cloud/billing/plans.js.map +1 -0
- package/dist/cloud/billing/service.d.ts +80 -0
- package/dist/cloud/billing/service.d.ts.map +1 -0
- package/dist/cloud/billing/service.js +388 -0
- package/dist/cloud/billing/service.js.map +1 -0
- package/dist/cloud/billing/types.d.ts +135 -0
- package/dist/cloud/billing/types.d.ts.map +1 -0
- package/dist/cloud/billing/types.js +7 -0
- package/dist/cloud/billing/types.js.map +1 -0
- package/dist/cloud/config.d.ts +59 -0
- package/dist/cloud/config.d.ts.map +1 -0
- package/dist/cloud/config.js +83 -0
- package/dist/cloud/config.js.map +1 -0
- package/dist/cloud/db/drizzle.d.ts +132 -0
- package/dist/cloud/db/drizzle.d.ts.map +1 -0
- package/dist/cloud/db/drizzle.js +613 -0
- package/dist/cloud/db/drizzle.js.map +1 -0
- package/dist/cloud/db/index.d.ts +30 -0
- package/dist/cloud/db/index.d.ts.map +1 -0
- package/dist/cloud/db/index.js +44 -0
- package/dist/cloud/db/index.js.map +1 -0
- package/dist/cloud/db/schema.d.ts +1792 -0
- package/dist/cloud/db/schema.d.ts.map +1 -0
- package/dist/cloud/db/schema.js +234 -0
- package/dist/cloud/db/schema.js.map +1 -0
- package/dist/cloud/index.d.ts +11 -0
- package/dist/cloud/index.d.ts.map +1 -0
- package/dist/cloud/index.js +37 -0
- package/dist/cloud/index.js.map +1 -0
- package/dist/cloud/provisioner/index.d.ts +51 -0
- package/dist/cloud/provisioner/index.d.ts.map +1 -0
- package/dist/cloud/provisioner/index.js +676 -0
- package/dist/cloud/provisioner/index.js.map +1 -0
- package/dist/cloud/server.d.ts +16 -0
- package/dist/cloud/server.d.ts.map +1 -0
- package/dist/cloud/server.js +190 -0
- package/dist/cloud/server.js.map +1 -0
- package/dist/cloud/services/coordinator.d.ts +62 -0
- package/dist/cloud/services/coordinator.d.ts.map +1 -0
- package/dist/cloud/services/coordinator.js +389 -0
- package/dist/cloud/services/coordinator.js.map +1 -0
- package/dist/cloud/services/planLimits.d.ts +110 -0
- package/dist/cloud/services/planLimits.d.ts.map +1 -0
- package/dist/cloud/services/planLimits.js +254 -0
- package/dist/cloud/services/planLimits.js.map +1 -0
- package/dist/cloud/vault/index.d.ts +76 -0
- package/dist/cloud/vault/index.d.ts.map +1 -0
- package/dist/cloud/vault/index.js +219 -0
- package/dist/cloud/vault/index.js.map +1 -0
- package/dist/daemon/agent-manager.d.ts +87 -0
- package/dist/daemon/agent-manager.d.ts.map +1 -0
- package/dist/daemon/agent-manager.js +412 -0
- package/dist/daemon/agent-manager.js.map +1 -0
- package/dist/daemon/agent-registry.d.ts +2 -0
- package/dist/daemon/agent-registry.d.ts.map +1 -1
- package/dist/daemon/agent-registry.js +3 -0
- package/dist/daemon/agent-registry.js.map +1 -1
- package/dist/daemon/api.d.ts +69 -0
- package/dist/daemon/api.d.ts.map +1 -0
- package/dist/daemon/api.js +425 -0
- package/dist/daemon/api.js.map +1 -0
- package/dist/daemon/cloud-sync.d.ts +101 -0
- package/dist/daemon/cloud-sync.d.ts.map +1 -0
- package/dist/daemon/cloud-sync.js +261 -0
- package/dist/daemon/cloud-sync.js.map +1 -0
- package/dist/daemon/index.d.ts +4 -0
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +6 -0
- package/dist/daemon/index.js.map +1 -1
- package/dist/daemon/orchestrator.d.ts +155 -0
- package/dist/daemon/orchestrator.d.ts.map +1 -0
- package/dist/daemon/orchestrator.js +736 -0
- package/dist/daemon/orchestrator.js.map +1 -0
- package/dist/daemon/router.d.ts +24 -0
- package/dist/daemon/router.d.ts.map +1 -1
- package/dist/daemon/router.js +71 -1
- package/dist/daemon/router.js.map +1 -1
- package/dist/daemon/server.d.ts +37 -0
- package/dist/daemon/server.d.ts.map +1 -1
- package/dist/daemon/server.js +191 -16
- package/dist/daemon/server.js.map +1 -1
- package/dist/daemon/types.d.ts +127 -0
- package/dist/daemon/types.d.ts.map +1 -0
- package/dist/daemon/types.js +6 -0
- package/dist/daemon/types.js.map +1 -0
- package/dist/daemon/workspace-manager.d.ts +75 -0
- package/dist/daemon/workspace-manager.d.ts.map +1 -0
- package/dist/daemon/workspace-manager.js +289 -0
- package/dist/daemon/workspace-manager.js.map +1 -0
- package/dist/dashboard/out/404.html +1 -1
- package/dist/dashboard/out/_next/static/chunks/693-7b3301d8f6bc5014.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/713-f78477eb185f1f4d.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/766-e53e1cfe39b0b5b5.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/900-037c64bfd797fb2a.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/app/page-e3d9e1f4466b9bae.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/history/page-b6edd4dde8d08194.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/layout-2433bb48965f4333.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-e68825a81db67ba1.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/page-cc108bf68c8a657f.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/app/pricing/page-d80e03a5297f95b6.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/main-app-5d692157a8eb1fd9.js +1 -0
- package/dist/dashboard/out/_next/static/chunks/{main-e0a1f53fe0617a63.js → main-c2f423b9c9f4591b.js} +1 -1
- package/dist/dashboard/out/_next/static/chunks/{webpack-c81f7fd28659d64f.js → webpack-a5acc2831d094776.js} +1 -1
- package/dist/dashboard/out/_next/static/css/79b80143647a07d7.css +1 -0
- package/dist/dashboard/out/_next/static/css/8cf277370ad48cfe.css +1 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo-128.png +0 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo-256.png +0 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo-32.png +0 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo-512.png +0 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo-64.png +0 -0
- package/dist/dashboard/out/alt-logos/agent-relay-logo.svg +45 -0
- package/dist/dashboard/out/alt-logos/logo.svg +38 -0
- package/dist/dashboard/out/alt-logos/monogram-logo-128.png +0 -0
- package/dist/dashboard/out/alt-logos/monogram-logo-256.png +0 -0
- package/dist/dashboard/out/alt-logos/monogram-logo-32.png +0 -0
- package/dist/dashboard/out/alt-logos/monogram-logo-512.png +0 -0
- package/dist/dashboard/out/alt-logos/monogram-logo-64.png +0 -0
- package/dist/dashboard/out/alt-logos/monogram-logo.svg +38 -0
- package/dist/dashboard/out/app.html +14 -0
- package/dist/dashboard/out/app.txt +7 -0
- package/dist/dashboard/out/history.html +1 -0
- package/dist/dashboard/out/history.txt +7 -0
- package/dist/dashboard/out/index.html +1 -1
- package/dist/dashboard/out/index.txt +2 -2
- package/dist/dashboard/out/metrics.html +1 -515
- package/dist/dashboard/out/metrics.txt +2 -2
- package/dist/dashboard/out/pricing.html +13 -0
- package/dist/dashboard/out/pricing.txt +7 -0
- package/dist/dashboard-server/metrics.d.ts.map +1 -1
- package/dist/dashboard-server/metrics.js +3 -2
- package/dist/dashboard-server/metrics.js.map +1 -1
- package/dist/dashboard-server/server.d.ts.map +1 -1
- package/dist/dashboard-server/server.js +1279 -56
- package/dist/dashboard-server/server.js.map +1 -1
- package/dist/protocol/types.d.ts +10 -1
- package/dist/protocol/types.d.ts.map +1 -1
- package/dist/resiliency/context-persistence.d.ts +140 -0
- package/dist/resiliency/context-persistence.d.ts.map +1 -0
- package/dist/resiliency/context-persistence.js +397 -0
- package/dist/resiliency/context-persistence.js.map +1 -0
- package/dist/resiliency/health-monitor.d.ts +97 -0
- package/dist/resiliency/health-monitor.d.ts.map +1 -0
- package/dist/resiliency/health-monitor.js +291 -0
- package/dist/resiliency/health-monitor.js.map +1 -0
- package/dist/resiliency/index.d.ts +63 -0
- package/dist/resiliency/index.d.ts.map +1 -0
- package/dist/resiliency/index.js +63 -0
- package/dist/resiliency/index.js.map +1 -0
- package/dist/resiliency/logger.d.ts +114 -0
- package/dist/resiliency/logger.d.ts.map +1 -0
- package/dist/resiliency/logger.js +250 -0
- package/dist/resiliency/logger.js.map +1 -0
- package/dist/resiliency/metrics.d.ts +115 -0
- package/dist/resiliency/metrics.d.ts.map +1 -0
- package/dist/resiliency/metrics.js +239 -0
- package/dist/resiliency/metrics.js.map +1 -0
- package/dist/resiliency/provider-context.d.ts +100 -0
- package/dist/resiliency/provider-context.d.ts.map +1 -0
- package/dist/resiliency/provider-context.js +360 -0
- package/dist/resiliency/provider-context.js.map +1 -0
- package/dist/resiliency/supervisor.d.ts +109 -0
- package/dist/resiliency/supervisor.d.ts.map +1 -0
- package/dist/resiliency/supervisor.js +337 -0
- package/dist/resiliency/supervisor.js.map +1 -0
- package/dist/storage/adapter.d.ts +2 -0
- package/dist/storage/adapter.d.ts.map +1 -1
- package/dist/storage/adapter.js +12 -2
- package/dist/storage/adapter.js.map +1 -1
- package/dist/storage/sqlite-adapter.d.ts.map +1 -1
- package/dist/storage/sqlite-adapter.js +18 -14
- package/dist/storage/sqlite-adapter.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/logger.d.ts +40 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +84 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/wrapper/client.d.ts +16 -1
- package/dist/wrapper/client.d.ts.map +1 -1
- package/dist/wrapper/client.js +32 -1
- package/dist/wrapper/client.js.map +1 -1
- package/dist/wrapper/parser.d.ts +3 -0
- package/dist/wrapper/parser.d.ts.map +1 -1
- package/dist/wrapper/parser.js +121 -18
- package/dist/wrapper/parser.js.map +1 -1
- package/dist/wrapper/pty-wrapper.d.ts +28 -1
- package/dist/wrapper/pty-wrapper.d.ts.map +1 -1
- package/dist/wrapper/pty-wrapper.js +166 -30
- package/dist/wrapper/pty-wrapper.js.map +1 -1
- package/dist/wrapper/tmux-wrapper.d.ts +5 -0
- package/dist/wrapper/tmux-wrapper.d.ts.map +1 -1
- package/dist/wrapper/tmux-wrapper.js +58 -18
- package/dist/wrapper/tmux-wrapper.js.map +1 -1
- package/docs/CLOUD-ARCHITECTURE.md +652 -0
- package/docs/CLOUD-ONBOARDING-DESIGN.md +1983 -0
- package/docs/TESTING_PRESENCE_FEATURES.md +327 -0
- package/docs/agent-relay-snippet.md +107 -4
- package/docs/guides/CLOUD.md +236 -0
- package/docs/guides/LOCAL.md +535 -0
- package/docs/guides/SELF-HOSTED.md +494 -0
- package/docs/proposals/shadow-as-subagent.md +765 -0
- package/docs/proposals/slack-bot-integration.md +1457 -0
- package/package.json +33 -4
- package/dist/dashboard/out/_next/static/chunks/app/layout-c9d8c5d95e48c6bf.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/metrics/page-8aa9936bc6c771ab.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/app/page-49055e5d2b5e34ec.js +0 -1
- package/dist/dashboard/out/_next/static/chunks/main-app-bae2e535de00de50.js +0 -1
- package/dist/dashboard/out/_next/static/css/50ed6996e3df7bdd.css +0 -1
- /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_buildManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_ssgManifest.js +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{117-3bef7b19f3e60751.js → 117-b2cd8d6485aacf2b.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{648-6cf686106c891ad3.js → 648-8f3f26864ce515e5.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-8ff6572bc7c9bc61.js → page-0b990dbb71d72a98.js} +0 -0
- /package/dist/dashboard/out/_next/static/chunks/{fd9d1056-26bd8d656b496dba.js → fd9d1056-bf46c09eb57e019c.js} +0 -0
|
@@ -0,0 +1,250 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Structured Logger
|
|
3
|
+
*
|
|
4
|
+
* Provides consistent, structured logging across agent-relay components.
|
|
5
|
+
* - JSON format for machine parsing
|
|
6
|
+
* - Log levels with filtering
|
|
7
|
+
* - Context propagation (correlation IDs, agent names)
|
|
8
|
+
* - File rotation support
|
|
9
|
+
*/
|
|
10
|
+
import { EventEmitter } from 'events';
|
|
11
|
+
import * as fs from 'fs';
|
|
12
|
+
import * as path from 'path';
|
|
13
|
+
const LOG_LEVELS = {
|
|
14
|
+
debug: 0,
|
|
15
|
+
info: 1,
|
|
16
|
+
warn: 2,
|
|
17
|
+
error: 3,
|
|
18
|
+
fatal: 4,
|
|
19
|
+
};
|
|
20
|
+
const LEVEL_COLORS = {
|
|
21
|
+
debug: '\x1b[90m', // gray
|
|
22
|
+
info: '\x1b[36m', // cyan
|
|
23
|
+
warn: '\x1b[33m', // yellow
|
|
24
|
+
error: '\x1b[31m', // red
|
|
25
|
+
fatal: '\x1b[35m', // magenta
|
|
26
|
+
};
|
|
27
|
+
const RESET = '\x1b[0m';
|
|
28
|
+
const DEFAULT_CONFIG = {
|
|
29
|
+
level: 'info',
|
|
30
|
+
json: process.env.NODE_ENV === 'production',
|
|
31
|
+
console: true,
|
|
32
|
+
maxFileSize: 10 * 1024 * 1024, // 10MB
|
|
33
|
+
maxFiles: 5,
|
|
34
|
+
};
|
|
35
|
+
export class Logger extends EventEmitter {
|
|
36
|
+
config;
|
|
37
|
+
component;
|
|
38
|
+
context = {};
|
|
39
|
+
fileStream;
|
|
40
|
+
currentFileSize = 0;
|
|
41
|
+
constructor(component, config = {}) {
|
|
42
|
+
super();
|
|
43
|
+
this.component = component;
|
|
44
|
+
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
45
|
+
if (this.config.file) {
|
|
46
|
+
this.initFileStream();
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Create a child logger with additional context
|
|
51
|
+
*/
|
|
52
|
+
child(context) {
|
|
53
|
+
const child = new Logger(this.component, this.config);
|
|
54
|
+
child.context = { ...this.context, ...context };
|
|
55
|
+
return child;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Set context that will be included in all log entries
|
|
59
|
+
*/
|
|
60
|
+
setContext(context) {
|
|
61
|
+
this.context = { ...this.context, ...context };
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Log at debug level
|
|
65
|
+
*/
|
|
66
|
+
debug(message, context) {
|
|
67
|
+
this.log('debug', message, context);
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Log at info level
|
|
71
|
+
*/
|
|
72
|
+
info(message, context) {
|
|
73
|
+
this.log('info', message, context);
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Log at warn level
|
|
77
|
+
*/
|
|
78
|
+
warn(message, context) {
|
|
79
|
+
this.log('warn', message, context);
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Log at error level
|
|
83
|
+
*/
|
|
84
|
+
error(message, context) {
|
|
85
|
+
this.log('error', message, context);
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Log at fatal level
|
|
89
|
+
*/
|
|
90
|
+
fatal(message, context) {
|
|
91
|
+
this.log('fatal', message, context);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Log with timing (returns function to end timing)
|
|
95
|
+
*/
|
|
96
|
+
time(message, context) {
|
|
97
|
+
const start = Date.now();
|
|
98
|
+
return () => {
|
|
99
|
+
const duration = Date.now() - start;
|
|
100
|
+
this.info(message, { ...context, duration });
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Log an error with stack trace
|
|
105
|
+
*/
|
|
106
|
+
logError(error, message, context) {
|
|
107
|
+
this.log('error', message || error.message, {
|
|
108
|
+
...context,
|
|
109
|
+
error: {
|
|
110
|
+
name: error.name,
|
|
111
|
+
message: error.message,
|
|
112
|
+
stack: error.stack,
|
|
113
|
+
},
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Core log method
|
|
118
|
+
*/
|
|
119
|
+
log(level, message, context) {
|
|
120
|
+
if (LOG_LEVELS[level] < LOG_LEVELS[this.config.level]) {
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
const entry = {
|
|
124
|
+
timestamp: new Date().toISOString(),
|
|
125
|
+
level,
|
|
126
|
+
component: this.component,
|
|
127
|
+
message,
|
|
128
|
+
...this.context,
|
|
129
|
+
...context,
|
|
130
|
+
};
|
|
131
|
+
// Emit for external handlers
|
|
132
|
+
this.emit('log', entry);
|
|
133
|
+
// Console output
|
|
134
|
+
if (this.config.console) {
|
|
135
|
+
this.writeConsole(entry);
|
|
136
|
+
}
|
|
137
|
+
// File output
|
|
138
|
+
if (this.fileStream) {
|
|
139
|
+
this.writeFile(entry);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Write to console
|
|
144
|
+
*/
|
|
145
|
+
writeConsole(entry) {
|
|
146
|
+
if (this.config.json) {
|
|
147
|
+
console.log(JSON.stringify(entry));
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
const color = LEVEL_COLORS[entry.level];
|
|
151
|
+
const levelStr = entry.level.toUpperCase().padEnd(5);
|
|
152
|
+
const componentStr = `[${entry.component}]`.padEnd(20);
|
|
153
|
+
let line = `${entry.timestamp} ${color}${levelStr}${RESET} ${componentStr} ${entry.message}`;
|
|
154
|
+
// Add context fields (exclude standard log entry fields)
|
|
155
|
+
const { timestamp: _t, level: _l, component: _c, message: _m, ...contextFields } = entry;
|
|
156
|
+
if (Object.keys(contextFields).length > 0) {
|
|
157
|
+
line += ` ${JSON.stringify(contextFields)}`;
|
|
158
|
+
}
|
|
159
|
+
console.log(line);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Write to file with rotation
|
|
164
|
+
*/
|
|
165
|
+
writeFile(entry) {
|
|
166
|
+
if (!this.fileStream)
|
|
167
|
+
return;
|
|
168
|
+
const line = JSON.stringify(entry) + '\n';
|
|
169
|
+
const lineBytes = Buffer.byteLength(line);
|
|
170
|
+
// Check if rotation needed
|
|
171
|
+
if (this.config.maxFileSize &&
|
|
172
|
+
this.currentFileSize + lineBytes > this.config.maxFileSize) {
|
|
173
|
+
this.rotateFile();
|
|
174
|
+
}
|
|
175
|
+
this.fileStream.write(line);
|
|
176
|
+
this.currentFileSize += lineBytes;
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Initialize file stream
|
|
180
|
+
*/
|
|
181
|
+
initFileStream() {
|
|
182
|
+
if (!this.config.file)
|
|
183
|
+
return;
|
|
184
|
+
const dir = path.dirname(this.config.file);
|
|
185
|
+
if (!fs.existsSync(dir)) {
|
|
186
|
+
fs.mkdirSync(dir, { recursive: true });
|
|
187
|
+
}
|
|
188
|
+
// Get current file size
|
|
189
|
+
if (fs.existsSync(this.config.file)) {
|
|
190
|
+
const stats = fs.statSync(this.config.file);
|
|
191
|
+
this.currentFileSize = stats.size;
|
|
192
|
+
}
|
|
193
|
+
this.fileStream = fs.createWriteStream(this.config.file, { flags: 'a' });
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Rotate log file
|
|
197
|
+
*/
|
|
198
|
+
rotateFile() {
|
|
199
|
+
if (!this.config.file || !this.fileStream)
|
|
200
|
+
return;
|
|
201
|
+
this.fileStream.end();
|
|
202
|
+
// Rotate existing files
|
|
203
|
+
for (let i = (this.config.maxFiles || 5) - 1; i >= 1; i--) {
|
|
204
|
+
const oldPath = `${this.config.file}.${i}`;
|
|
205
|
+
const newPath = `${this.config.file}.${i + 1}`;
|
|
206
|
+
if (fs.existsSync(oldPath)) {
|
|
207
|
+
if (i === (this.config.maxFiles || 5) - 1) {
|
|
208
|
+
fs.unlinkSync(oldPath); // Delete oldest
|
|
209
|
+
}
|
|
210
|
+
else {
|
|
211
|
+
fs.renameSync(oldPath, newPath);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
// Rename current to .1
|
|
216
|
+
if (fs.existsSync(this.config.file)) {
|
|
217
|
+
fs.renameSync(this.config.file, `${this.config.file}.1`);
|
|
218
|
+
}
|
|
219
|
+
// Create new stream
|
|
220
|
+
this.currentFileSize = 0;
|
|
221
|
+
this.fileStream = fs.createWriteStream(this.config.file, { flags: 'a' });
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Close the logger
|
|
225
|
+
*/
|
|
226
|
+
close() {
|
|
227
|
+
if (this.fileStream) {
|
|
228
|
+
this.fileStream.end();
|
|
229
|
+
this.fileStream = undefined;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
// Logger factory with global configuration
|
|
234
|
+
let globalConfig = {};
|
|
235
|
+
export function configure(config) {
|
|
236
|
+
globalConfig = config;
|
|
237
|
+
}
|
|
238
|
+
export function createLogger(component, config) {
|
|
239
|
+
return new Logger(component, { ...globalConfig, ...config });
|
|
240
|
+
}
|
|
241
|
+
// Pre-configured loggers for common components
|
|
242
|
+
export const loggers = {
|
|
243
|
+
daemon: () => createLogger('daemon'),
|
|
244
|
+
spawner: () => createLogger('spawner'),
|
|
245
|
+
router: () => createLogger('router'),
|
|
246
|
+
agent: (name) => createLogger('agent').child({ agentName: name }),
|
|
247
|
+
health: () => createLogger('health-monitor'),
|
|
248
|
+
connection: (id) => createLogger('connection').child({ connectionId: id }),
|
|
249
|
+
};
|
|
250
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/resiliency/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Resiliency Metrics
|
|
3
|
+
*
|
|
4
|
+
* Collects and exposes metrics about agent health, crashes, and restarts.
|
|
5
|
+
* - Prometheus-compatible format
|
|
6
|
+
* - In-memory aggregation
|
|
7
|
+
* - Real-time stats
|
|
8
|
+
*/
|
|
9
|
+
export interface AgentMetrics {
|
|
10
|
+
name: string;
|
|
11
|
+
spawns: number;
|
|
12
|
+
crashes: number;
|
|
13
|
+
restarts: number;
|
|
14
|
+
successfulRestarts: number;
|
|
15
|
+
failedRestarts: number;
|
|
16
|
+
currentStatus: 'healthy' | 'unhealthy' | 'dead' | 'unknown';
|
|
17
|
+
uptimeMs: number;
|
|
18
|
+
lastCrashAt?: Date;
|
|
19
|
+
lastCrashReason?: string;
|
|
20
|
+
avgUptimeMs: number;
|
|
21
|
+
memoryUsageBytes?: number;
|
|
22
|
+
cpuUsagePercent?: number;
|
|
23
|
+
}
|
|
24
|
+
export interface SystemMetrics {
|
|
25
|
+
totalAgents: number;
|
|
26
|
+
healthyAgents: number;
|
|
27
|
+
unhealthyAgents: number;
|
|
28
|
+
deadAgents: number;
|
|
29
|
+
totalCrashes: number;
|
|
30
|
+
totalRestarts: number;
|
|
31
|
+
uptimeSeconds: number;
|
|
32
|
+
memoryUsageMb: number;
|
|
33
|
+
}
|
|
34
|
+
export interface MetricPoint {
|
|
35
|
+
name: string;
|
|
36
|
+
value: number;
|
|
37
|
+
labels: Record<string, string>;
|
|
38
|
+
timestamp: number;
|
|
39
|
+
}
|
|
40
|
+
declare class MetricsCollector {
|
|
41
|
+
private agents;
|
|
42
|
+
private startTime;
|
|
43
|
+
private history;
|
|
44
|
+
private maxHistorySize;
|
|
45
|
+
/**
|
|
46
|
+
* Record an agent spawn
|
|
47
|
+
*/
|
|
48
|
+
recordSpawn(name: string): void;
|
|
49
|
+
/**
|
|
50
|
+
* Record an agent crash
|
|
51
|
+
*/
|
|
52
|
+
recordCrash(name: string, reason: string): void;
|
|
53
|
+
/**
|
|
54
|
+
* Record a restart attempt
|
|
55
|
+
*/
|
|
56
|
+
recordRestartAttempt(name: string): void;
|
|
57
|
+
/**
|
|
58
|
+
* Record a successful restart
|
|
59
|
+
*/
|
|
60
|
+
recordRestartSuccess(name: string): void;
|
|
61
|
+
/**
|
|
62
|
+
* Record a failed restart
|
|
63
|
+
*/
|
|
64
|
+
recordRestartFailure(name: string, reason: string): void;
|
|
65
|
+
/**
|
|
66
|
+
* Mark agent as dead (exceeded max restarts)
|
|
67
|
+
*/
|
|
68
|
+
recordDead(name: string): void;
|
|
69
|
+
/**
|
|
70
|
+
* Update resource usage
|
|
71
|
+
*/
|
|
72
|
+
updateResourceUsage(name: string, memoryBytes: number, cpuPercent: number): void;
|
|
73
|
+
/**
|
|
74
|
+
* Get metrics for a specific agent
|
|
75
|
+
*/
|
|
76
|
+
getAgentMetrics(name: string): AgentMetrics | undefined;
|
|
77
|
+
/**
|
|
78
|
+
* Get metrics for all agents
|
|
79
|
+
*/
|
|
80
|
+
getAllAgentMetrics(): AgentMetrics[];
|
|
81
|
+
/**
|
|
82
|
+
* Get system-wide metrics
|
|
83
|
+
*/
|
|
84
|
+
getSystemMetrics(): SystemMetrics;
|
|
85
|
+
/**
|
|
86
|
+
* Export metrics in Prometheus format
|
|
87
|
+
*/
|
|
88
|
+
toPrometheus(): string;
|
|
89
|
+
/**
|
|
90
|
+
* Export metrics as JSON
|
|
91
|
+
*/
|
|
92
|
+
toJSON(): {
|
|
93
|
+
system: SystemMetrics;
|
|
94
|
+
agents: AgentMetrics[];
|
|
95
|
+
};
|
|
96
|
+
/**
|
|
97
|
+
* Get recent metric history
|
|
98
|
+
*/
|
|
99
|
+
getHistory(name?: string, since?: Date): MetricPoint[];
|
|
100
|
+
/**
|
|
101
|
+
* Reset all metrics
|
|
102
|
+
*/
|
|
103
|
+
reset(): void;
|
|
104
|
+
/**
|
|
105
|
+
* Get or create agent metrics
|
|
106
|
+
*/
|
|
107
|
+
private getOrCreate;
|
|
108
|
+
/**
|
|
109
|
+
* Record a metric point
|
|
110
|
+
*/
|
|
111
|
+
private record;
|
|
112
|
+
}
|
|
113
|
+
export declare const metrics: MetricsCollector;
|
|
114
|
+
export {};
|
|
115
|
+
//# sourceMappingURL=metrics.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../src/resiliency/metrics.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,SAAS,GAAG,WAAW,GAAG,MAAM,GAAG,SAAS,CAAC;IAC5D,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,IAAI,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,aAAa,EAAE,MAAM,CAAC;IACtB,eAAe,EAAE,MAAM,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,cAAM,gBAAgB;IACpB,OAAO,CAAC,MAAM,CAAmC;IACjD,OAAO,CAAC,SAAS,CAAc;IAC/B,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,cAAc,CAAS;IAE/B;;OAEG;IACH,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAO/B;;OAEG;IACH,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAiB/C;;OAEG;IACH,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAOxC;;OAEG;IACH,oBAAoB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAOxC;;OAEG;IACH,oBAAoB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAMxD;;OAEG;IACH,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAM9B;;OAEG;IACH,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAQhF;;OAEG;IACH,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;IAIvD;;OAEG;IACH,kBAAkB,IAAI,YAAY,EAAE;IAIpC;;OAEG;IACH,gBAAgB,IAAI,aAAa;IAejC;;OAEG;IACH,YAAY,IAAI,MAAM;IAmEtB;;OAEG;IACH,MAAM,IAAI;QAAE,MAAM,EAAE,aAAa,CAAC;QAAC,MAAM,EAAE,YAAY,EAAE,CAAA;KAAE;IAO3D;;OAEG;IACH,UAAU,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,IAAI,GAAG,WAAW,EAAE;IAetD;;OAEG;IACH,KAAK,IAAI,IAAI;IAMb;;OAEG;IACH,OAAO,CAAC,WAAW;IAmBnB;;OAEG;IACH,OAAO,CAAC,MAAM;CAef;AAGD,eAAO,MAAM,OAAO,kBAAyB,CAAC"}
|
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Resiliency Metrics
|
|
3
|
+
*
|
|
4
|
+
* Collects and exposes metrics about agent health, crashes, and restarts.
|
|
5
|
+
* - Prometheus-compatible format
|
|
6
|
+
* - In-memory aggregation
|
|
7
|
+
* - Real-time stats
|
|
8
|
+
*/
|
|
9
|
+
class MetricsCollector {
|
|
10
|
+
agents = new Map();
|
|
11
|
+
startTime = Date.now();
|
|
12
|
+
history = [];
|
|
13
|
+
maxHistorySize = 10000;
|
|
14
|
+
/**
|
|
15
|
+
* Record an agent spawn
|
|
16
|
+
*/
|
|
17
|
+
recordSpawn(name) {
|
|
18
|
+
const metrics = this.getOrCreate(name);
|
|
19
|
+
metrics.spawns++;
|
|
20
|
+
metrics.currentStatus = 'healthy';
|
|
21
|
+
this.record('agent_spawns_total', 1, { agent: name });
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Record an agent crash
|
|
25
|
+
*/
|
|
26
|
+
recordCrash(name, reason) {
|
|
27
|
+
const metrics = this.getOrCreate(name);
|
|
28
|
+
metrics.crashes++;
|
|
29
|
+
metrics.lastCrashAt = new Date();
|
|
30
|
+
metrics.lastCrashReason = reason;
|
|
31
|
+
metrics.currentStatus = 'unhealthy';
|
|
32
|
+
// Update average uptime
|
|
33
|
+
if (metrics.spawns > 0) {
|
|
34
|
+
const currentUptime = Date.now() - (this.startTime + metrics.uptimeMs);
|
|
35
|
+
metrics.avgUptimeMs =
|
|
36
|
+
(metrics.avgUptimeMs * (metrics.spawns - 1) + currentUptime) / metrics.spawns;
|
|
37
|
+
}
|
|
38
|
+
this.record('agent_crashes_total', 1, { agent: name, reason });
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Record a restart attempt
|
|
42
|
+
*/
|
|
43
|
+
recordRestartAttempt(name) {
|
|
44
|
+
const metrics = this.getOrCreate(name);
|
|
45
|
+
metrics.restarts++;
|
|
46
|
+
metrics.currentStatus = 'unhealthy';
|
|
47
|
+
this.record('agent_restart_attempts_total', 1, { agent: name });
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Record a successful restart
|
|
51
|
+
*/
|
|
52
|
+
recordRestartSuccess(name) {
|
|
53
|
+
const metrics = this.getOrCreate(name);
|
|
54
|
+
metrics.successfulRestarts++;
|
|
55
|
+
metrics.currentStatus = 'healthy';
|
|
56
|
+
this.record('agent_restart_success_total', 1, { agent: name });
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Record a failed restart
|
|
60
|
+
*/
|
|
61
|
+
recordRestartFailure(name, reason) {
|
|
62
|
+
const metrics = this.getOrCreate(name);
|
|
63
|
+
metrics.failedRestarts++;
|
|
64
|
+
this.record('agent_restart_failures_total', 1, { agent: name, reason });
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Mark agent as dead (exceeded max restarts)
|
|
68
|
+
*/
|
|
69
|
+
recordDead(name) {
|
|
70
|
+
const metrics = this.getOrCreate(name);
|
|
71
|
+
metrics.currentStatus = 'dead';
|
|
72
|
+
this.record('agent_dead_total', 1, { agent: name });
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Update resource usage
|
|
76
|
+
*/
|
|
77
|
+
updateResourceUsage(name, memoryBytes, cpuPercent) {
|
|
78
|
+
const metrics = this.getOrCreate(name);
|
|
79
|
+
metrics.memoryUsageBytes = memoryBytes;
|
|
80
|
+
metrics.cpuUsagePercent = cpuPercent;
|
|
81
|
+
this.record('agent_memory_bytes', memoryBytes, { agent: name });
|
|
82
|
+
this.record('agent_cpu_percent', cpuPercent, { agent: name });
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Get metrics for a specific agent
|
|
86
|
+
*/
|
|
87
|
+
getAgentMetrics(name) {
|
|
88
|
+
return this.agents.get(name);
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get metrics for all agents
|
|
92
|
+
*/
|
|
93
|
+
getAllAgentMetrics() {
|
|
94
|
+
return Array.from(this.agents.values());
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* Get system-wide metrics
|
|
98
|
+
*/
|
|
99
|
+
getSystemMetrics() {
|
|
100
|
+
const allMetrics = this.getAllAgentMetrics();
|
|
101
|
+
return {
|
|
102
|
+
totalAgents: allMetrics.length,
|
|
103
|
+
healthyAgents: allMetrics.filter((m) => m.currentStatus === 'healthy').length,
|
|
104
|
+
unhealthyAgents: allMetrics.filter((m) => m.currentStatus === 'unhealthy').length,
|
|
105
|
+
deadAgents: allMetrics.filter((m) => m.currentStatus === 'dead').length,
|
|
106
|
+
totalCrashes: allMetrics.reduce((sum, m) => sum + m.crashes, 0),
|
|
107
|
+
totalRestarts: allMetrics.reduce((sum, m) => sum + m.restarts, 0),
|
|
108
|
+
uptimeSeconds: Math.floor((Date.now() - this.startTime) / 1000),
|
|
109
|
+
memoryUsageMb: Math.round(process.memoryUsage().heapUsed / 1024 / 1024),
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Export metrics in Prometheus format
|
|
114
|
+
*/
|
|
115
|
+
toPrometheus() {
|
|
116
|
+
const lines = [];
|
|
117
|
+
const system = this.getSystemMetrics();
|
|
118
|
+
// System metrics
|
|
119
|
+
lines.push('# HELP agent_relay_uptime_seconds Total uptime in seconds');
|
|
120
|
+
lines.push('# TYPE agent_relay_uptime_seconds gauge');
|
|
121
|
+
lines.push(`agent_relay_uptime_seconds ${system.uptimeSeconds}`);
|
|
122
|
+
lines.push('# HELP agent_relay_agents_total Total number of agents');
|
|
123
|
+
lines.push('# TYPE agent_relay_agents_total gauge');
|
|
124
|
+
lines.push(`agent_relay_agents_total ${system.totalAgents}`);
|
|
125
|
+
lines.push('# HELP agent_relay_agents_healthy Number of healthy agents');
|
|
126
|
+
lines.push('# TYPE agent_relay_agents_healthy gauge');
|
|
127
|
+
lines.push(`agent_relay_agents_healthy ${system.healthyAgents}`);
|
|
128
|
+
lines.push('# HELP agent_relay_agents_unhealthy Number of unhealthy agents');
|
|
129
|
+
lines.push('# TYPE agent_relay_agents_unhealthy gauge');
|
|
130
|
+
lines.push(`agent_relay_agents_unhealthy ${system.unhealthyAgents}`);
|
|
131
|
+
lines.push('# HELP agent_relay_agents_dead Number of dead agents');
|
|
132
|
+
lines.push('# TYPE agent_relay_agents_dead gauge');
|
|
133
|
+
lines.push(`agent_relay_agents_dead ${system.deadAgents}`);
|
|
134
|
+
lines.push('# HELP agent_relay_crashes_total Total number of crashes');
|
|
135
|
+
lines.push('# TYPE agent_relay_crashes_total counter');
|
|
136
|
+
lines.push(`agent_relay_crashes_total ${system.totalCrashes}`);
|
|
137
|
+
lines.push('# HELP agent_relay_restarts_total Total number of restart attempts');
|
|
138
|
+
lines.push('# TYPE agent_relay_restarts_total counter');
|
|
139
|
+
lines.push(`agent_relay_restarts_total ${system.totalRestarts}`);
|
|
140
|
+
lines.push('# HELP agent_relay_memory_bytes Memory usage in bytes');
|
|
141
|
+
lines.push('# TYPE agent_relay_memory_bytes gauge');
|
|
142
|
+
lines.push(`agent_relay_memory_bytes ${system.memoryUsageMb * 1024 * 1024}`);
|
|
143
|
+
// Per-agent metrics
|
|
144
|
+
lines.push('# HELP agent_crashes_total Crashes per agent');
|
|
145
|
+
lines.push('# TYPE agent_crashes_total counter');
|
|
146
|
+
for (const m of this.getAllAgentMetrics()) {
|
|
147
|
+
lines.push(`agent_crashes_total{agent="${m.name}"} ${m.crashes}`);
|
|
148
|
+
}
|
|
149
|
+
lines.push('# HELP agent_restarts_total Restart attempts per agent');
|
|
150
|
+
lines.push('# TYPE agent_restarts_total counter');
|
|
151
|
+
for (const m of this.getAllAgentMetrics()) {
|
|
152
|
+
lines.push(`agent_restarts_total{agent="${m.name}"} ${m.restarts}`);
|
|
153
|
+
}
|
|
154
|
+
lines.push('# HELP agent_status Current agent status (0=unknown, 1=healthy, 2=unhealthy, 3=dead)');
|
|
155
|
+
lines.push('# TYPE agent_status gauge');
|
|
156
|
+
for (const m of this.getAllAgentMetrics()) {
|
|
157
|
+
const statusValue = m.currentStatus === 'healthy'
|
|
158
|
+
? 1
|
|
159
|
+
: m.currentStatus === 'unhealthy'
|
|
160
|
+
? 2
|
|
161
|
+
: m.currentStatus === 'dead'
|
|
162
|
+
? 3
|
|
163
|
+
: 0;
|
|
164
|
+
lines.push(`agent_status{agent="${m.name}"} ${statusValue}`);
|
|
165
|
+
}
|
|
166
|
+
return lines.join('\n');
|
|
167
|
+
}
|
|
168
|
+
/**
|
|
169
|
+
* Export metrics as JSON
|
|
170
|
+
*/
|
|
171
|
+
toJSON() {
|
|
172
|
+
return {
|
|
173
|
+
system: this.getSystemMetrics(),
|
|
174
|
+
agents: this.getAllAgentMetrics(),
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Get recent metric history
|
|
179
|
+
*/
|
|
180
|
+
getHistory(name, since) {
|
|
181
|
+
let points = this.history;
|
|
182
|
+
if (since) {
|
|
183
|
+
const sinceTs = since.getTime();
|
|
184
|
+
points = points.filter((p) => p.timestamp >= sinceTs);
|
|
185
|
+
}
|
|
186
|
+
if (name) {
|
|
187
|
+
points = points.filter((p) => p.labels.agent === name);
|
|
188
|
+
}
|
|
189
|
+
return points;
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Reset all metrics
|
|
193
|
+
*/
|
|
194
|
+
reset() {
|
|
195
|
+
this.agents.clear();
|
|
196
|
+
this.history = [];
|
|
197
|
+
this.startTime = Date.now();
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Get or create agent metrics
|
|
201
|
+
*/
|
|
202
|
+
getOrCreate(name) {
|
|
203
|
+
let metrics = this.agents.get(name);
|
|
204
|
+
if (!metrics) {
|
|
205
|
+
metrics = {
|
|
206
|
+
name,
|
|
207
|
+
spawns: 0,
|
|
208
|
+
crashes: 0,
|
|
209
|
+
restarts: 0,
|
|
210
|
+
successfulRestarts: 0,
|
|
211
|
+
failedRestarts: 0,
|
|
212
|
+
currentStatus: 'unknown',
|
|
213
|
+
uptimeMs: 0,
|
|
214
|
+
avgUptimeMs: 0,
|
|
215
|
+
};
|
|
216
|
+
this.agents.set(name, metrics);
|
|
217
|
+
}
|
|
218
|
+
return metrics;
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Record a metric point
|
|
222
|
+
*/
|
|
223
|
+
record(name, value, labels) {
|
|
224
|
+
const point = {
|
|
225
|
+
name,
|
|
226
|
+
value,
|
|
227
|
+
labels,
|
|
228
|
+
timestamp: Date.now(),
|
|
229
|
+
};
|
|
230
|
+
this.history.push(point);
|
|
231
|
+
// Trim history if too large
|
|
232
|
+
if (this.history.length > this.maxHistorySize) {
|
|
233
|
+
this.history = this.history.slice(-this.maxHistorySize / 2);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
// Singleton instance
|
|
238
|
+
export const metrics = new MetricsCollector();
|
|
239
|
+
//# sourceMappingURL=metrics.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../src/resiliency/metrics.ts"],"names":[],"mappings":"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"}
|