4runr-os 2.10.39 → 2.10.41

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 (51) hide show
  1. package/apps/gateway/dist/apps/gateway/src/index.js +14 -4
  2. package/apps/gateway/dist/apps/gateway/src/index.js.map +1 -1
  3. package/apps/gateway/dist/apps/gateway/src/metrics/monitoring-detail.d.ts +18 -0
  4. package/apps/gateway/dist/apps/gateway/src/metrics/monitoring-detail.d.ts.map +1 -0
  5. package/apps/gateway/dist/apps/gateway/src/metrics/monitoring-detail.js +117 -0
  6. package/apps/gateway/dist/apps/gateway/src/metrics/monitoring-detail.js.map +1 -0
  7. package/apps/gateway/dist/apps/gateway/src/middleware/log-capture.d.ts +2 -0
  8. package/apps/gateway/dist/apps/gateway/src/middleware/log-capture.d.ts.map +1 -0
  9. package/apps/gateway/dist/apps/gateway/src/middleware/log-capture.js +54 -0
  10. package/apps/gateway/dist/apps/gateway/src/middleware/log-capture.js.map +1 -0
  11. package/apps/gateway/dist/apps/gateway/src/routes/monitoring.d.ts +15 -0
  12. package/apps/gateway/dist/apps/gateway/src/routes/monitoring.d.ts.map +1 -0
  13. package/apps/gateway/dist/apps/gateway/src/routes/monitoring.js +164 -0
  14. package/apps/gateway/dist/apps/gateway/src/routes/monitoring.js.map +1 -0
  15. package/apps/gateway/package-lock.json +204 -353
  16. package/apps/gateway/src/index.ts +27 -8
  17. package/apps/gateway/src/metrics/monitoring-detail.ts +162 -0
  18. package/apps/gateway/src/middleware/log-capture.ts +70 -0
  19. package/apps/gateway/src/routes/monitoring.ts +298 -0
  20. package/dist/gateway-client.d.ts +2 -0
  21. package/dist/gateway-client.d.ts.map +1 -1
  22. package/dist/gateway-client.js +22 -0
  23. package/dist/gateway-client.js.map +1 -1
  24. package/dist/tui-handlers.js +498 -0
  25. package/dist/tui-handlers.js.map +1 -1
  26. package/mk3-tui/src/app/render_scheduler.rs +111 -112
  27. package/mk3-tui/src/app.rs +1078 -295
  28. package/mk3-tui/src/debug_log.rs +131 -124
  29. package/mk3-tui/src/io/mod.rs +63 -66
  30. package/mk3-tui/src/io/protocol.rs +14 -15
  31. package/mk3-tui/src/io/stdio.rs +31 -32
  32. package/mk3-tui/src/io/ws.rs +25 -32
  33. package/mk3-tui/src/main.rs +774 -212
  34. package/mk3-tui/src/monitoring/mod.rs +428 -0
  35. package/mk3-tui/src/screens/mod.rs +53 -39
  36. package/mk3-tui/src/storage/cache.rs +221 -224
  37. package/mk3-tui/src/storage/mod.rs +5 -6
  38. package/mk3-tui/src/ui/agent_builder.rs +1148 -922
  39. package/mk3-tui/src/ui/agent_list.rs +344 -295
  40. package/mk3-tui/src/ui/boot.rs +145 -148
  41. package/mk3-tui/src/ui/connection_portal.rs +121 -98
  42. package/mk3-tui/src/ui/help.rs +340 -284
  43. package/mk3-tui/src/ui/layout.rs +966 -803
  44. package/mk3-tui/src/ui/mod.rs +1 -1
  45. package/mk3-tui/src/ui/portal_monitoring.rs +1027 -147
  46. package/mk3-tui/src/ui/run_manager.rs +784 -764
  47. package/mk3-tui/src/ui/safe_viewport.rs +236 -235
  48. package/mk3-tui/src/ui/settings.rs +414 -362
  49. package/mk3-tui/src/ui/setup_portal.rs +158 -101
  50. package/mk3-tui/src/websocket.rs +315 -308
  51. package/package.json +2 -2
