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.
Files changed (283) hide show
  1. package/dist/bridge/shadow-cli.d.ts +17 -0
  2. package/dist/bridge/shadow-cli.d.ts.map +1 -0
  3. package/dist/bridge/shadow-cli.js +75 -0
  4. package/dist/bridge/shadow-cli.js.map +1 -0
  5. package/dist/bridge/shadow-config.d.ts +87 -0
  6. package/dist/bridge/shadow-config.d.ts.map +1 -0
  7. package/dist/bridge/shadow-config.js +134 -0
  8. package/dist/bridge/shadow-config.js.map +1 -0
  9. package/dist/bridge/spawner.d.ts +15 -1
  10. package/dist/bridge/spawner.d.ts.map +1 -1
  11. package/dist/bridge/spawner.js +164 -4
  12. package/dist/bridge/spawner.js.map +1 -1
  13. package/dist/bridge/types.d.ts +55 -0
  14. package/dist/bridge/types.d.ts.map +1 -1
  15. package/dist/cli/index.js +796 -11
  16. package/dist/cli/index.js.map +1 -1
  17. package/dist/cloud/api/auth.d.ts +19 -0
  18. package/dist/cloud/api/auth.d.ts.map +1 -0
  19. package/dist/cloud/api/auth.js +216 -0
  20. package/dist/cloud/api/auth.js.map +1 -0
  21. package/dist/cloud/api/billing.d.ts +17 -0
  22. package/dist/cloud/api/billing.d.ts.map +1 -0
  23. package/dist/cloud/api/billing.js +353 -0
  24. package/dist/cloud/api/billing.js.map +1 -0
  25. package/dist/cloud/api/coordinators.d.ts +8 -0
  26. package/dist/cloud/api/coordinators.d.ts.map +1 -0
  27. package/dist/cloud/api/coordinators.js +347 -0
  28. package/dist/cloud/api/coordinators.js.map +1 -0
  29. package/dist/cloud/api/daemons.d.ts +12 -0
  30. package/dist/cloud/api/daemons.d.ts.map +1 -0
  31. package/dist/cloud/api/daemons.js +320 -0
  32. package/dist/cloud/api/daemons.js.map +1 -0
  33. package/dist/cloud/api/middleware/planLimits.d.ts +36 -0
  34. package/dist/cloud/api/middleware/planLimits.d.ts.map +1 -0
  35. package/dist/cloud/api/middleware/planLimits.js +164 -0
  36. package/dist/cloud/api/middleware/planLimits.js.map +1 -0
  37. package/dist/cloud/api/onboarding.d.ts +8 -0
  38. package/dist/cloud/api/onboarding.d.ts.map +1 -0
  39. package/dist/cloud/api/onboarding.js +407 -0
  40. package/dist/cloud/api/onboarding.js.map +1 -0
  41. package/dist/cloud/api/providers.d.ts +7 -0
  42. package/dist/cloud/api/providers.d.ts.map +1 -0
  43. package/dist/cloud/api/providers.js +435 -0
  44. package/dist/cloud/api/providers.js.map +1 -0
  45. package/dist/cloud/api/repos.d.ts +7 -0
  46. package/dist/cloud/api/repos.d.ts.map +1 -0
  47. package/dist/cloud/api/repos.js +314 -0
  48. package/dist/cloud/api/repos.js.map +1 -0
  49. package/dist/cloud/api/teams.d.ts +7 -0
  50. package/dist/cloud/api/teams.d.ts.map +1 -0
  51. package/dist/cloud/api/teams.js +279 -0
  52. package/dist/cloud/api/teams.js.map +1 -0
  53. package/dist/cloud/api/usage.d.ts +7 -0
  54. package/dist/cloud/api/usage.d.ts.map +1 -0
  55. package/dist/cloud/api/usage.js +98 -0
  56. package/dist/cloud/api/usage.js.map +1 -0
  57. package/dist/cloud/api/workspaces.d.ts +7 -0
  58. package/dist/cloud/api/workspaces.d.ts.map +1 -0
  59. package/dist/cloud/api/workspaces.js +510 -0
  60. package/dist/cloud/api/workspaces.js.map +1 -0
  61. package/dist/cloud/billing/index.d.ts +9 -0
  62. package/dist/cloud/billing/index.d.ts.map +1 -0
  63. package/dist/cloud/billing/index.js +9 -0
  64. package/dist/cloud/billing/index.js.map +1 -0
  65. package/dist/cloud/billing/plans.d.ts +39 -0
  66. package/dist/cloud/billing/plans.d.ts.map +1 -0
  67. package/dist/cloud/billing/plans.js +232 -0
  68. package/dist/cloud/billing/plans.js.map +1 -0
  69. package/dist/cloud/billing/service.d.ts +80 -0
  70. package/dist/cloud/billing/service.d.ts.map +1 -0
  71. package/dist/cloud/billing/service.js +388 -0
  72. package/dist/cloud/billing/service.js.map +1 -0
  73. package/dist/cloud/billing/types.d.ts +135 -0
  74. package/dist/cloud/billing/types.d.ts.map +1 -0
  75. package/dist/cloud/billing/types.js +7 -0
  76. package/dist/cloud/billing/types.js.map +1 -0
  77. package/dist/cloud/config.d.ts +59 -0
  78. package/dist/cloud/config.d.ts.map +1 -0
  79. package/dist/cloud/config.js +83 -0
  80. package/dist/cloud/config.js.map +1 -0
  81. package/dist/cloud/db/drizzle.d.ts +132 -0
  82. package/dist/cloud/db/drizzle.d.ts.map +1 -0
  83. package/dist/cloud/db/drizzle.js +613 -0
  84. package/dist/cloud/db/drizzle.js.map +1 -0
  85. package/dist/cloud/db/index.d.ts +30 -0
  86. package/dist/cloud/db/index.d.ts.map +1 -0
  87. package/dist/cloud/db/index.js +44 -0
  88. package/dist/cloud/db/index.js.map +1 -0
  89. package/dist/cloud/db/schema.d.ts +1792 -0
  90. package/dist/cloud/db/schema.d.ts.map +1 -0
  91. package/dist/cloud/db/schema.js +234 -0
  92. package/dist/cloud/db/schema.js.map +1 -0
  93. package/dist/cloud/index.d.ts +11 -0
  94. package/dist/cloud/index.d.ts.map +1 -0
  95. package/dist/cloud/index.js +37 -0
  96. package/dist/cloud/index.js.map +1 -0
  97. package/dist/cloud/provisioner/index.d.ts +51 -0
  98. package/dist/cloud/provisioner/index.d.ts.map +1 -0
  99. package/dist/cloud/provisioner/index.js +676 -0
  100. package/dist/cloud/provisioner/index.js.map +1 -0
  101. package/dist/cloud/server.d.ts +16 -0
  102. package/dist/cloud/server.d.ts.map +1 -0
  103. package/dist/cloud/server.js +190 -0
  104. package/dist/cloud/server.js.map +1 -0
  105. package/dist/cloud/services/coordinator.d.ts +62 -0
  106. package/dist/cloud/services/coordinator.d.ts.map +1 -0
  107. package/dist/cloud/services/coordinator.js +389 -0
  108. package/dist/cloud/services/coordinator.js.map +1 -0
  109. package/dist/cloud/services/planLimits.d.ts +110 -0
  110. package/dist/cloud/services/planLimits.d.ts.map +1 -0
  111. package/dist/cloud/services/planLimits.js +254 -0
  112. package/dist/cloud/services/planLimits.js.map +1 -0
  113. package/dist/cloud/vault/index.d.ts +76 -0
  114. package/dist/cloud/vault/index.d.ts.map +1 -0
  115. package/dist/cloud/vault/index.js +219 -0
  116. package/dist/cloud/vault/index.js.map +1 -0
  117. package/dist/daemon/agent-manager.d.ts +87 -0
  118. package/dist/daemon/agent-manager.d.ts.map +1 -0
  119. package/dist/daemon/agent-manager.js +412 -0
  120. package/dist/daemon/agent-manager.js.map +1 -0
  121. package/dist/daemon/agent-registry.d.ts +2 -0
  122. package/dist/daemon/agent-registry.d.ts.map +1 -1
  123. package/dist/daemon/agent-registry.js +3 -0
  124. package/dist/daemon/agent-registry.js.map +1 -1
  125. package/dist/daemon/api.d.ts +69 -0
  126. package/dist/daemon/api.d.ts.map +1 -0
  127. package/dist/daemon/api.js +425 -0
  128. package/dist/daemon/api.js.map +1 -0
  129. package/dist/daemon/cloud-sync.d.ts +101 -0
  130. package/dist/daemon/cloud-sync.d.ts.map +1 -0
  131. package/dist/daemon/cloud-sync.js +261 -0
  132. package/dist/daemon/cloud-sync.js.map +1 -0
  133. package/dist/daemon/index.d.ts +4 -0
  134. package/dist/daemon/index.d.ts.map +1 -1
  135. package/dist/daemon/index.js +6 -0
  136. package/dist/daemon/index.js.map +1 -1
  137. package/dist/daemon/orchestrator.d.ts +155 -0
  138. package/dist/daemon/orchestrator.d.ts.map +1 -0
  139. package/dist/daemon/orchestrator.js +736 -0
  140. package/dist/daemon/orchestrator.js.map +1 -0
  141. package/dist/daemon/router.d.ts +24 -0
  142. package/dist/daemon/router.d.ts.map +1 -1
  143. package/dist/daemon/router.js +71 -1
  144. package/dist/daemon/router.js.map +1 -1
  145. package/dist/daemon/server.d.ts +37 -0
  146. package/dist/daemon/server.d.ts.map +1 -1
  147. package/dist/daemon/server.js +191 -16
  148. package/dist/daemon/server.js.map +1 -1
  149. package/dist/daemon/types.d.ts +127 -0
  150. package/dist/daemon/types.d.ts.map +1 -0
  151. package/dist/daemon/types.js +6 -0
  152. package/dist/daemon/types.js.map +1 -0
  153. package/dist/daemon/workspace-manager.d.ts +75 -0
  154. package/dist/daemon/workspace-manager.d.ts.map +1 -0
  155. package/dist/daemon/workspace-manager.js +289 -0
  156. package/dist/daemon/workspace-manager.js.map +1 -0
  157. package/dist/dashboard/out/404.html +1 -1
  158. package/dist/dashboard/out/_next/static/chunks/693-7b3301d8f6bc5014.js +1 -0
  159. package/dist/dashboard/out/_next/static/chunks/713-f78477eb185f1f4d.js +1 -0
  160. package/dist/dashboard/out/_next/static/chunks/766-e53e1cfe39b0b5b5.js +1 -0
  161. package/dist/dashboard/out/_next/static/chunks/900-037c64bfd797fb2a.js +1 -0
  162. package/dist/dashboard/out/_next/static/chunks/app/app/page-e3d9e1f4466b9bae.js +1 -0
  163. package/dist/dashboard/out/_next/static/chunks/app/history/page-b6edd4dde8d08194.js +1 -0
  164. package/dist/dashboard/out/_next/static/chunks/app/layout-2433bb48965f4333.js +1 -0
  165. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-e68825a81db67ba1.js +1 -0
  166. package/dist/dashboard/out/_next/static/chunks/app/page-cc108bf68c8a657f.js +1 -0
  167. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-d80e03a5297f95b6.js +1 -0
  168. package/dist/dashboard/out/_next/static/chunks/main-app-5d692157a8eb1fd9.js +1 -0
  169. package/dist/dashboard/out/_next/static/chunks/{main-e0a1f53fe0617a63.js → main-c2f423b9c9f4591b.js} +1 -1
  170. package/dist/dashboard/out/_next/static/chunks/{webpack-c81f7fd28659d64f.js → webpack-a5acc2831d094776.js} +1 -1
  171. package/dist/dashboard/out/_next/static/css/79b80143647a07d7.css +1 -0
  172. package/dist/dashboard/out/_next/static/css/8cf277370ad48cfe.css +1 -0
  173. package/dist/dashboard/out/alt-logos/agent-relay-logo-128.png +0 -0
  174. package/dist/dashboard/out/alt-logos/agent-relay-logo-256.png +0 -0
  175. package/dist/dashboard/out/alt-logos/agent-relay-logo-32.png +0 -0
  176. package/dist/dashboard/out/alt-logos/agent-relay-logo-512.png +0 -0
  177. package/dist/dashboard/out/alt-logos/agent-relay-logo-64.png +0 -0
  178. package/dist/dashboard/out/alt-logos/agent-relay-logo.svg +45 -0
  179. package/dist/dashboard/out/alt-logos/logo.svg +38 -0
  180. package/dist/dashboard/out/alt-logos/monogram-logo-128.png +0 -0
  181. package/dist/dashboard/out/alt-logos/monogram-logo-256.png +0 -0
  182. package/dist/dashboard/out/alt-logos/monogram-logo-32.png +0 -0
  183. package/dist/dashboard/out/alt-logos/monogram-logo-512.png +0 -0
  184. package/dist/dashboard/out/alt-logos/monogram-logo-64.png +0 -0
  185. package/dist/dashboard/out/alt-logos/monogram-logo.svg +38 -0
  186. package/dist/dashboard/out/app.html +14 -0
  187. package/dist/dashboard/out/app.txt +7 -0
  188. package/dist/dashboard/out/history.html +1 -0
  189. package/dist/dashboard/out/history.txt +7 -0
  190. package/dist/dashboard/out/index.html +1 -1
  191. package/dist/dashboard/out/index.txt +2 -2
  192. package/dist/dashboard/out/metrics.html +1 -515
  193. package/dist/dashboard/out/metrics.txt +2 -2
  194. package/dist/dashboard/out/pricing.html +13 -0
  195. package/dist/dashboard/out/pricing.txt +7 -0
  196. package/dist/dashboard-server/metrics.d.ts.map +1 -1
  197. package/dist/dashboard-server/metrics.js +3 -2
  198. package/dist/dashboard-server/metrics.js.map +1 -1
  199. package/dist/dashboard-server/server.d.ts.map +1 -1
  200. package/dist/dashboard-server/server.js +1279 -56
  201. package/dist/dashboard-server/server.js.map +1 -1
  202. package/dist/protocol/types.d.ts +10 -1
  203. package/dist/protocol/types.d.ts.map +1 -1
  204. package/dist/resiliency/context-persistence.d.ts +140 -0
  205. package/dist/resiliency/context-persistence.d.ts.map +1 -0
  206. package/dist/resiliency/context-persistence.js +397 -0
  207. package/dist/resiliency/context-persistence.js.map +1 -0
  208. package/dist/resiliency/health-monitor.d.ts +97 -0
  209. package/dist/resiliency/health-monitor.d.ts.map +1 -0
  210. package/dist/resiliency/health-monitor.js +291 -0
  211. package/dist/resiliency/health-monitor.js.map +1 -0
  212. package/dist/resiliency/index.d.ts +63 -0
  213. package/dist/resiliency/index.d.ts.map +1 -0
  214. package/dist/resiliency/index.js +63 -0
  215. package/dist/resiliency/index.js.map +1 -0
  216. package/dist/resiliency/logger.d.ts +114 -0
  217. package/dist/resiliency/logger.d.ts.map +1 -0
  218. package/dist/resiliency/logger.js +250 -0
  219. package/dist/resiliency/logger.js.map +1 -0
  220. package/dist/resiliency/metrics.d.ts +115 -0
  221. package/dist/resiliency/metrics.d.ts.map +1 -0
  222. package/dist/resiliency/metrics.js +239 -0
  223. package/dist/resiliency/metrics.js.map +1 -0
  224. package/dist/resiliency/provider-context.d.ts +100 -0
  225. package/dist/resiliency/provider-context.d.ts.map +1 -0
  226. package/dist/resiliency/provider-context.js +360 -0
  227. package/dist/resiliency/provider-context.js.map +1 -0
  228. package/dist/resiliency/supervisor.d.ts +109 -0
  229. package/dist/resiliency/supervisor.d.ts.map +1 -0
  230. package/dist/resiliency/supervisor.js +337 -0
  231. package/dist/resiliency/supervisor.js.map +1 -0
  232. package/dist/storage/adapter.d.ts +2 -0
  233. package/dist/storage/adapter.d.ts.map +1 -1
  234. package/dist/storage/adapter.js +12 -2
  235. package/dist/storage/adapter.js.map +1 -1
  236. package/dist/storage/sqlite-adapter.d.ts.map +1 -1
  237. package/dist/storage/sqlite-adapter.js +18 -14
  238. package/dist/storage/sqlite-adapter.js.map +1 -1
  239. package/dist/utils/index.d.ts +1 -0
  240. package/dist/utils/index.d.ts.map +1 -1
  241. package/dist/utils/index.js +1 -0
  242. package/dist/utils/index.js.map +1 -1
  243. package/dist/utils/logger.d.ts +40 -0
  244. package/dist/utils/logger.d.ts.map +1 -0
  245. package/dist/utils/logger.js +84 -0
  246. package/dist/utils/logger.js.map +1 -0
  247. package/dist/wrapper/client.d.ts +16 -1
  248. package/dist/wrapper/client.d.ts.map +1 -1
  249. package/dist/wrapper/client.js +32 -1
  250. package/dist/wrapper/client.js.map +1 -1
  251. package/dist/wrapper/parser.d.ts +3 -0
  252. package/dist/wrapper/parser.d.ts.map +1 -1
  253. package/dist/wrapper/parser.js +121 -18
  254. package/dist/wrapper/parser.js.map +1 -1
  255. package/dist/wrapper/pty-wrapper.d.ts +28 -1
  256. package/dist/wrapper/pty-wrapper.d.ts.map +1 -1
  257. package/dist/wrapper/pty-wrapper.js +166 -30
  258. package/dist/wrapper/pty-wrapper.js.map +1 -1
  259. package/dist/wrapper/tmux-wrapper.d.ts +5 -0
  260. package/dist/wrapper/tmux-wrapper.d.ts.map +1 -1
  261. package/dist/wrapper/tmux-wrapper.js +58 -18
  262. package/dist/wrapper/tmux-wrapper.js.map +1 -1
  263. package/docs/CLOUD-ARCHITECTURE.md +652 -0
  264. package/docs/CLOUD-ONBOARDING-DESIGN.md +1983 -0
  265. package/docs/TESTING_PRESENCE_FEATURES.md +327 -0
  266. package/docs/agent-relay-snippet.md +107 -4
  267. package/docs/guides/CLOUD.md +236 -0
  268. package/docs/guides/LOCAL.md +535 -0
  269. package/docs/guides/SELF-HOSTED.md +494 -0
  270. package/docs/proposals/shadow-as-subagent.md +765 -0
  271. package/docs/proposals/slack-bot-integration.md +1457 -0
  272. package/package.json +33 -4
  273. package/dist/dashboard/out/_next/static/chunks/app/layout-c9d8c5d95e48c6bf.js +0 -1
  274. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-8aa9936bc6c771ab.js +0 -1
  275. package/dist/dashboard/out/_next/static/chunks/app/page-49055e5d2b5e34ec.js +0 -1
  276. package/dist/dashboard/out/_next/static/chunks/main-app-bae2e535de00de50.js +0 -1
  277. package/dist/dashboard/out/_next/static/css/50ed6996e3df7bdd.css +0 -1
  278. /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_buildManifest.js +0 -0
  279. /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_ssgManifest.js +0 -0
  280. /package/dist/dashboard/out/_next/static/chunks/{117-3bef7b19f3e60751.js → 117-b2cd8d6485aacf2b.js} +0 -0
  281. /package/dist/dashboard/out/_next/static/chunks/{648-6cf686106c891ad3.js → 648-8f3f26864ce515e5.js} +0 -0
  282. /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-8ff6572bc7c9bc61.js → page-0b990dbb71d72a98.js} +0 -0
  283. /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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"}