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.
Files changed (311) hide show
  1. package/.env.example +97 -0
  2. package/README.md +372 -0
  3. package/dist/__tests__/config/settings.test.d.ts +5 -0
  4. package/dist/__tests__/config/settings.test.d.ts.map +1 -0
  5. package/dist/__tests__/config/settings.test.js +154 -0
  6. package/dist/__tests__/config/settings.test.js.map +1 -0
  7. package/dist/__tests__/core/discovery/topology.test.d.ts +5 -0
  8. package/dist/__tests__/core/discovery/topology.test.d.ts.map +1 -0
  9. package/dist/__tests__/core/discovery/topology.test.js +191 -0
  10. package/dist/__tests__/core/discovery/topology.test.js.map +1 -0
  11. package/dist/__tests__/core/failover/executor.test.d.ts +5 -0
  12. package/dist/__tests__/core/failover/executor.test.d.ts.map +1 -0
  13. package/dist/__tests__/core/failover/executor.test.js +256 -0
  14. package/dist/__tests__/core/failover/executor.test.js.map +1 -0
  15. package/dist/__tests__/core/monitoring/collector.test.d.ts +5 -0
  16. package/dist/__tests__/core/monitoring/collector.test.d.ts.map +1 -0
  17. package/dist/__tests__/core/monitoring/collector.test.js +131 -0
  18. package/dist/__tests__/core/monitoring/collector.test.js.map +1 -0
  19. package/dist/__tests__/core/monitoring/exporters.test.d.ts +5 -0
  20. package/dist/__tests__/core/monitoring/exporters.test.d.ts.map +1 -0
  21. package/dist/__tests__/core/monitoring/exporters.test.js +90 -0
  22. package/dist/__tests__/core/monitoring/exporters.test.js.map +1 -0
  23. package/dist/__tests__/core/routing/proxysql-manager.test.d.ts +5 -0
  24. package/dist/__tests__/core/routing/proxysql-manager.test.d.ts.map +1 -0
  25. package/dist/__tests__/core/routing/proxysql-manager.test.js +155 -0
  26. package/dist/__tests__/core/routing/proxysql-manager.test.js.map +1 -0
  27. package/dist/__tests__/types/index.test.d.ts +5 -0
  28. package/dist/__tests__/types/index.test.d.ts.map +1 -0
  29. package/dist/__tests__/types/index.test.js +290 -0
  30. package/dist/__tests__/types/index.test.js.map +1 -0
  31. package/dist/__tests__/utils/exceptions.test.d.ts +5 -0
  32. package/dist/__tests__/utils/exceptions.test.d.ts.map +1 -0
  33. package/dist/__tests__/utils/exceptions.test.js +142 -0
  34. package/dist/__tests__/utils/exceptions.test.js.map +1 -0
  35. package/dist/api/routes/clusters.d.ts +7 -0
  36. package/dist/api/routes/clusters.d.ts.map +1 -0
  37. package/dist/api/routes/clusters.js +123 -0
  38. package/dist/api/routes/clusters.js.map +1 -0
  39. package/dist/api/routes/config.d.ts +7 -0
  40. package/dist/api/routes/config.d.ts.map +1 -0
  41. package/dist/api/routes/config.js +65 -0
  42. package/dist/api/routes/config.js.map +1 -0
  43. package/dist/api/routes/failover.d.ts +7 -0
  44. package/dist/api/routes/failover.d.ts.map +1 -0
  45. package/dist/api/routes/failover.js +100 -0
  46. package/dist/api/routes/failover.js.map +1 -0
  47. package/dist/api/routes/instances.d.ts +11 -0
  48. package/dist/api/routes/instances.d.ts.map +1 -0
  49. package/dist/api/routes/instances.js +315 -0
  50. package/dist/api/routes/instances.js.map +1 -0
  51. package/dist/api/routes/monitoring.d.ts +7 -0
  52. package/dist/api/routes/monitoring.d.ts.map +1 -0
  53. package/dist/api/routes/monitoring.js +72 -0
  54. package/dist/api/routes/monitoring.js.map +1 -0
  55. package/dist/api/routes/webhooks.d.ts +12 -0
  56. package/dist/api/routes/webhooks.d.ts.map +1 -0
  57. package/dist/api/routes/webhooks.js +232 -0
  58. package/dist/api/routes/webhooks.js.map +1 -0
  59. package/dist/api/schemas/index.d.ts +965 -0
  60. package/dist/api/schemas/index.d.ts.map +1 -0
  61. package/dist/api/schemas/index.js +171 -0
  62. package/dist/api/schemas/index.js.map +1 -0
  63. package/dist/app.d.ts +13 -0
  64. package/dist/app.d.ts.map +1 -0
  65. package/dist/app.js +197 -0
  66. package/dist/app.js.map +1 -0
  67. package/dist/bin/clawsql.d.ts +12 -0
  68. package/dist/bin/clawsql.d.ts.map +1 -0
  69. package/dist/bin/clawsql.js +43 -0
  70. package/dist/bin/clawsql.js.map +1 -0
  71. package/dist/cli/agent/handler.d.ts +73 -0
  72. package/dist/cli/agent/handler.d.ts.map +1 -0
  73. package/dist/cli/agent/handler.js +258 -0
  74. package/dist/cli/agent/handler.js.map +1 -0
  75. package/dist/cli/agent/index.d.ts +14 -0
  76. package/dist/cli/agent/index.d.ts.map +1 -0
  77. package/dist/cli/agent/index.js +30 -0
  78. package/dist/cli/agent/index.js.map +1 -0
  79. package/dist/cli/agent/openclaw-integration.d.ts +81 -0
  80. package/dist/cli/agent/openclaw-integration.d.ts.map +1 -0
  81. package/dist/cli/agent/openclaw-integration.js +341 -0
  82. package/dist/cli/agent/openclaw-integration.js.map +1 -0
  83. package/dist/cli/agent/providers/anthropic.d.ts +27 -0
  84. package/dist/cli/agent/providers/anthropic.d.ts.map +1 -0
  85. package/dist/cli/agent/providers/anthropic.js +106 -0
  86. package/dist/cli/agent/providers/anthropic.js.map +1 -0
  87. package/dist/cli/agent/providers/base.d.ts +91 -0
  88. package/dist/cli/agent/providers/base.d.ts.map +1 -0
  89. package/dist/cli/agent/providers/base.js +24 -0
  90. package/dist/cli/agent/providers/base.js.map +1 -0
  91. package/dist/cli/agent/providers/openai.d.ts +27 -0
  92. package/dist/cli/agent/providers/openai.d.ts.map +1 -0
  93. package/dist/cli/agent/providers/openai.js +98 -0
  94. package/dist/cli/agent/providers/openai.js.map +1 -0
  95. package/dist/cli/agent/tools/index.d.ts +32 -0
  96. package/dist/cli/agent/tools/index.d.ts.map +1 -0
  97. package/dist/cli/agent/tools/index.js +263 -0
  98. package/dist/cli/agent/tools/index.js.map +1 -0
  99. package/dist/cli/commands/cleanup.d.ts +12 -0
  100. package/dist/cli/commands/cleanup.d.ts.map +1 -0
  101. package/dist/cli/commands/cleanup.js +205 -0
  102. package/dist/cli/commands/cleanup.js.map +1 -0
  103. package/dist/cli/commands/clusters.d.ts +12 -0
  104. package/dist/cli/commands/clusters.d.ts.map +1 -0
  105. package/dist/cli/commands/clusters.js +468 -0
  106. package/dist/cli/commands/clusters.js.map +1 -0
  107. package/dist/cli/commands/config.d.ts +12 -0
  108. package/dist/cli/commands/config.d.ts.map +1 -0
  109. package/dist/cli/commands/config.js +406 -0
  110. package/dist/cli/commands/config.js.map +1 -0
  111. package/dist/cli/commands/cron.d.ts +12 -0
  112. package/dist/cli/commands/cron.d.ts.map +1 -0
  113. package/dist/cli/commands/cron.js +215 -0
  114. package/dist/cli/commands/cron.js.map +1 -0
  115. package/dist/cli/commands/doctor.d.ts +13 -0
  116. package/dist/cli/commands/doctor.d.ts.map +1 -0
  117. package/dist/cli/commands/doctor.js +687 -0
  118. package/dist/cli/commands/doctor.js.map +1 -0
  119. package/dist/cli/commands/failover.d.ts +16 -0
  120. package/dist/cli/commands/failover.d.ts.map +1 -0
  121. package/dist/cli/commands/failover.js +333 -0
  122. package/dist/cli/commands/failover.js.map +1 -0
  123. package/dist/cli/commands/health.d.ts +12 -0
  124. package/dist/cli/commands/health.d.ts.map +1 -0
  125. package/dist/cli/commands/health.js +125 -0
  126. package/dist/cli/commands/health.js.map +1 -0
  127. package/dist/cli/commands/help.d.ts +12 -0
  128. package/dist/cli/commands/help.d.ts.map +1 -0
  129. package/dist/cli/commands/help.js +52 -0
  130. package/dist/cli/commands/help.js.map +1 -0
  131. package/dist/cli/commands/instances.d.ts +12 -0
  132. package/dist/cli/commands/instances.d.ts.map +1 -0
  133. package/dist/cli/commands/instances.js +801 -0
  134. package/dist/cli/commands/instances.js.map +1 -0
  135. package/dist/cli/commands/notify.d.ts +12 -0
  136. package/dist/cli/commands/notify.d.ts.map +1 -0
  137. package/dist/cli/commands/notify.js +43 -0
  138. package/dist/cli/commands/notify.js.map +1 -0
  139. package/dist/cli/commands/sql.d.ts +12 -0
  140. package/dist/cli/commands/sql.d.ts.map +1 -0
  141. package/dist/cli/commands/sql.js +90 -0
  142. package/dist/cli/commands/sql.js.map +1 -0
  143. package/dist/cli/commands/start.d.ts +12 -0
  144. package/dist/cli/commands/start.d.ts.map +1 -0
  145. package/dist/cli/commands/start.js +174 -0
  146. package/dist/cli/commands/start.js.map +1 -0
  147. package/dist/cli/commands/status.d.ts +12 -0
  148. package/dist/cli/commands/status.d.ts.map +1 -0
  149. package/dist/cli/commands/status.js +218 -0
  150. package/dist/cli/commands/status.js.map +1 -0
  151. package/dist/cli/commands/stop.d.ts +12 -0
  152. package/dist/cli/commands/stop.d.ts.map +1 -0
  153. package/dist/cli/commands/stop.js +128 -0
  154. package/dist/cli/commands/stop.js.map +1 -0
  155. package/dist/cli/commands/topology.d.ts +12 -0
  156. package/dist/cli/commands/topology.d.ts.map +1 -0
  157. package/dist/cli/commands/topology.js +106 -0
  158. package/dist/cli/commands/topology.js.map +1 -0
  159. package/dist/cli/completer.d.ts +47 -0
  160. package/dist/cli/completer.d.ts.map +1 -0
  161. package/dist/cli/completer.js +332 -0
  162. package/dist/cli/completer.js.map +1 -0
  163. package/dist/cli/formatter.d.ts +165 -0
  164. package/dist/cli/formatter.d.ts.map +1 -0
  165. package/dist/cli/formatter.js +408 -0
  166. package/dist/cli/formatter.js.map +1 -0
  167. package/dist/cli/index.d.ts +21 -0
  168. package/dist/cli/index.d.ts.map +1 -0
  169. package/dist/cli/index.js +79 -0
  170. package/dist/cli/index.js.map +1 -0
  171. package/dist/cli/raw-input.d.ts +97 -0
  172. package/dist/cli/raw-input.d.ts.map +1 -0
  173. package/dist/cli/raw-input.js +493 -0
  174. package/dist/cli/raw-input.js.map +1 -0
  175. package/dist/cli/registry.d.ts +103 -0
  176. package/dist/cli/registry.d.ts.map +1 -0
  177. package/dist/cli/registry.js +205 -0
  178. package/dist/cli/registry.js.map +1 -0
  179. package/dist/cli/repl.d.ts +83 -0
  180. package/dist/cli/repl.d.ts.map +1 -0
  181. package/dist/cli/repl.js +447 -0
  182. package/dist/cli/repl.js.map +1 -0
  183. package/dist/cli/ui/components.d.ts +144 -0
  184. package/dist/cli/ui/components.d.ts.map +1 -0
  185. package/dist/cli/ui/components.js +331 -0
  186. package/dist/cli/ui/components.js.map +1 -0
  187. package/dist/cli/ui/index.d.ts +7 -0
  188. package/dist/cli/ui/index.d.ts.map +1 -0
  189. package/dist/cli/ui/index.js +23 -0
  190. package/dist/cli/ui/index.js.map +1 -0
  191. package/dist/cli/utils/docker-files.d.ts +39 -0
  192. package/dist/cli/utils/docker-files.d.ts.map +1 -0
  193. package/dist/cli/utils/docker-files.js +223 -0
  194. package/dist/cli/utils/docker-files.js.map +1 -0
  195. package/dist/cli/utils/docker-prereq.d.ts +48 -0
  196. package/dist/cli/utils/docker-prereq.d.ts.map +1 -0
  197. package/dist/cli/utils/docker-prereq.js +203 -0
  198. package/dist/cli/utils/docker-prereq.js.map +1 -0
  199. package/dist/config/settings.d.ts +594 -0
  200. package/dist/config/settings.d.ts.map +1 -0
  201. package/dist/config/settings.js +250 -0
  202. package/dist/config/settings.js.map +1 -0
  203. package/dist/core/discovery/cluster-view.d.ts +50 -0
  204. package/dist/core/discovery/cluster-view.d.ts.map +1 -0
  205. package/dist/core/discovery/cluster-view.js +235 -0
  206. package/dist/core/discovery/cluster-view.js.map +1 -0
  207. package/dist/core/discovery/scanner.d.ts +70 -0
  208. package/dist/core/discovery/scanner.d.ts.map +1 -0
  209. package/dist/core/discovery/scanner.js +197 -0
  210. package/dist/core/discovery/scanner.js.map +1 -0
  211. package/dist/core/discovery/topology.d.ts +118 -0
  212. package/dist/core/discovery/topology.d.ts.map +1 -0
  213. package/dist/core/discovery/topology.js +550 -0
  214. package/dist/core/discovery/topology.js.map +1 -0
  215. package/dist/core/failover/candidate-selector.d.ts +46 -0
  216. package/dist/core/failover/candidate-selector.d.ts.map +1 -0
  217. package/dist/core/failover/candidate-selector.js +70 -0
  218. package/dist/core/failover/candidate-selector.js.map +1 -0
  219. package/dist/core/failover/executor.d.ts +104 -0
  220. package/dist/core/failover/executor.d.ts.map +1 -0
  221. package/dist/core/failover/executor.js +248 -0
  222. package/dist/core/failover/executor.js.map +1 -0
  223. package/dist/core/failover/operation-builder.d.ts +71 -0
  224. package/dist/core/failover/operation-builder.d.ts.map +1 -0
  225. package/dist/core/failover/operation-builder.js +157 -0
  226. package/dist/core/failover/operation-builder.js.map +1 -0
  227. package/dist/core/failover/operation-runner.d.ts +75 -0
  228. package/dist/core/failover/operation-runner.d.ts.map +1 -0
  229. package/dist/core/failover/operation-runner.js +191 -0
  230. package/dist/core/failover/operation-runner.js.map +1 -0
  231. package/dist/core/failover/promoter.d.ts +33 -0
  232. package/dist/core/failover/promoter.d.ts.map +1 -0
  233. package/dist/core/failover/promoter.js +97 -0
  234. package/dist/core/failover/promoter.js.map +1 -0
  235. package/dist/core/failover/recovery-manager.d.ts +47 -0
  236. package/dist/core/failover/recovery-manager.d.ts.map +1 -0
  237. package/dist/core/failover/recovery-manager.js +145 -0
  238. package/dist/core/failover/recovery-manager.js.map +1 -0
  239. package/dist/core/failover/types.d.ts +54 -0
  240. package/dist/core/failover/types.d.ts.map +1 -0
  241. package/dist/core/failover/types.js +8 -0
  242. package/dist/core/failover/types.js.map +1 -0
  243. package/dist/core/monitoring/collector.d.ts +25 -0
  244. package/dist/core/monitoring/collector.d.ts.map +1 -0
  245. package/dist/core/monitoring/collector.js +115 -0
  246. package/dist/core/monitoring/collector.js.map +1 -0
  247. package/dist/core/monitoring/exporters.d.ts +49 -0
  248. package/dist/core/monitoring/exporters.d.ts.map +1 -0
  249. package/dist/core/monitoring/exporters.js +126 -0
  250. package/dist/core/monitoring/exporters.js.map +1 -0
  251. package/dist/core/routing/proxysql-manager.d.ts +213 -0
  252. package/dist/core/routing/proxysql-manager.d.ts.map +1 -0
  253. package/dist/core/routing/proxysql-manager.js +632 -0
  254. package/dist/core/routing/proxysql-manager.js.map +1 -0
  255. package/dist/core/sync/replica-recovery.d.ts +40 -0
  256. package/dist/core/sync/replica-recovery.d.ts.map +1 -0
  257. package/dist/core/sync/replica-recovery.js +134 -0
  258. package/dist/core/sync/replica-recovery.js.map +1 -0
  259. package/dist/core/sync/sync-coordinator.d.ts +83 -0
  260. package/dist/core/sync/sync-coordinator.d.ts.map +1 -0
  261. package/dist/core/sync/sync-coordinator.js +254 -0
  262. package/dist/core/sync/sync-coordinator.js.map +1 -0
  263. package/dist/core/sync/topology-watcher.d.ts +76 -0
  264. package/dist/core/sync/topology-watcher.d.ts.map +1 -0
  265. package/dist/core/sync/topology-watcher.js +222 -0
  266. package/dist/core/sync/topology-watcher.js.map +1 -0
  267. package/dist/core/sync/types.d.ts +85 -0
  268. package/dist/core/sync/types.d.ts.map +1 -0
  269. package/dist/core/sync/types.js +8 -0
  270. package/dist/core/sync/types.js.map +1 -0
  271. package/dist/index.d.ts +5 -0
  272. package/dist/index.d.ts.map +1 -0
  273. package/dist/index.js +9 -0
  274. package/dist/index.js.map +1 -0
  275. package/dist/types/index.d.ts +212 -0
  276. package/dist/types/index.d.ts.map +1 -0
  277. package/dist/types/index.js +153 -0
  278. package/dist/types/index.js.map +1 -0
  279. package/dist/utils/database.d.ts +62 -0
  280. package/dist/utils/database.d.ts.map +1 -0
  281. package/dist/utils/database.js +257 -0
  282. package/dist/utils/database.js.map +1 -0
  283. package/dist/utils/exceptions.d.ts +69 -0
  284. package/dist/utils/exceptions.d.ts.map +1 -0
  285. package/dist/utils/exceptions.js +121 -0
  286. package/dist/utils/exceptions.js.map +1 -0
  287. package/dist/utils/logger.d.ts +20 -0
  288. package/dist/utils/logger.d.ts.map +1 -0
  289. package/dist/utils/logger.js +90 -0
  290. package/dist/utils/logger.js.map +1 -0
  291. package/dist/utils/mysql-client.d.ts +43 -0
  292. package/dist/utils/mysql-client.d.ts.map +1 -0
  293. package/dist/utils/mysql-client.js +125 -0
  294. package/dist/utils/mysql-client.js.map +1 -0
  295. package/docker/Dockerfile +61 -0
  296. package/docker/Dockerfile.node +41 -0
  297. package/docker/grafana/dashboards/clawsql.json +212 -0
  298. package/docker/grafana/provisioning/dashboards/dashboards.yml +13 -0
  299. package/docker/grafana/provisioning/datasources/datasources.yml +12 -0
  300. package/docker/init/primary.sql +26 -0
  301. package/docker/init/replica.sql +16 -0
  302. package/docker/orchestrator/orchestrator.conf.json +98 -0
  303. package/docker/prometheus/prometheus.yml +45 -0
  304. package/docker/proxysql/entrypoint.sh +8 -0
  305. package/docker/proxysql/init.sql.demo +30 -0
  306. package/docker/proxysql/proxysql.cnf +38 -0
  307. package/docker-compose.demo.yml +115 -0
  308. package/docker-compose.yml +217 -0
  309. package/init/primary.sql +19 -0
  310. package/init/replica.sql +13 -0
  311. 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,7 @@
1
+ /**
2
+ * ClawSQL - Monitoring API Routes
3
+ */
4
+ import { FastifyPluginAsync } from 'fastify';
5
+ declare const monitoringRoutes: FastifyPluginAsync;
6
+ export default monitoringRoutes;
7
+ //# sourceMappingURL=monitoring.d.ts.map
@@ -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"}