@@ -0,0 +1,164 @@
1
+ import { getQueue } from '../queue/index.js';
2
+ import { performHealthChecks } from '../health/index.js';
3
+ import { createLogger } from '@4runr/shared';
4
+ import { getDependencyPoolsPayload, getMonitoringHttpPayload, getMonitoringRunsPayload, getMonitoringSsePayload, } from '../metrics/monitoring-detail.js';
5
+ const logger = createLogger('Gateway:Monitoring');
6
+ const LOG_BUFFER_SIZE = 1000;
7
+ const logBuffer = [];
8
+ export function addMonitoringLog(entry) {
9
+ logBuffer.push(entry);
10
+ if (logBuffer.length > LOG_BUFFER_SIZE) {
11
+ logBuffer.shift();
12
+ }
13
+ }
14
+ export function registerMonitoringRoutes(fastify, options) {
15
+ const { requireAuth, readRateLimit } = options || {};
16
+ const authHandler = requireAuth === false ? null : requireAuth;
17
+ const preHandler = authHandler && readRateLimit
18
+ ? [authHandler, readRateLimit]
19
+ : authHandler
20
+ ? [authHandler]
21
+ : [];
22
+ fastify.get('/api/monitoring/logs', {
23
+ ...(preHandler.length > 0 && { preHandler }),
24
+ }, async (request, reply) => {
25
+ const query = request.query;
26
+ const limit = Math.min(parseInt(query.limit || '100', 10), LOG_BUFFER_SIZE);
27
+ const levelFilter = query.level;
28
+ let logs = logBuffer.slice(-limit);
29
+ if (levelFilter) {
30
+ logs = logs.filter(log => log.level === levelFilter);
31
+ }
32
+ return {
33
+ logs,
34
+ count: logs.length,
35
+ bufferSize: logBuffer.length,
36
+ timestamp: new Date().toISOString(),
37
+ };
38
+ });
39
+ fastify.get('/api/monitoring/dependencies/detail', {
40
+ ...(preHandler.length > 0 && { preHandler }),
41
+ }, async (request, reply) => {
42
+ const health = await performHealthChecks();
43
+ const details = {};
44
+ const pools = await getDependencyPoolsPayload();
45
+ if (health.checks.database) {
46
+ const dbLatency = health.checks.database.responseTime;
47
+ details.database = {
48
+ status: health.checks.database.status,
49
+ ...(dbLatency !== undefined && { latency: dbLatency }),
50
+ poolAvailable: true,
51
+ pool: {
52
+ active: pools.database.active,
53
+ idle: pools.database.idle,
54
+ },
55
+ telemetry: pools.telemetry,
56
+ };
57
+ }
58
+ if (health.checks.redis) {
59
+ const redisLatency = health.checks.redis.responseTime;
60
+ details.redis = {
61
+ status: health.checks.redis.status,
62
+ ...(redisLatency !== undefined && { latency: redisLatency }),
63
+ connectionCountAvailable: true,
64
+ connections: {
65
+ active: pools.redis.active,
66
+ },
67
+ telemetry: pools.telemetry,
68
+ };
69
+ }
70
+ if (health.checks.queue) {
71
+ details.queue = {
72
+ status: health.checks.queue.status,
73
+ };
74
+ try {
75
+ const queue = getQueue();
76
+ if (queue) {
77
+ const counts = await queue.getJobCounts('waiting', 'active', 'completed', 'failed', 'delayed');
78
+ details.queue.jobs = {
79
+ waiting: counts['waiting'] ?? 0,
80
+ active: counts['active'] ?? 0,
81
+ completed: counts['completed'] ?? 0,
82
+ failed: counts['failed'] ?? 0,
83
+ delayed: counts['delayed'] ?? 0,
84
+ };
85
+ }
86
+ }
87
+ catch (err) {
88
+ logger.error('Failed to fetch queue job counts', {
89
+ error: err instanceof Error ? err.message : String(err),
90
+ });
91
+ }
92
+ }
93
+ return {
94
+ details,
95
+ telemetry: pools.telemetry,
96
+ timestamp: new Date().toISOString(),
97
+ };
98
+ });
99
+ fastify.get('/api/monitoring/metrics/http', {
100
+ ...(preHandler.length > 0 && { preHandler }),
101
+ }, async (_request, _reply) => {
102
+ return await getMonitoringHttpPayload();
103
+ });
104
+ fastify.get('/api/monitoring/metrics/runs', {
105
+ ...(preHandler.length > 0 && { preHandler }),
106
+ }, async (_request, _reply) => {
107
+ return await getMonitoringRunsPayload();
108
+ });
109
+ fastify.get('/api/monitoring/metrics/sse', {
110
+ ...(preHandler.length > 0 && { preHandler }),
111
+ }, async (_request, _reply) => {
112
+ return await getMonitoringSsePayload();
113
+ });
114
+ fastify.get('/api/monitoring/metrics/queue', {
115
+ ...(preHandler.length > 0 && { preHandler }),
116
+ }, async (request, reply) => {
117
+ try {
118
+ const queue = getQueue();
119
+ if (!queue) {
120
+ return {
121
+ available: false,
122
+ message: 'Queue not initialized (Redis required)',
123
+ timestamp: new Date().toISOString(),
124
+ };
125
+ }
126
+ const counts = await queue.getJobCounts('waiting', 'active', 'completed', 'failed', 'delayed', 'paused');
127
+ return {
128
+ available: true,
129
+ jobs: {
130
+ waiting: counts['waiting'] ?? 0,
131
+ active: counts['active'] ?? 0,
132
+ completed: counts['completed'] ?? 0,
133
+ failed: counts['failed'] ?? 0,
134
+ delayed: counts['delayed'] ?? 0,
135
+ paused: counts['paused'] ?? 0,
136
+ },
137
+ queueName: queue.name || 'run-execution',
138
+ timestamp: new Date().toISOString(),
139
+ };
140
+ }
141
+ catch (error) {
142
+ logger.error('Failed to get queue metrics', {
143
+ error: error instanceof Error ? error.message : String(error),
144
+ });
145
+ return {
146
+ available: false,
147
+ error: error instanceof Error ? error.message : String(error),
148
+ timestamp: new Date().toISOString(),
149
+ };
150
+ }
151
+ });
152
+ logger.info('Monitoring routes registered (Phase 0)', {
153
+ authRequired: preHandler.length > 0,
154
+ endpoints: [
155
+ '/api/monitoring/logs',
156
+ '/api/monitoring/dependencies/detail',
157
+ '/api/monitoring/metrics/http',
158
+ '/api/monitoring/metrics/runs',
159
+ '/api/monitoring/metrics/sse',
160
+ '/api/monitoring/metrics/queue',
161
+ ],
162
+ });
163
+ }
164
+ //# sourceMappingURL=monitoring.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"monitoring.js","sourceRoot":"","sources":["../../../../../src/routes/monitoring.ts"],"names":[],"mappings":"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"}