@platformatic/watt-admin 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +68 -0
  3. package/cli.js +155 -0
  4. package/lib/start.js +19 -0
  5. package/package.json +59 -0
  6. package/watt.json +13 -0
  7. package/web/backend/dist/plugins/metrics.js +13 -0
  8. package/web/backend/dist/plugins/metrics.js.map +1 -0
  9. package/web/backend/dist/routes/root.js +84 -0
  10. package/web/backend/dist/routes/root.js.map +1 -0
  11. package/web/backend/dist/utils/calc.js +200 -0
  12. package/web/backend/dist/utils/calc.js.map +1 -0
  13. package/web/backend/dist/utils/log.js +29 -0
  14. package/web/backend/dist/utils/log.js.map +1 -0
  15. package/web/backend/platformatic.json +17 -0
  16. package/web/composer/platformatic.json +22 -0
  17. package/web/frontend/dist/.platformatic-build.json +1 -0
  18. package/web/frontend/dist/assets/index-BfyK1jrk.js +267 -0
  19. package/web/frontend/dist/assets/index-BfyK1jrk.js.map +1 -0
  20. package/web/frontend/dist/assets/index-D-ld0Cou.css +1 -0
  21. package/web/frontend/dist/browser-source-map-support.js +434 -0
  22. package/web/frontend/dist/favicon.svg +10 -0
  23. package/web/frontend/dist/fonts/Inter/Inter-VariableFont_wght.ttf +0 -0
  24. package/web/frontend/dist/fonts/Inter/OFL.txt +93 -0
  25. package/web/frontend/dist/fonts/Roboto_Mono/LICENSE.txt +202 -0
  26. package/web/frontend/dist/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf +0 -0
  27. package/web/frontend/dist/index.html +18 -0
  28. package/web/frontend/index.html +17 -0
  29. package/web/frontend/postcss.config.cjs +11 -0
  30. package/web/frontend/public/browser-source-map-support.js +434 -0
  31. package/web/frontend/public/favicon.svg +10 -0
  32. package/web/frontend/public/fonts/Inter/Inter-VariableFont_wght.ttf +0 -0
  33. package/web/frontend/public/fonts/Inter/OFL.txt +93 -0
  34. package/web/frontend/public/fonts/Roboto_Mono/LICENSE.txt +202 -0
  35. package/web/frontend/public/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf +0 -0
  36. package/web/frontend/watt.json +7 -0
