clawsql 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.
- package/.env.example +97 -0
- package/README.md +372 -0
- package/dist/__tests__/config/settings.test.d.ts +5 -0
- package/dist/__tests__/config/settings.test.d.ts.map +1 -0
- package/dist/__tests__/config/settings.test.js +154 -0
- package/dist/__tests__/config/settings.test.js.map +1 -0
- package/dist/__tests__/core/discovery/topology.test.d.ts +5 -0
- package/dist/__tests__/core/discovery/topology.test.d.ts.map +1 -0
- package/dist/__tests__/core/discovery/topology.test.js +191 -0
- package/dist/__tests__/core/discovery/topology.test.js.map +1 -0
- package/dist/__tests__/core/failover/executor.test.d.ts +5 -0
- package/dist/__tests__/core/failover/executor.test.d.ts.map +1 -0
- package/dist/__tests__/core/failover/executor.test.js +256 -0
- package/dist/__tests__/core/failover/executor.test.js.map +1 -0
- package/dist/__tests__/core/monitoring/collector.test.d.ts +5 -0
- package/dist/__tests__/core/monitoring/collector.test.d.ts.map +1 -0
- package/dist/__tests__/core/monitoring/collector.test.js +131 -0
- package/dist/__tests__/core/monitoring/collector.test.js.map +1 -0
- package/dist/__tests__/core/monitoring/exporters.test.d.ts +5 -0
- package/dist/__tests__/core/monitoring/exporters.test.d.ts.map +1 -0
- package/dist/__tests__/core/monitoring/exporters.test.js +90 -0
- package/dist/__tests__/core/monitoring/exporters.test.js.map +1 -0
- package/dist/__tests__/core/routing/proxysql-manager.test.d.ts +5 -0
- package/dist/__tests__/core/routing/proxysql-manager.test.d.ts.map +1 -0
- package/dist/__tests__/core/routing/proxysql-manager.test.js +155 -0
- package/dist/__tests__/core/routing/proxysql-manager.test.js.map +1 -0
- package/dist/__tests__/types/index.test.d.ts +5 -0
- package/dist/__tests__/types/index.test.d.ts.map +1 -0
- package/dist/__tests__/types/index.test.js +290 -0
- package/dist/__tests__/types/index.test.js.map +1 -0
- package/dist/__tests__/utils/exceptions.test.d.ts +5 -0
- package/dist/__tests__/utils/exceptions.test.d.ts.map +1 -0
- package/dist/__tests__/utils/exceptions.test.js +142 -0
- package/dist/__tests__/utils/exceptions.test.js.map +1 -0
- package/dist/api/routes/clusters.d.ts +7 -0
- package/dist/api/routes/clusters.d.ts.map +1 -0
- package/dist/api/routes/clusters.js +123 -0
- package/dist/api/routes/clusters.js.map +1 -0
- package/dist/api/routes/config.d.ts +7 -0
- package/dist/api/routes/config.d.ts.map +1 -0
- package/dist/api/routes/config.js +65 -0
- package/dist/api/routes/config.js.map +1 -0
- package/dist/api/routes/failover.d.ts +7 -0
- package/dist/api/routes/failover.d.ts.map +1 -0
- package/dist/api/routes/failover.js +100 -0
- package/dist/api/routes/failover.js.map +1 -0
- package/dist/api/routes/instances.d.ts +11 -0
- package/dist/api/routes/instances.d.ts.map +1 -0
- package/dist/api/routes/instances.js +315 -0
- package/dist/api/routes/instances.js.map +1 -0
- package/dist/api/routes/monitoring.d.ts +7 -0
- package/dist/api/routes/monitoring.d.ts.map +1 -0
- package/dist/api/routes/monitoring.js +72 -0
- package/dist/api/routes/monitoring.js.map +1 -0
- package/dist/api/routes/webhooks.d.ts +12 -0
- package/dist/api/routes/webhooks.d.ts.map +1 -0
- package/dist/api/routes/webhooks.js +232 -0
- package/dist/api/routes/webhooks.js.map +1 -0
- package/dist/api/schemas/index.d.ts +965 -0
- package/dist/api/schemas/index.d.ts.map +1 -0
- package/dist/api/schemas/index.js +171 -0
- package/dist/api/schemas/index.js.map +1 -0
- package/dist/app.d.ts +13 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.js +197 -0
- package/dist/app.js.map +1 -0
- package/dist/bin/clawsql.d.ts +12 -0
- package/dist/bin/clawsql.d.ts.map +1 -0
- package/dist/bin/clawsql.js +43 -0
- package/dist/bin/clawsql.js.map +1 -0
- package/dist/cli/agent/handler.d.ts +73 -0
- package/dist/cli/agent/handler.d.ts.map +1 -0
- package/dist/cli/agent/handler.js +258 -0
- package/dist/cli/agent/handler.js.map +1 -0
- package/dist/cli/agent/index.d.ts +14 -0
- package/dist/cli/agent/index.d.ts.map +1 -0
- package/dist/cli/agent/index.js +30 -0
- package/dist/cli/agent/index.js.map +1 -0
- package/dist/cli/agent/openclaw-integration.d.ts +81 -0
- package/dist/cli/agent/openclaw-integration.d.ts.map +1 -0
- package/dist/cli/agent/openclaw-integration.js +341 -0
- package/dist/cli/agent/openclaw-integration.js.map +1 -0
- package/dist/cli/agent/providers/anthropic.d.ts +27 -0
- package/dist/cli/agent/providers/anthropic.d.ts.map +1 -0
- package/dist/cli/agent/providers/anthropic.js +106 -0
- package/dist/cli/agent/providers/anthropic.js.map +1 -0
- package/dist/cli/agent/providers/base.d.ts +91 -0
- package/dist/cli/agent/providers/base.d.ts.map +1 -0
- package/dist/cli/agent/providers/base.js +24 -0
- package/dist/cli/agent/providers/base.js.map +1 -0
- package/dist/cli/agent/providers/openai.d.ts +27 -0
- package/dist/cli/agent/providers/openai.d.ts.map +1 -0
- package/dist/cli/agent/providers/openai.js +98 -0
- package/dist/cli/agent/providers/openai.js.map +1 -0
- package/dist/cli/agent/tools/index.d.ts +32 -0
- package/dist/cli/agent/tools/index.d.ts.map +1 -0
- package/dist/cli/agent/tools/index.js +263 -0
- package/dist/cli/agent/tools/index.js.map +1 -0
- package/dist/cli/commands/cleanup.d.ts +12 -0
- package/dist/cli/commands/cleanup.d.ts.map +1 -0
- package/dist/cli/commands/cleanup.js +205 -0
- package/dist/cli/commands/cleanup.js.map +1 -0
- package/dist/cli/commands/clusters.d.ts +12 -0
- package/dist/cli/commands/clusters.d.ts.map +1 -0
- package/dist/cli/commands/clusters.js +468 -0
- package/dist/cli/commands/clusters.js.map +1 -0
- package/dist/cli/commands/config.d.ts +12 -0
- package/dist/cli/commands/config.d.ts.map +1 -0
- package/dist/cli/commands/config.js +406 -0
- package/dist/cli/commands/config.js.map +1 -0
- package/dist/cli/commands/cron.d.ts +12 -0
- package/dist/cli/commands/cron.d.ts.map +1 -0
- package/dist/cli/commands/cron.js +215 -0
- package/dist/cli/commands/cron.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +13 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +687 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/failover.d.ts +16 -0
- package/dist/cli/commands/failover.d.ts.map +1 -0
- package/dist/cli/commands/failover.js +333 -0
- package/dist/cli/commands/failover.js.map +1 -0
- package/dist/cli/commands/health.d.ts +12 -0
- package/dist/cli/commands/health.d.ts.map +1 -0
- package/dist/cli/commands/health.js +125 -0
- package/dist/cli/commands/health.js.map +1 -0
- package/dist/cli/commands/help.d.ts +12 -0
- package/dist/cli/commands/help.d.ts.map +1 -0
- package/dist/cli/commands/help.js +52 -0
- package/dist/cli/commands/help.js.map +1 -0
- package/dist/cli/commands/instances.d.ts +12 -0
- package/dist/cli/commands/instances.d.ts.map +1 -0
- package/dist/cli/commands/instances.js +801 -0
- package/dist/cli/commands/instances.js.map +1 -0
- package/dist/cli/commands/notify.d.ts +12 -0
- package/dist/cli/commands/notify.d.ts.map +1 -0
- package/dist/cli/commands/notify.js +43 -0
- package/dist/cli/commands/notify.js.map +1 -0
- package/dist/cli/commands/sql.d.ts +12 -0
- package/dist/cli/commands/sql.d.ts.map +1 -0
- package/dist/cli/commands/sql.js +90 -0
- package/dist/cli/commands/sql.js.map +1 -0
- package/dist/cli/commands/start.d.ts +12 -0
- package/dist/cli/commands/start.d.ts.map +1 -0
- package/dist/cli/commands/start.js +174 -0
- package/dist/cli/commands/start.js.map +1 -0
- package/dist/cli/commands/status.d.ts +12 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +218 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/stop.d.ts +12 -0
- package/dist/cli/commands/stop.d.ts.map +1 -0
- package/dist/cli/commands/stop.js +128 -0
- package/dist/cli/commands/stop.js.map +1 -0
- package/dist/cli/commands/topology.d.ts +12 -0
- package/dist/cli/commands/topology.d.ts.map +1 -0
- package/dist/cli/commands/topology.js +106 -0
- package/dist/cli/commands/topology.js.map +1 -0
- package/dist/cli/completer.d.ts +47 -0
- package/dist/cli/completer.d.ts.map +1 -0
- package/dist/cli/completer.js +332 -0
- package/dist/cli/completer.js.map +1 -0
- package/dist/cli/formatter.d.ts +165 -0
- package/dist/cli/formatter.d.ts.map +1 -0
- package/dist/cli/formatter.js +408 -0
- package/dist/cli/formatter.js.map +1 -0
- package/dist/cli/index.d.ts +21 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +79 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/raw-input.d.ts +97 -0
- package/dist/cli/raw-input.d.ts.map +1 -0
- package/dist/cli/raw-input.js +493 -0
- package/dist/cli/raw-input.js.map +1 -0
- package/dist/cli/registry.d.ts +103 -0
- package/dist/cli/registry.d.ts.map +1 -0
- package/dist/cli/registry.js +205 -0
- package/dist/cli/registry.js.map +1 -0
- package/dist/cli/repl.d.ts +83 -0
- package/dist/cli/repl.d.ts.map +1 -0
- package/dist/cli/repl.js +447 -0
- package/dist/cli/repl.js.map +1 -0
- package/dist/cli/ui/components.d.ts +144 -0
- package/dist/cli/ui/components.d.ts.map +1 -0
- package/dist/cli/ui/components.js +331 -0
- package/dist/cli/ui/components.js.map +1 -0
- package/dist/cli/ui/index.d.ts +7 -0
- package/dist/cli/ui/index.d.ts.map +1 -0
- package/dist/cli/ui/index.js +23 -0
- package/dist/cli/ui/index.js.map +1 -0
- package/dist/cli/utils/docker-files.d.ts +39 -0
- package/dist/cli/utils/docker-files.d.ts.map +1 -0
- package/dist/cli/utils/docker-files.js +223 -0
- package/dist/cli/utils/docker-files.js.map +1 -0
- package/dist/cli/utils/docker-prereq.d.ts +48 -0
- package/dist/cli/utils/docker-prereq.d.ts.map +1 -0
- package/dist/cli/utils/docker-prereq.js +203 -0
- package/dist/cli/utils/docker-prereq.js.map +1 -0
- package/dist/config/settings.d.ts +594 -0
- package/dist/config/settings.d.ts.map +1 -0
- package/dist/config/settings.js +250 -0
- package/dist/config/settings.js.map +1 -0
- package/dist/core/discovery/cluster-view.d.ts +50 -0
- package/dist/core/discovery/cluster-view.d.ts.map +1 -0
- package/dist/core/discovery/cluster-view.js +235 -0
- package/dist/core/discovery/cluster-view.js.map +1 -0
- package/dist/core/discovery/scanner.d.ts +70 -0
- package/dist/core/discovery/scanner.d.ts.map +1 -0
- package/dist/core/discovery/scanner.js +197 -0
- package/dist/core/discovery/scanner.js.map +1 -0
- package/dist/core/discovery/topology.d.ts +118 -0
- package/dist/core/discovery/topology.d.ts.map +1 -0
- package/dist/core/discovery/topology.js +550 -0
- package/dist/core/discovery/topology.js.map +1 -0
- package/dist/core/failover/candidate-selector.d.ts +46 -0
- package/dist/core/failover/candidate-selector.d.ts.map +1 -0
- package/dist/core/failover/candidate-selector.js +70 -0
- package/dist/core/failover/candidate-selector.js.map +1 -0
- package/dist/core/failover/executor.d.ts +104 -0
- package/dist/core/failover/executor.d.ts.map +1 -0
- package/dist/core/failover/executor.js +248 -0
- package/dist/core/failover/executor.js.map +1 -0
- package/dist/core/failover/operation-builder.d.ts +71 -0
- package/dist/core/failover/operation-builder.d.ts.map +1 -0
- package/dist/core/failover/operation-builder.js +157 -0
- package/dist/core/failover/operation-builder.js.map +1 -0
- package/dist/core/failover/operation-runner.d.ts +75 -0
- package/dist/core/failover/operation-runner.d.ts.map +1 -0
- package/dist/core/failover/operation-runner.js +191 -0
- package/dist/core/failover/operation-runner.js.map +1 -0
- package/dist/core/failover/promoter.d.ts +33 -0
- package/dist/core/failover/promoter.d.ts.map +1 -0
- package/dist/core/failover/promoter.js +97 -0
- package/dist/core/failover/promoter.js.map +1 -0
- package/dist/core/failover/recovery-manager.d.ts +47 -0
- package/dist/core/failover/recovery-manager.d.ts.map +1 -0
- package/dist/core/failover/recovery-manager.js +145 -0
- package/dist/core/failover/recovery-manager.js.map +1 -0
- package/dist/core/failover/types.d.ts +54 -0
- package/dist/core/failover/types.d.ts.map +1 -0
- package/dist/core/failover/types.js +8 -0
- package/dist/core/failover/types.js.map +1 -0
- package/dist/core/monitoring/collector.d.ts +25 -0
- package/dist/core/monitoring/collector.d.ts.map +1 -0
- package/dist/core/monitoring/collector.js +115 -0
- package/dist/core/monitoring/collector.js.map +1 -0
- package/dist/core/monitoring/exporters.d.ts +49 -0
- package/dist/core/monitoring/exporters.d.ts.map +1 -0
- package/dist/core/monitoring/exporters.js +126 -0
- package/dist/core/monitoring/exporters.js.map +1 -0
- package/dist/core/routing/proxysql-manager.d.ts +213 -0
- package/dist/core/routing/proxysql-manager.d.ts.map +1 -0
- package/dist/core/routing/proxysql-manager.js +632 -0
- package/dist/core/routing/proxysql-manager.js.map +1 -0
- package/dist/core/sync/replica-recovery.d.ts +40 -0
- package/dist/core/sync/replica-recovery.d.ts.map +1 -0
- package/dist/core/sync/replica-recovery.js +134 -0
- package/dist/core/sync/replica-recovery.js.map +1 -0
- package/dist/core/sync/sync-coordinator.d.ts +83 -0
- package/dist/core/sync/sync-coordinator.d.ts.map +1 -0
- package/dist/core/sync/sync-coordinator.js +254 -0
- package/dist/core/sync/sync-coordinator.js.map +1 -0
- package/dist/core/sync/topology-watcher.d.ts +76 -0
- package/dist/core/sync/topology-watcher.d.ts.map +1 -0
- package/dist/core/sync/topology-watcher.js +222 -0
- package/dist/core/sync/topology-watcher.js.map +1 -0
- package/dist/core/sync/types.d.ts +85 -0
- package/dist/core/sync/types.d.ts.map +1 -0
- package/dist/core/sync/types.js +8 -0
- package/dist/core/sync/types.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +9 -0
- package/dist/index.js.map +1 -0
- package/dist/types/index.d.ts +212 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +153 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/database.d.ts +62 -0
- package/dist/utils/database.d.ts.map +1 -0
- package/dist/utils/database.js +257 -0
- package/dist/utils/database.js.map +1 -0
- package/dist/utils/exceptions.d.ts +69 -0
- package/dist/utils/exceptions.d.ts.map +1 -0
- package/dist/utils/exceptions.js +121 -0
- package/dist/utils/exceptions.js.map +1 -0
- package/dist/utils/logger.d.ts +20 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +90 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/mysql-client.d.ts +43 -0
- package/dist/utils/mysql-client.d.ts.map +1 -0
- package/dist/utils/mysql-client.js +125 -0
- package/dist/utils/mysql-client.js.map +1 -0
- package/docker/Dockerfile +61 -0
- package/docker/Dockerfile.node +41 -0
- package/docker/grafana/dashboards/clawsql.json +212 -0
- package/docker/grafana/provisioning/dashboards/dashboards.yml +13 -0
- package/docker/grafana/provisioning/datasources/datasources.yml +12 -0
- package/docker/init/primary.sql +26 -0
- package/docker/init/replica.sql +16 -0
- package/docker/orchestrator/orchestrator.conf.json +98 -0
- package/docker/prometheus/prometheus.yml +45 -0
- package/docker/proxysql/entrypoint.sh +8 -0
- package/docker/proxysql/init.sql.demo +30 -0
- package/docker/proxysql/proxysql.cnf +38 -0
- package/docker-compose.demo.yml +115 -0
- package/docker-compose.yml +217 -0
- package/init/primary.sql +19 -0
- package/init/replica.sql +13 -0
- package/package.json +84 -0
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ClawSQL - Instances API Routes
|
|
4
|
+
*
|
|
5
|
+
* Instance management with persistence in shared metadata database.
|
|
6
|
+
* - Topology data (role, state, replication) comes from Orchestrator
|
|
7
|
+
* - User metadata (labels, extra) stored in instance_metadata table
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
const uuid_1 = require("uuid");
|
|
11
|
+
const index_js_1 = require("../../types/index.js");
|
|
12
|
+
const exceptions_js_1 = require("../../utils/exceptions.js");
|
|
13
|
+
const collector_js_1 = require("../../core/monitoring/collector.js");
|
|
14
|
+
const database_js_1 = require("../../utils/database.js");
|
|
15
|
+
const topology_js_1 = require("../../core/discovery/topology.js");
|
|
16
|
+
/**
|
|
17
|
+
* Get instance metadata from database
|
|
18
|
+
*/
|
|
19
|
+
async function getInstanceMetadata(instanceId) {
|
|
20
|
+
const db = (0, database_js_1.getDatabase)();
|
|
21
|
+
return db.get('SELECT * FROM instance_metadata WHERE instance_id = ?', [instanceId]);
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Save instance metadata to database
|
|
25
|
+
*/
|
|
26
|
+
async function saveInstanceMetadata(instanceId, labels, extra) {
|
|
27
|
+
const db = (0, database_js_1.getDatabase)();
|
|
28
|
+
await db.execute(`INSERT INTO instance_metadata (instance_id, labels, extra)
|
|
29
|
+
VALUES (?, ?, ?)
|
|
30
|
+
ON DUPLICATE KEY UPDATE labels = VALUES(labels), extra = VALUES(extra)`, [instanceId, JSON.stringify(labels), JSON.stringify(extra)]);
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Delete instance metadata from database
|
|
34
|
+
*/
|
|
35
|
+
async function deleteInstanceMetadata(instanceId) {
|
|
36
|
+
const db = (0, database_js_1.getDatabase)();
|
|
37
|
+
await db.execute('DELETE FROM instance_metadata WHERE instance_id = ?', [instanceId]);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* List all instance metadata from database
|
|
41
|
+
*/
|
|
42
|
+
async function listInstanceMetadata() {
|
|
43
|
+
const db = (0, database_js_1.getDatabase)();
|
|
44
|
+
return db.query('SELECT * FROM instance_metadata');
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Parse JSON field from MySQL (can be object or string)
|
|
48
|
+
*/
|
|
49
|
+
function parseJsonField(value) {
|
|
50
|
+
if (!value)
|
|
51
|
+
return {};
|
|
52
|
+
if (typeof value === 'object')
|
|
53
|
+
return value;
|
|
54
|
+
if (typeof value === 'string') {
|
|
55
|
+
try {
|
|
56
|
+
return JSON.parse(value);
|
|
57
|
+
}
|
|
58
|
+
catch {
|
|
59
|
+
return {};
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return {};
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Parse labels field (string values only)
|
|
66
|
+
*/
|
|
67
|
+
function parseLabels(value) {
|
|
68
|
+
const parsed = parseJsonField(value);
|
|
69
|
+
const result = {};
|
|
70
|
+
for (const [key, val] of Object.entries(parsed)) {
|
|
71
|
+
if (typeof val === 'string') {
|
|
72
|
+
result[key] = val;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return result;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Convert to API response
|
|
79
|
+
*/
|
|
80
|
+
function toResponse(metadata, orchestratorData) {
|
|
81
|
+
const labels = parseLabels(metadata.labels);
|
|
82
|
+
const extra = parseJsonField(metadata.extra);
|
|
83
|
+
// Parse instance_id to get host and port
|
|
84
|
+
const [host, portStr] = metadata.instance_id.split(':');
|
|
85
|
+
const port = parseInt(portStr, 10) || 3306;
|
|
86
|
+
return {
|
|
87
|
+
instance_id: metadata.instance_id,
|
|
88
|
+
host,
|
|
89
|
+
port,
|
|
90
|
+
server_id: orchestratorData?.server_id ?? null,
|
|
91
|
+
role: orchestratorData ? orchestratorData.master_host ? 'replica' : 'primary' : 'unknown',
|
|
92
|
+
state: orchestratorData ? 'online' : 'offline',
|
|
93
|
+
version: orchestratorData?.version ?? null,
|
|
94
|
+
cluster_id: orchestratorData?.cluster_name ?? null,
|
|
95
|
+
replication_lag: orchestratorData?.replication_lag_seconds ?? null,
|
|
96
|
+
labels,
|
|
97
|
+
extra,
|
|
98
|
+
last_seen: orchestratorData?.last_seen ?? metadata.updated_at,
|
|
99
|
+
created_at: metadata.created_at,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
const instancesRoutes = async (fastify) => {
|
|
103
|
+
// List instances
|
|
104
|
+
fastify.get('/', async (request) => {
|
|
105
|
+
const metadataList = await listInstanceMetadata();
|
|
106
|
+
const orchestrator = (0, topology_js_1.getOrchestratorClient)();
|
|
107
|
+
// Get topology from Orchestrator for enrichment
|
|
108
|
+
let instances = await Promise.all(metadataList.map(async (m) => {
|
|
109
|
+
const [host, portStr] = m.instance_id.split(':');
|
|
110
|
+
const port = parseInt(portStr, 10) || 3306;
|
|
111
|
+
try {
|
|
112
|
+
const topo = await orchestrator.getInstance(host, port);
|
|
113
|
+
return toResponse(m, topo);
|
|
114
|
+
}
|
|
115
|
+
catch {
|
|
116
|
+
return toResponse(m);
|
|
117
|
+
}
|
|
118
|
+
}));
|
|
119
|
+
// Apply filters
|
|
120
|
+
if (request.query.cluster_id) {
|
|
121
|
+
instances = instances.filter(i => i.cluster_id === request.query.cluster_id);
|
|
122
|
+
}
|
|
123
|
+
if (request.query.state) {
|
|
124
|
+
instances = instances.filter(i => i.state === request.query.state);
|
|
125
|
+
}
|
|
126
|
+
if (request.query.role) {
|
|
127
|
+
instances = instances.filter(i => i.role === request.query.role);
|
|
128
|
+
}
|
|
129
|
+
// Paginate
|
|
130
|
+
const page = request.query.page || 1;
|
|
131
|
+
const pageSize = request.query.page_size || 20;
|
|
132
|
+
const total = instances.length;
|
|
133
|
+
const start = (page - 1) * pageSize;
|
|
134
|
+
const end = start + pageSize;
|
|
135
|
+
return {
|
|
136
|
+
items: instances.slice(start, end),
|
|
137
|
+
total,
|
|
138
|
+
page,
|
|
139
|
+
page_size: pageSize,
|
|
140
|
+
};
|
|
141
|
+
});
|
|
142
|
+
// Get instance
|
|
143
|
+
fastify.get('/:instance_id', async (request) => {
|
|
144
|
+
const metadata = await getInstanceMetadata(request.params.instance_id);
|
|
145
|
+
if (!metadata) {
|
|
146
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
147
|
+
}
|
|
148
|
+
const [host, portStr] = request.params.instance_id.split(':');
|
|
149
|
+
const port = parseInt(portStr, 10) || 3306;
|
|
150
|
+
const orchestrator = (0, topology_js_1.getOrchestratorClient)();
|
|
151
|
+
try {
|
|
152
|
+
const topo = await orchestrator.getInstance(host, port);
|
|
153
|
+
return toResponse(metadata, topo);
|
|
154
|
+
}
|
|
155
|
+
catch {
|
|
156
|
+
return toResponse(metadata);
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
// Register instance
|
|
160
|
+
fastify.post('/', async (request, reply) => {
|
|
161
|
+
const port = request.body.port || 3306;
|
|
162
|
+
const instanceId = (0, index_js_1.createInstanceId)(request.body.host, port);
|
|
163
|
+
const existing = await getInstanceMetadata(instanceId);
|
|
164
|
+
if (existing) {
|
|
165
|
+
throw new exceptions_js_1.AlreadyExistsError('Instance', instanceId);
|
|
166
|
+
}
|
|
167
|
+
await saveInstanceMetadata(instanceId, request.body.labels || {}, {
|
|
168
|
+
registeredCluster: request.body.cluster_id,
|
|
169
|
+
});
|
|
170
|
+
// Also discover in Orchestrator
|
|
171
|
+
const orchestrator = (0, topology_js_1.getOrchestratorClient)();
|
|
172
|
+
try {
|
|
173
|
+
await orchestrator.discoverInstance(request.body.host, port);
|
|
174
|
+
}
|
|
175
|
+
catch (error) {
|
|
176
|
+
fastify.log.warn({ error, instanceId }, 'Failed to discover instance in Orchestrator');
|
|
177
|
+
}
|
|
178
|
+
const metadata = await getInstanceMetadata(instanceId);
|
|
179
|
+
reply.code(201);
|
|
180
|
+
return toResponse(metadata);
|
|
181
|
+
});
|
|
182
|
+
// Deregister instance
|
|
183
|
+
fastify.delete('/:instance_id', async (request, reply) => {
|
|
184
|
+
const existing = await getInstanceMetadata(request.params.instance_id);
|
|
185
|
+
if (!existing) {
|
|
186
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
187
|
+
}
|
|
188
|
+
await deleteInstanceMetadata(request.params.instance_id);
|
|
189
|
+
reply.code(204);
|
|
190
|
+
});
|
|
191
|
+
// Discover instances
|
|
192
|
+
fastify.post('/discover', async (request, reply) => {
|
|
193
|
+
const taskId = (0, uuid_1.v4)();
|
|
194
|
+
// Simplified discovery - in production this would scan networks
|
|
195
|
+
const discovered = [];
|
|
196
|
+
for (const segment of request.body.network_segments) {
|
|
197
|
+
fastify.log.info({ segment }, 'Scanning network segment');
|
|
198
|
+
}
|
|
199
|
+
// Register discovered instances
|
|
200
|
+
for (const instance of discovered) {
|
|
201
|
+
const instanceId = (0, index_js_1.createInstanceId)(instance.host, instance.port);
|
|
202
|
+
const existing = await getInstanceMetadata(instanceId);
|
|
203
|
+
if (!existing) {
|
|
204
|
+
await saveInstanceMetadata(instanceId, {}, { discovered: true });
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
reply.code(202);
|
|
208
|
+
return {
|
|
209
|
+
task_id: taskId,
|
|
210
|
+
status: 'completed',
|
|
211
|
+
network_segments: request.body.network_segments,
|
|
212
|
+
instances_found: discovered.length,
|
|
213
|
+
instances: discovered,
|
|
214
|
+
completed_at: new Date().toISOString(),
|
|
215
|
+
};
|
|
216
|
+
});
|
|
217
|
+
// Set maintenance mode
|
|
218
|
+
fastify.post('/:instance_id/maintenance', async (request) => {
|
|
219
|
+
const metadata = await getInstanceMetadata(request.params.instance_id);
|
|
220
|
+
if (!metadata) {
|
|
221
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
222
|
+
}
|
|
223
|
+
const extra = parseJsonField(metadata.extra);
|
|
224
|
+
extra.maintenance_reason = request.body.reason;
|
|
225
|
+
extra.maintenance_duration = request.body.duration_minutes || 60;
|
|
226
|
+
extra.maintenance_mode = true;
|
|
227
|
+
const labels = parseLabels(metadata.labels);
|
|
228
|
+
await saveInstanceMetadata(request.params.instance_id, labels, extra);
|
|
229
|
+
return { message: `Instance ${request.params.instance_id} set to maintenance mode` };
|
|
230
|
+
});
|
|
231
|
+
// Remove maintenance mode
|
|
232
|
+
fastify.delete('/:instance_id/maintenance', async (request, reply) => {
|
|
233
|
+
const metadata = await getInstanceMetadata(request.params.instance_id);
|
|
234
|
+
if (!metadata) {
|
|
235
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
236
|
+
}
|
|
237
|
+
const extra = parseJsonField(metadata.extra);
|
|
238
|
+
if (!extra.maintenance_mode) {
|
|
239
|
+
return reply.code(400).send({
|
|
240
|
+
error: 'INVALID_STATE',
|
|
241
|
+
message: `Instance is not in maintenance mode: ${request.params.instance_id}`,
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
delete extra.maintenance_reason;
|
|
245
|
+
delete extra.maintenance_duration;
|
|
246
|
+
delete extra.maintenance_mode;
|
|
247
|
+
const labels = parseLabels(metadata.labels);
|
|
248
|
+
await saveInstanceMetadata(request.params.instance_id, labels, extra);
|
|
249
|
+
return { message: `Instance ${request.params.instance_id} removed from maintenance mode` };
|
|
250
|
+
});
|
|
251
|
+
// Get instance metrics
|
|
252
|
+
fastify.get('/:instance_id/metrics', async (request) => {
|
|
253
|
+
const metadata = await getInstanceMetadata(request.params.instance_id);
|
|
254
|
+
if (!metadata) {
|
|
255
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
256
|
+
}
|
|
257
|
+
const [host, portStr] = request.params.instance_id.split(':');
|
|
258
|
+
const port = parseInt(portStr, 10) || 3306;
|
|
259
|
+
const instance = (0, index_js_1.createMySQLInstance)(host, port, {
|
|
260
|
+
state: index_js_1.InstanceState.ONLINE,
|
|
261
|
+
role: index_js_1.InstanceRole.UNKNOWN,
|
|
262
|
+
});
|
|
263
|
+
const collector = (0, collector_js_1.getMetricsCollector)();
|
|
264
|
+
const metrics = await collector.collectMetrics(instance);
|
|
265
|
+
return {
|
|
266
|
+
...metrics,
|
|
267
|
+
timestamp: metrics.timestamp.toISOString(),
|
|
268
|
+
};
|
|
269
|
+
});
|
|
270
|
+
// Get instance health
|
|
271
|
+
fastify.get('/:instance_id/health', async (request) => {
|
|
272
|
+
const metadata = await getInstanceMetadata(request.params.instance_id);
|
|
273
|
+
if (!metadata) {
|
|
274
|
+
throw new exceptions_js_1.NotFoundError('Instance', request.params.instance_id);
|
|
275
|
+
}
|
|
276
|
+
const [host, portStr] = request.params.instance_id.split(':');
|
|
277
|
+
const port = parseInt(portStr, 10) || 3306;
|
|
278
|
+
const orchestrator = (0, topology_js_1.getOrchestratorClient)();
|
|
279
|
+
let isOnline = false;
|
|
280
|
+
let replicationLag;
|
|
281
|
+
try {
|
|
282
|
+
const topo = await orchestrator.getInstance(host, port);
|
|
283
|
+
isOnline = true;
|
|
284
|
+
replicationLag = topo.replication_lag_seconds;
|
|
285
|
+
}
|
|
286
|
+
catch {
|
|
287
|
+
isOnline = false;
|
|
288
|
+
}
|
|
289
|
+
const extra = parseJsonField(metadata.extra);
|
|
290
|
+
const inMaintenance = extra.maintenance_mode === true;
|
|
291
|
+
const checks = [
|
|
292
|
+
{
|
|
293
|
+
check_name: 'connectivity',
|
|
294
|
+
status: inMaintenance ? 'maintenance' : (isOnline ? 'healthy' : 'unhealthy'),
|
|
295
|
+
value: isOnline ? 1 : 0,
|
|
296
|
+
message: inMaintenance ? 'Instance is in maintenance mode' : (isOnline ? 'Instance is reachable' : 'Instance is not reachable'),
|
|
297
|
+
},
|
|
298
|
+
{
|
|
299
|
+
check_name: 'replication_lag',
|
|
300
|
+
status: replicationLag !== undefined && replicationLag < 10 ? 'healthy' : 'unhealthy',
|
|
301
|
+
value: replicationLag ?? 0,
|
|
302
|
+
message: replicationLag !== undefined
|
|
303
|
+
? `Replication lag: ${replicationLag}s`
|
|
304
|
+
: 'Replication not configured',
|
|
305
|
+
},
|
|
306
|
+
];
|
|
307
|
+
return {
|
|
308
|
+
instance_id: request.params.instance_id,
|
|
309
|
+
status: inMaintenance ? 'maintenance' : (isOnline ? 'healthy' : 'unhealthy'),
|
|
310
|
+
checks,
|
|
311
|
+
};
|
|
312
|
+
});
|
|
313
|
+
};
|
|
314
|
+
exports.default = instancesRoutes;
|
|
315
|
+
//# sourceMappingURL=instances.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instances.js","sourceRoot":"","sources":["../../../src/api/routes/instances.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"monitoring.d.ts","sourceRoot":"","sources":["../../../src/api/routes/monitoring.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAM7C,QAAA,MAAM,gBAAgB,EAAE,kBAgEvB,CAAC;AAEF,eAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* ClawSQL - Monitoring API Routes
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const topology_js_1 = require("../../core/discovery/topology.js");
|
|
7
|
+
const proxysql_manager_js_1 = require("../../core/routing/proxysql-manager.js");
|
|
8
|
+
const exporters_js_1 = require("../../core/monitoring/exporters.js");
|
|
9
|
+
const settings_js_1 = require("../../config/settings.js");
|
|
10
|
+
const monitoringRoutes = async (fastify) => {
|
|
11
|
+
// Health check
|
|
12
|
+
fastify.get('/health', async () => {
|
|
13
|
+
const settings = (0, settings_js_1.getSettings)();
|
|
14
|
+
return {
|
|
15
|
+
status: 'healthy',
|
|
16
|
+
version: settings.appVersion,
|
|
17
|
+
};
|
|
18
|
+
});
|
|
19
|
+
// System health
|
|
20
|
+
fastify.get('/system', async () => {
|
|
21
|
+
const orchestrator = (0, topology_js_1.getOrchestratorClient)();
|
|
22
|
+
const proxysql = (0, proxysql_manager_js_1.getProxySQLManager)();
|
|
23
|
+
// Check Orchestrator
|
|
24
|
+
let orchestratorHealth = 'unhealthy';
|
|
25
|
+
try {
|
|
26
|
+
orchestratorHealth = await orchestrator.healthCheck() ? 'healthy' : 'unhealthy';
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
orchestratorHealth = 'unhealthy';
|
|
30
|
+
}
|
|
31
|
+
// Check ProxySQL
|
|
32
|
+
let proxysqlHealth = 'unhealthy';
|
|
33
|
+
try {
|
|
34
|
+
await proxysql.connect();
|
|
35
|
+
proxysqlHealth = 'healthy';
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
proxysqlHealth = 'unhealthy';
|
|
39
|
+
}
|
|
40
|
+
// Check Prometheus (simplified)
|
|
41
|
+
let prometheusHealth = 'healthy';
|
|
42
|
+
try {
|
|
43
|
+
const response = await fetch('http://prometheus:9090/-/healthy');
|
|
44
|
+
prometheusHealth = response.ok ? 'healthy' : 'unhealthy';
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
prometheusHealth = 'unhealthy';
|
|
48
|
+
}
|
|
49
|
+
const allHealthy = orchestratorHealth === 'healthy' &&
|
|
50
|
+
proxysqlHealth === 'healthy' &&
|
|
51
|
+
prometheusHealth === 'healthy';
|
|
52
|
+
return {
|
|
53
|
+
status: allHealthy ? 'healthy' : 'degraded',
|
|
54
|
+
services: {
|
|
55
|
+
api: 'healthy',
|
|
56
|
+
orchestrator: orchestratorHealth,
|
|
57
|
+
proxysql: proxysqlHealth,
|
|
58
|
+
prometheus: prometheusHealth,
|
|
59
|
+
},
|
|
60
|
+
timestamp: new Date(),
|
|
61
|
+
};
|
|
62
|
+
});
|
|
63
|
+
// Prometheus metrics
|
|
64
|
+
fastify.get('/metrics', async (_request, reply) => {
|
|
65
|
+
const exporter = (0, exporters_js_1.getPrometheusExporter)();
|
|
66
|
+
const metrics = await exporter.getMetrics();
|
|
67
|
+
reply.type(exporter.getContentType());
|
|
68
|
+
return metrics;
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
exports.default = monitoringRoutes;
|
|
72
|
+
//# sourceMappingURL=monitoring.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"monitoring.js","sourceRoot":"","sources":["../../../src/api/routes/monitoring.ts"],"names":[],"mappings":";AAAA;;GAEG;;AAGH,kEAAyE;AACzE,gFAA4E;AAC5E,qEAA2E;AAC3E,0DAAuD;AAEvD,MAAM,gBAAgB,GAAuB,KAAK,EAAE,OAAO,EAAE,EAAE;IAC7D,eAAe;IACf,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QAChC,MAAM,QAAQ,GAAG,IAAA,yBAAW,GAAE,CAAC;QAC/B,OAAO;YACL,MAAM,EAAE,SAAS;YACjB,OAAO,EAAE,QAAQ,CAAC,UAAU;SAC7B,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,gBAAgB;IAChB,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,IAAI,EAAE;QAChC,MAAM,YAAY,GAAG,IAAA,mCAAqB,GAAE,CAAC;QAC7C,MAAM,QAAQ,GAAG,IAAA,wCAAkB,GAAE,CAAC;QAEtC,qBAAqB;QACrB,IAAI,kBAAkB,GAA4B,WAAW,CAAC;QAC9D,IAAI,CAAC;YACH,kBAAkB,GAAG,MAAM,YAAY,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;QAClF,CAAC;QAAC,MAAM,CAAC;YACP,kBAAkB,GAAG,WAAW,CAAC;QACnC,CAAC;QAED,iBAAiB;QACjB,IAAI,cAAc,GAA4B,WAAW,CAAC;QAC1D,IAAI,CAAC;YACH,MAAM,QAAQ,CAAC,OAAO,EAAE,CAAC;YACzB,cAAc,GAAG,SAAS,CAAC;QAC7B,CAAC;QAAC,MAAM,CAAC;YACP,cAAc,GAAG,WAAW,CAAC;QAC/B,CAAC;QAED,gCAAgC;QAChC,IAAI,gBAAgB,GAA4B,SAAS,CAAC;QAC1D,IAAI,CAAC;YACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,kCAAkC,CAAC,CAAC;YACjE,gBAAgB,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC;QAC3D,CAAC;QAAC,MAAM,CAAC;YACP,gBAAgB,GAAG,WAAW,CAAC;QACjC,CAAC;QAED,MAAM,UAAU,GAAG,kBAAkB,KAAK,SAAS;YACjD,cAAc,KAAK,SAAS;YAC5B,gBAAgB,KAAK,SAAS,CAAC;QAEjC,OAAO;YACL,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU;YAC3C,QAAQ,EAAE;gBACR,GAAG,EAAE,SAAS;gBACd,YAAY,EAAE,kBAAkB;gBAChC,QAAQ,EAAE,cAAc;gBACxB,UAAU,EAAE,gBAAgB;aAC7B;YACD,SAAS,EAAE,IAAI,IAAI,EAAE;SACtB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,qBAAqB;IACrB,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE;QAChD,MAAM,QAAQ,GAAG,IAAA,oCAAqB,GAAE,CAAC;QACzC,MAAM,OAAO,GAAG,MAAM,QAAQ,CAAC,UAAU,EAAE,CAAC;QAC5C,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC,CAAC;QACtC,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,kBAAe,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ClawSQL - Webhook Routes
|
|
3
|
+
*
|
|
4
|
+
* Handles webhook callbacks from Orchestrator.
|
|
5
|
+
*/
|
|
6
|
+
import { FastifyPluginAsync } from 'fastify';
|
|
7
|
+
/**
|
|
8
|
+
* Webhook routes
|
|
9
|
+
*/
|
|
10
|
+
declare const webhookRoutes: FastifyPluginAsync;
|
|
11
|
+
export default webhookRoutes;
|
|
12
|
+
//# sourceMappingURL=webhooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webhooks.d.ts","sourceRoot":"","sources":["../../../src/api/routes/webhooks.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AA4B7C;;GAEG;AACH,QAAA,MAAM,aAAa,EAAE,kBA4CpB,CAAC;AAiNF,eAAe,aAAa,CAAC"}
|