@@ -0,0 +1,200 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.calcBytesToMB = exports.calculateMetrics = void 0;
4
+ const control_1 = require("@platformatic/control");
5
+ const MAX_STORED_METRICS = 20;
6
+ const calculateMetrics = async ({ mappedMetrics, log }) => {
7
+ try {
8
+ const api = new control_1.RuntimeApiClient();
9
+ const runtimes = await api.getRuntimes();
10
+ for (const { pid } of runtimes) {
11
+ const date = new Date();
12
+ const aggregatedMemData = {
13
+ date,
14
+ rss: 0,
15
+ totalHeap: 0,
16
+ usedHeap: 0,
17
+ newSpace: 0,
18
+ oldSpace: 0
19
+ };
20
+ const aggregatedCpuData = {
21
+ date,
22
+ cpu: 0,
23
+ eventLoop: 0
24
+ };
25
+ const aggregatedLatencyData = {
26
+ date,
27
+ p90: 0,
28
+ p95: 0,
29
+ p99: 0
30
+ };
31
+ const aggregatedReqData = {
32
+ date,
33
+ count: 0,
34
+ rps: 0,
35
+ };
36
+ let aggregatedRss = 0;
37
+ const runtimeMetrics = await api.getRuntimeMetrics(pid, { format: 'json' });
38
+ if (!mappedMetrics[pid]) {
39
+ mappedMetrics[pid] = { services: {}, aggregated: { dataCpu: [], dataLatency: [], dataMem: [], dataReq: [] } };
40
+ }
41
+ const { services, entrypoint } = await api.getRuntimeServices(pid);
42
+ for (const { id: serviceId } of services) {
43
+ const isEntrypointService = entrypoint === serviceId;
44
+ if (!mappedMetrics[pid].services[serviceId]) {
45
+ mappedMetrics[pid].services[serviceId] = { dataCpu: [], dataLatency: [], dataMem: [], dataReq: [] };
46
+ }
47
+ const serviceMemData = {
48
+ date,
49
+ rss: 0,
50
+ totalHeap: 0,
51
+ usedHeap: 0,
52
+ newSpace: 0,
53
+ oldSpace: 0
54
+ };
55
+ const serviceCpuData = {
56
+ date,
57
+ cpu: 0,
58
+ eventLoop: 0
59
+ };
60
+ const serviceLatencyData = {
61
+ date,
62
+ p90: 0,
63
+ p95: 0,
64
+ p99: 0
65
+ };
66
+ const serviceReqData = {
67
+ date,
68
+ count: 0,
69
+ rps: 0
70
+ };
71
+ for (const metric of runtimeMetrics) {
72
+ if (metric.values.length > 0) {
73
+ const [{ value, labels }] = metric.values;
74
+ if (metric.name === 'process_resident_memory_bytes') {
75
+ aggregatedRss = (0, exports.calcBytesToMB)(value);
76
+ }
77
+ if (serviceId === labels.serviceId) {
78
+ if (metric.name === 'nodejs_heap_size_total_bytes') {
79
+ serviceMemData.totalHeap = (0, exports.calcBytesToMB)(value);
80
+ aggregatedMemData.totalHeap += serviceMemData.totalHeap;
81
+ }
82
+ if (metric.name === 'nodejs_heap_size_used_bytes') {
83
+ serviceMemData.usedHeap = (0, exports.calcBytesToMB)(value);
84
+ aggregatedMemData.usedHeap += serviceMemData.usedHeap;
85
+ }
86
+ if (metric.name === 'nodejs_heap_space_size_used_bytes') {
87
+ metric.values.forEach(val => {
88
+ if (val.labels?.space === 'new') {
89
+ serviceMemData.newSpace = (0, exports.calcBytesToMB)(val.value);
90
+ aggregatedMemData.newSpace += serviceMemData.newSpace;
91
+ }
92
+ else if (val.labels?.space === 'old') {
93
+ serviceMemData.oldSpace = (0, exports.calcBytesToMB)(val.value);
94
+ aggregatedMemData.oldSpace += serviceMemData.oldSpace;
95
+ }
96
+ });
97
+ }
98
+ if (metric.name === 'thread_cpu_percent_usage') {
99
+ serviceCpuData.cpu = value;
100
+ aggregatedCpuData.cpu += serviceCpuData.cpu;
101
+ }
102
+ if (metric.name === 'nodejs_eventloop_utilization') {
103
+ serviceCpuData.eventLoop = value * 100;
104
+ aggregatedCpuData.eventLoop += serviceCpuData.eventLoop;
105
+ }
106
+ if (metric.name === 'http_request_all_summary_seconds') {
107
+ for (const metricValue of metric.values) {
108
+ const data = metricValue.value * 1000;
109
+ if (data > 0) {
110
+ if (metricValue.labels?.quantile === 0.9) {
111
+ serviceLatencyData.p90 = data;
112
+ if (isEntrypointService) {
113
+ aggregatedLatencyData.p90 = data;
114
+ }
115
+ }
116
+ if (metricValue.labels?.quantile === 0.95) {
117
+ serviceLatencyData.p95 = data;
118
+ if (isEntrypointService) {
119
+ aggregatedLatencyData.p95 = data;
120
+ }
121
+ }
122
+ if (metricValue.labels?.quantile === 0.99) {
123
+ serviceLatencyData.p99 = data;
124
+ if (isEntrypointService) {
125
+ aggregatedLatencyData.p99 = data;
126
+ }
127
+ }
128
+ }
129
+ }
130
+ }
131
+ if (metric.name === 'http_request_duration_seconds') {
132
+ const count = metric.values.reduce((acc, { metricName, value, labels }) => {
133
+ const lastRouteChar = labels.route?.slice(-1);
134
+ if (metricName === 'http_request_duration_seconds_count' && lastRouteChar !== '/') {
135
+ acc += value;
136
+ }
137
+ return acc;
138
+ }, 0);
139
+ if (!count) {
140
+ log.debug(metric.values, 'Empty HTTP request count');
141
+ }
142
+ else {
143
+ const req = mappedMetrics[pid].services[serviceId].dataReq;
144
+ const rps = count - (req[req.length - 1]?.count || 0);
145
+ serviceReqData.rps = rps;
146
+ serviceReqData.count = count;
147
+ if (isEntrypointService) {
148
+ aggregatedReqData.count = count;
149
+ aggregatedReqData.rps = rps;
150
+ }
151
+ }
152
+ }
153
+ }
154
+ }
155
+ }
156
+ serviceMemData.rss = aggregatedRss;
157
+ aggregatedMemData.rss = aggregatedRss;
158
+ if (mappedMetrics[pid].services[serviceId].dataMem.length >= MAX_STORED_METRICS) {
159
+ mappedMetrics[pid].services[serviceId].dataMem.shift();
160
+ }
161
+ if (mappedMetrics[pid].services[serviceId].dataCpu.length >= MAX_STORED_METRICS) {
162
+ mappedMetrics[pid].services[serviceId].dataCpu.shift();
163
+ }
164
+ if (mappedMetrics[pid].services[serviceId].dataLatency.length >= MAX_STORED_METRICS) {
165
+ mappedMetrics[pid].services[serviceId].dataLatency.shift();
166
+ }
167
+ if (mappedMetrics[pid].services[serviceId].dataReq.length >= MAX_STORED_METRICS) {
168
+ mappedMetrics[pid].services[serviceId].dataReq.shift();
169
+ }
170
+ mappedMetrics[pid].services[serviceId].dataMem.push(serviceMemData);
171
+ mappedMetrics[pid].services[serviceId].dataCpu.push(serviceCpuData);
172
+ mappedMetrics[pid].services[serviceId].dataLatency.push(serviceLatencyData);
173
+ mappedMetrics[pid].services[serviceId].dataReq.push(serviceReqData);
174
+ }
175
+ if (mappedMetrics[pid].aggregated.dataMem.length >= MAX_STORED_METRICS) {
176
+ mappedMetrics[pid].aggregated.dataMem.shift();
177
+ }
178
+ if (mappedMetrics[pid].aggregated.dataCpu.length >= MAX_STORED_METRICS) {
179
+ mappedMetrics[pid].aggregated.dataCpu.shift();
180
+ }
181
+ if (mappedMetrics[pid].aggregated.dataLatency.length >= MAX_STORED_METRICS) {
182
+ mappedMetrics[pid].aggregated.dataLatency.shift();
183
+ }
184
+ if (mappedMetrics[pid].aggregated.dataReq.length >= MAX_STORED_METRICS) {
185
+ mappedMetrics[pid].aggregated.dataReq.shift();
186
+ }
187
+ mappedMetrics[pid].aggregated.dataMem.push(aggregatedMemData);
188
+ mappedMetrics[pid].aggregated.dataCpu.push(aggregatedCpuData);
189
+ mappedMetrics[pid].aggregated.dataLatency.push(aggregatedLatencyData);
190
+ mappedMetrics[pid].aggregated.dataReq.push(aggregatedReqData);
191
+ }
192
+ }
193
+ catch (error) {
194
+ log.warn(error, 'Unable to get runtime metrics. Retry will start soon...');
195
+ }
196
+ };
197
+ exports.calculateMetrics = calculateMetrics;
198
+ const calcBytesToMB = (bytes) => Number((bytes / (1024 * 1024)).toFixed(2));
199
+ exports.calcBytesToMB = calcBytesToMB;
200
+ //# sourceMappingURL=calc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"calc.js","sourceRoot":"","sources":["../../utils/calc.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getLogsFromReadable = void 0;
7
+ const split2_1 = __importDefault(require("split2"));
8
+ const promises_1 = require("node:stream/promises");
9
+ const MAX_LOGS = 1000;
10
+ const getLogsFromReadable = async (readable, log) => {
11
+ const result = [];
12
+ await (0, promises_1.pipeline)(readable, (0, split2_1.default)(), async function* (source) {
13
+ for await (const line of source) {
14
+ try {
15
+ const parsedObject = JSON.parse(line);
16
+ if (result.length >= MAX_LOGS) {
17
+ result.shift();
18
+ }
19
+ result.push(parsedObject);
20
+ }
21
+ catch (err) {
22
+ log?.warn({ line }, 'Invalid JSON line found:');
23
+ }
24
+ }
25
+ });
26
+ return result;
27
+ };
28
+ exports.getLogsFromReadable = getLogsFromReadable;
29
+ //# sourceMappingURL=log.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log.js","sourceRoot":"","sources":["../../utils/log.ts"],"names":[],"mappings":";;;;;;AAAA,oDAA2B;AAE3B,mDAA+C;AAW/C,MAAM,QAAQ,GAAG,IAAI,CAAA;AAEd,MAAM,mBAAmB,GAAG,KAAK,EAAE,QAAkB,EAAE,GAAuB,EAAE,EAAE;IACvF,MAAM,MAAM,GAAU,EAAE,CAAA;IAExB,MAAM,IAAA,mBAAQ,EACZ,QAAQ,EACR,IAAA,gBAAM,GAAE,EACR,KAAK,SAAU,CAAC,EAAE,MAAM;QACtB,IAAI,KAAK,EAAE,MAAM,IAAI,IAAI,MAAM,EAAE,CAAC;YAChC,IAAI,CAAC;gBACH,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;gBACrC,IAAI,MAAM,CAAC,MAAM,IAAI,QAAQ,EAAE,CAAC;oBAC9B,MAAM,CAAC,KAAK,EAAE,CAAA;gBAChB,CAAC;gBACD,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;YAC3B,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,GAAG,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,0BAA0B,CAAC,CAAA;YACjD,CAAC;QACH,CAAC;IACH,CAAC,CACF,CAAA;IAED,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAtBY,QAAA,mBAAmB,uBAsB/B"}
@@ -0,0 +1,17 @@
1
+ {
2
+ "$schema": "https://schemas.platformatic.dev/@platformatic/service/2.55.0.json",
3
+ "service": {
4
+ "openapi": true
5
+ },
6
+ "watch": true,
7
+ "plugins": {
8
+ "paths": [
9
+ {
10
+ "path": "./plugins",
11
+ "encapsulate": false
12
+ },
13
+ "./routes"
14
+ ],
15
+ "typescript": "{PLT_BACKEND_TYPESCRIPT}"
16
+ }
17
+ }
@@ -0,0 +1,22 @@
1
+ {
2
+ "$schema": "https://schemas.platformatic.dev/@platformatic/composer/2.55.0.json",
3
+ "composer": {
4
+ "services": [
5
+ {
6
+ "id": "backend",
7
+ "openapi": {
8
+ "url": "/documentation/json",
9
+ "prefix": "/api"
10
+ }
11
+ },
12
+ {
13
+ "id": "frontend",
14
+ "proxy": {
15
+ "prefix": "/"
16
+ }
17
+ }
18
+ ],
19
+ "refreshTimeout": 1000
20
+ },
21
+ "watch": true
22
+ }
@@ -0,0 +1 @@
1
+ {"basePath":"/"}