spindb 0.37.2 → 0.38.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 (811) hide show
  1. package/dist/cli/bin.js +9 -0
  2. package/dist/cli/bin.js.map +1 -0
  3. package/dist/cli/commands/attach.js +102 -0
  4. package/dist/cli/commands/attach.js.map +1 -0
  5. package/dist/cli/commands/backup.js +197 -0
  6. package/dist/cli/commands/backup.js.map +1 -0
  7. package/dist/cli/commands/backups.js +190 -0
  8. package/dist/cli/commands/backups.js.map +1 -0
  9. package/dist/cli/commands/clone.js +119 -0
  10. package/dist/cli/commands/clone.js.map +1 -0
  11. package/dist/cli/commands/config.js +276 -0
  12. package/dist/cli/commands/config.js.map +1 -0
  13. package/dist/cli/commands/connect.js +559 -0
  14. package/dist/cli/commands/connect.js.map +1 -0
  15. package/dist/cli/commands/create.js +952 -0
  16. package/dist/cli/commands/create.js.map +1 -0
  17. package/dist/cli/commands/databases.js +485 -0
  18. package/dist/cli/commands/databases.js.map +1 -0
  19. package/dist/cli/commands/delete.js +106 -0
  20. package/dist/cli/commands/delete.js.map +1 -0
  21. package/dist/cli/commands/deps.js +238 -0
  22. package/dist/cli/commands/deps.js.map +1 -0
  23. package/dist/cli/commands/detach.js +81 -0
  24. package/dist/cli/commands/detach.js.map +1 -0
  25. package/dist/cli/commands/doctor.js +567 -0
  26. package/dist/cli/commands/doctor.js.map +1 -0
  27. package/dist/cli/commands/duckdb.js +207 -0
  28. package/dist/cli/commands/duckdb.js.map +1 -0
  29. package/dist/cli/commands/edit.js +524 -0
  30. package/dist/cli/commands/edit.js.map +1 -0
  31. package/dist/cli/commands/engines.js +1414 -0
  32. package/dist/cli/commands/engines.js.map +1 -0
  33. package/dist/cli/commands/export.js +383 -0
  34. package/dist/cli/commands/export.js.map +1 -0
  35. package/dist/cli/commands/info.js +270 -0
  36. package/dist/cli/commands/info.js.map +1 -0
  37. package/dist/cli/commands/list.js +215 -0
  38. package/dist/cli/commands/list.js.map +1 -0
  39. package/dist/cli/commands/logs.js +81 -0
  40. package/dist/cli/commands/logs.js.map +1 -0
  41. package/dist/cli/commands/menu/backup-handlers.js +1202 -0
  42. package/dist/cli/commands/menu/backup-handlers.js.map +1 -0
  43. package/dist/cli/commands/menu/container-handlers.js +1788 -0
  44. package/dist/cli/commands/menu/container-handlers.js.map +1 -0
  45. package/dist/cli/commands/menu/engine-handlers.js +235 -0
  46. package/dist/cli/commands/menu/engine-handlers.js.map +1 -0
  47. package/dist/cli/commands/menu/index.js +266 -0
  48. package/dist/cli/commands/menu/index.js.map +1 -0
  49. package/dist/cli/commands/menu/settings-handlers.js +320 -0
  50. package/dist/cli/commands/menu/settings-handlers.js.map +1 -0
  51. package/dist/cli/commands/menu/shared.js +13 -0
  52. package/dist/cli/commands/menu/shared.js.map +1 -0
  53. package/dist/cli/commands/menu/shell-handlers.js +1573 -0
  54. package/dist/cli/commands/menu/shell-handlers.js.map +1 -0
  55. package/dist/cli/commands/menu/sql-handlers.js +185 -0
  56. package/dist/cli/commands/menu/sql-handlers.js.map +1 -0
  57. package/dist/cli/commands/menu/update-handlers.js +322 -0
  58. package/dist/cli/commands/menu/update-handlers.js.map +1 -0
  59. package/dist/cli/commands/menu/validators.js +9 -0
  60. package/dist/cli/commands/menu/validators.js.map +1 -0
  61. package/dist/cli/commands/ports.js +166 -0
  62. package/dist/cli/commands/ports.js.map +1 -0
  63. package/dist/cli/commands/pull.js +166 -0
  64. package/dist/cli/commands/pull.js.map +1 -0
  65. package/dist/cli/commands/query.js +180 -0
  66. package/dist/cli/commands/query.js.map +1 -0
  67. package/dist/cli/commands/restore.js +428 -0
  68. package/dist/cli/commands/restore.js.map +1 -0
  69. package/dist/cli/commands/run.js +115 -0
  70. package/dist/cli/commands/run.js.map +1 -0
  71. package/dist/cli/commands/self-update.js +99 -0
  72. package/dist/cli/commands/self-update.js.map +1 -0
  73. package/dist/cli/commands/sqlite.js +207 -0
  74. package/dist/cli/commands/sqlite.js.map +1 -0
  75. package/dist/cli/commands/start.js +196 -0
  76. package/dist/cli/commands/start.js.map +1 -0
  77. package/dist/cli/commands/stop.js +182 -0
  78. package/dist/cli/commands/stop.js.map +1 -0
  79. package/dist/cli/commands/url.js +88 -0
  80. package/dist/cli/commands/url.js.map +1 -0
  81. package/dist/cli/commands/users.js +189 -0
  82. package/dist/cli/commands/users.js.map +1 -0
  83. package/dist/cli/commands/version.js +52 -0
  84. package/dist/cli/commands/version.js.map +1 -0
  85. package/dist/cli/commands/which.js +258 -0
  86. package/dist/cli/commands/which.js.map +1 -0
  87. package/dist/cli/constants.js +212 -0
  88. package/dist/cli/constants.js.map +1 -0
  89. package/dist/cli/helpers.js +1120 -0
  90. package/dist/cli/helpers.js.map +1 -0
  91. package/dist/cli/index.js +146 -0
  92. package/dist/cli/index.js.map +1 -0
  93. package/dist/cli/ui/prompts.js +1002 -0
  94. package/dist/cli/ui/prompts.js.map +1 -0
  95. package/dist/cli/ui/spinner.js +74 -0
  96. package/dist/cli/ui/spinner.js.map +1 -0
  97. package/dist/cli/ui/theme.js +99 -0
  98. package/dist/cli/ui/theme.js.map +1 -0
  99. package/dist/cli/utils/file-follower.js +79 -0
  100. package/dist/cli/utils/file-follower.js.map +1 -0
  101. package/dist/config/backup-formats.js +363 -0
  102. package/dist/config/backup-formats.js.map +1 -0
  103. package/dist/config/defaults.js +25 -0
  104. package/dist/config/defaults.js.map +1 -0
  105. package/dist/config/engine-defaults.js +303 -0
  106. package/dist/config/engine-defaults.js.map +1 -0
  107. package/dist/config/engines-registry.js +103 -0
  108. package/dist/config/engines-registry.js.map +1 -0
  109. package/dist/config/os-dependencies.js +767 -0
  110. package/dist/config/os-dependencies.js.map +1 -0
  111. package/dist/config/paths.js +156 -0
  112. package/dist/config/paths.js.map +1 -0
  113. package/dist/config/version.js +3 -0
  114. package/dist/config/version.js.map +1 -0
  115. package/dist/core/backup-restore.js +219 -0
  116. package/dist/core/backup-restore.js.map +1 -0
  117. package/dist/core/base-binary-manager.js +403 -0
  118. package/dist/core/base-binary-manager.js.map +1 -0
  119. package/dist/core/base-document-binary-manager.js +364 -0
  120. package/dist/core/base-document-binary-manager.js.map +1 -0
  121. package/dist/core/base-embedded-binary-manager.js +364 -0
  122. package/dist/core/base-embedded-binary-manager.js.map +1 -0
  123. package/dist/core/base-server-binary-manager.js +368 -0
  124. package/dist/core/base-server-binary-manager.js.map +1 -0
  125. package/dist/core/config-manager.js +495 -0
  126. package/dist/core/config-manager.js.map +1 -0
  127. package/dist/core/container-manager.js +609 -0
  128. package/dist/core/container-manager.js.map +1 -0
  129. package/dist/core/credential-generator.js +67 -0
  130. package/dist/core/credential-generator.js.map +1 -0
  131. package/dist/core/credential-manager.js +211 -0
  132. package/dist/core/credential-manager.js.map +1 -0
  133. package/dist/core/dblab-utils.js +105 -0
  134. package/dist/core/dblab-utils.js.map +1 -0
  135. package/dist/core/dependency-manager.js +359 -0
  136. package/dist/core/dependency-manager.js.map +1 -0
  137. package/dist/core/docker-exporter.js +1077 -0
  138. package/dist/core/docker-exporter.js.map +1 -0
  139. package/dist/core/error-handler.js +295 -0
  140. package/dist/core/error-handler.js.map +1 -0
  141. package/dist/core/fs-error-utils.js +74 -0
  142. package/dist/core/fs-error-utils.js.map +1 -0
  143. package/dist/core/homebrew-version-manager.js +280 -0
  144. package/dist/core/homebrew-version-manager.js.map +1 -0
  145. package/dist/core/hostdb-client.js +252 -0
  146. package/dist/core/hostdb-client.js.map +1 -0
  147. package/dist/core/hostdb-metadata.js +243 -0
  148. package/dist/core/hostdb-metadata.js.map +1 -0
  149. package/dist/core/hostdb-releases-factory.js +161 -0
  150. package/dist/core/hostdb-releases-factory.js.map +1 -0
  151. package/dist/core/library-env.js +88 -0
  152. package/dist/core/library-env.js.map +1 -0
  153. package/dist/core/pgweb-utils.js +53 -0
  154. package/dist/core/pgweb-utils.js.map +1 -0
  155. package/dist/core/platform-service.js +632 -0
  156. package/dist/core/platform-service.js.map +1 -0
  157. package/dist/core/port-manager.js +136 -0
  158. package/dist/core/port-manager.js.map +1 -0
  159. package/dist/core/process-manager.js +445 -0
  160. package/dist/core/process-manager.js.map +1 -0
  161. package/dist/core/pull-manager.js +418 -0
  162. package/dist/core/pull-manager.js.map +1 -0
  163. package/dist/core/query-parser.js +449 -0
  164. package/dist/core/query-parser.js.map +1 -0
  165. package/dist/core/spawn-utils.js +90 -0
  166. package/dist/core/spawn-utils.js.map +1 -0
  167. package/dist/core/start-with-retry.js +90 -0
  168. package/dist/core/start-with-retry.js.map +1 -0
  169. package/dist/core/test-cleanup.js +85 -0
  170. package/dist/core/test-cleanup.js.map +1 -0
  171. package/dist/core/tls-generator.js +84 -0
  172. package/dist/core/tls-generator.js.map +1 -0
  173. package/dist/core/transaction-manager.js +139 -0
  174. package/dist/core/transaction-manager.js.map +1 -0
  175. package/dist/core/update-manager.js +241 -0
  176. package/dist/core/update-manager.js.map +1 -0
  177. package/dist/core/version-migration.js +260 -0
  178. package/dist/core/version-migration.js.map +1 -0
  179. package/dist/core/version-utils.js +91 -0
  180. package/dist/core/version-utils.js.map +1 -0
  181. package/dist/engines/base-engine.js +179 -0
  182. package/dist/engines/base-engine.js.map +1 -0
  183. package/dist/engines/clickhouse/backup.js +289 -0
  184. package/dist/engines/clickhouse/backup.js.map +1 -0
  185. package/dist/engines/clickhouse/binary-manager.js +145 -0
  186. package/dist/engines/clickhouse/binary-manager.js.map +1 -0
  187. package/dist/engines/clickhouse/binary-urls.js +100 -0
  188. package/dist/engines/clickhouse/binary-urls.js.map +1 -0
  189. package/dist/engines/clickhouse/cli-utils.js +143 -0
  190. package/dist/engines/clickhouse/cli-utils.js.map +1 -0
  191. package/dist/engines/clickhouse/hostdb-releases.js +24 -0
  192. package/dist/engines/clickhouse/hostdb-releases.js.map +1 -0
  193. package/dist/engines/clickhouse/index.js +1077 -0
  194. package/dist/engines/clickhouse/index.js.map +1 -0
  195. package/dist/engines/clickhouse/restore.js +335 -0
  196. package/dist/engines/clickhouse/restore.js.map +1 -0
  197. package/dist/engines/clickhouse/version-maps.js +83 -0
  198. package/dist/engines/clickhouse/version-maps.js.map +1 -0
  199. package/dist/engines/clickhouse/version-validator.js +133 -0
  200. package/dist/engines/clickhouse/version-validator.js.map +1 -0
  201. package/dist/engines/cockroachdb/backup.js +261 -0
  202. package/dist/engines/cockroachdb/backup.js.map +1 -0
  203. package/dist/engines/cockroachdb/binary-manager.js +33 -0
  204. package/dist/engines/cockroachdb/binary-manager.js.map +1 -0
  205. package/dist/engines/cockroachdb/binary-urls.js +33 -0
  206. package/dist/engines/cockroachdb/binary-urls.js.map +1 -0
  207. package/dist/engines/cockroachdb/cli-utils.js +338 -0
  208. package/dist/engines/cockroachdb/cli-utils.js.map +1 -0
  209. package/dist/engines/cockroachdb/hostdb-releases.js +21 -0
  210. package/dist/engines/cockroachdb/hostdb-releases.js.map +1 -0
  211. package/dist/engines/cockroachdb/index.js +1016 -0
  212. package/dist/engines/cockroachdb/index.js.map +1 -0
  213. package/dist/engines/cockroachdb/restore.js +323 -0
  214. package/dist/engines/cockroachdb/restore.js.map +1 -0
  215. package/dist/engines/cockroachdb/version-maps.js +37 -0
  216. package/dist/engines/cockroachdb/version-maps.js.map +1 -0
  217. package/dist/engines/couchdb/api-client.js +64 -0
  218. package/dist/engines/couchdb/api-client.js.map +1 -0
  219. package/dist/engines/couchdb/backup.js +90 -0
  220. package/dist/engines/couchdb/backup.js.map +1 -0
  221. package/dist/engines/couchdb/binary-manager.js +62 -0
  222. package/dist/engines/couchdb/binary-manager.js.map +1 -0
  223. package/dist/engines/couchdb/binary-urls.js +92 -0
  224. package/dist/engines/couchdb/binary-urls.js.map +1 -0
  225. package/dist/engines/couchdb/hostdb-releases.js +21 -0
  226. package/dist/engines/couchdb/hostdb-releases.js.map +1 -0
  227. package/dist/engines/couchdb/index.js +1043 -0
  228. package/dist/engines/couchdb/index.js.map +1 -0
  229. package/dist/engines/couchdb/restore.js +198 -0
  230. package/dist/engines/couchdb/restore.js.map +1 -0
  231. package/dist/engines/couchdb/version-maps.js +67 -0
  232. package/dist/engines/couchdb/version-maps.js.map +1 -0
  233. package/dist/engines/couchdb/version-validator.js +88 -0
  234. package/dist/engines/couchdb/version-validator.js.map +1 -0
  235. package/dist/engines/duckdb/binary-manager.js +33 -0
  236. package/dist/engines/duckdb/binary-manager.js.map +1 -0
  237. package/{engines/duckdb/binary-urls.ts → dist/engines/duckdb/binary-urls.js} +11 -16
  238. package/dist/engines/duckdb/binary-urls.js.map +1 -0
  239. package/dist/engines/duckdb/hostdb-releases.js +21 -0
  240. package/dist/engines/duckdb/hostdb-releases.js.map +1 -0
  241. package/dist/engines/duckdb/index.js +594 -0
  242. package/dist/engines/duckdb/index.js.map +1 -0
  243. package/dist/engines/duckdb/registry.js +265 -0
  244. package/dist/engines/duckdb/registry.js.map +1 -0
  245. package/dist/engines/duckdb/scanner.js +12 -0
  246. package/dist/engines/duckdb/scanner.js.map +1 -0
  247. package/dist/engines/duckdb/version-maps.js +67 -0
  248. package/dist/engines/duckdb/version-maps.js.map +1 -0
  249. package/dist/engines/duckdb/version-validator.js +62 -0
  250. package/dist/engines/duckdb/version-validator.js.map +1 -0
  251. package/dist/engines/ferretdb/backup.js +170 -0
  252. package/dist/engines/ferretdb/backup.js.map +1 -0
  253. package/dist/engines/ferretdb/binary-manager.js +765 -0
  254. package/dist/engines/ferretdb/binary-manager.js.map +1 -0
  255. package/dist/engines/ferretdb/binary-urls.js +135 -0
  256. package/dist/engines/ferretdb/binary-urls.js.map +1 -0
  257. package/dist/engines/ferretdb/index.js +1517 -0
  258. package/dist/engines/ferretdb/index.js.map +1 -0
  259. package/dist/engines/ferretdb/restore.js +310 -0
  260. package/dist/engines/ferretdb/restore.js.map +1 -0
  261. package/{engines/ferretdb/version-maps.ts → dist/engines/ferretdb/version-maps.js} +62 -79
  262. package/dist/engines/ferretdb/version-maps.js.map +1 -0
  263. package/dist/engines/file-based-utils.js +184 -0
  264. package/dist/engines/file-based-utils.js.map +1 -0
  265. package/dist/engines/index.js +124 -0
  266. package/dist/engines/index.js.map +1 -0
  267. package/dist/engines/influxdb/api-client.js +54 -0
  268. package/dist/engines/influxdb/api-client.js.map +1 -0
  269. package/dist/engines/influxdb/backup.js +119 -0
  270. package/dist/engines/influxdb/backup.js.map +1 -0
  271. package/dist/engines/influxdb/binary-manager.js +87 -0
  272. package/dist/engines/influxdb/binary-manager.js.map +1 -0
  273. package/dist/engines/influxdb/binary-urls.js +56 -0
  274. package/dist/engines/influxdb/binary-urls.js.map +1 -0
  275. package/dist/engines/influxdb/hostdb-releases.js +21 -0
  276. package/dist/engines/influxdb/hostdb-releases.js.map +1 -0
  277. package/dist/engines/influxdb/index.js +962 -0
  278. package/dist/engines/influxdb/index.js.map +1 -0
  279. package/dist/engines/influxdb/restore.js +329 -0
  280. package/dist/engines/influxdb/restore.js.map +1 -0
  281. package/dist/engines/influxdb/version-maps.js +64 -0
  282. package/dist/engines/influxdb/version-maps.js.map +1 -0
  283. package/dist/engines/influxdb/version-validator.js +109 -0
  284. package/dist/engines/influxdb/version-validator.js.map +1 -0
  285. package/dist/engines/mariadb/backup.js +178 -0
  286. package/dist/engines/mariadb/backup.js.map +1 -0
  287. package/dist/engines/mariadb/binary-manager.js +33 -0
  288. package/dist/engines/mariadb/binary-manager.js.map +1 -0
  289. package/{engines/mariadb/binary-urls.ts → dist/engines/mariadb/binary-urls.js} +38 -55
  290. package/dist/engines/mariadb/binary-urls.js.map +1 -0
  291. package/dist/engines/mariadb/hostdb-releases.js +21 -0
  292. package/dist/engines/mariadb/hostdb-releases.js.map +1 -0
  293. package/dist/engines/mariadb/index.js +1011 -0
  294. package/dist/engines/mariadb/index.js.map +1 -0
  295. package/dist/engines/mariadb/restore.js +322 -0
  296. package/dist/engines/mariadb/restore.js.map +1 -0
  297. package/dist/engines/mariadb/version-maps.js +63 -0
  298. package/dist/engines/mariadb/version-maps.js.map +1 -0
  299. package/dist/engines/mariadb/version-validator.js +143 -0
  300. package/dist/engines/mariadb/version-validator.js.map +1 -0
  301. package/dist/engines/meilisearch/api-client.js +50 -0
  302. package/dist/engines/meilisearch/api-client.js.map +1 -0
  303. package/dist/engines/meilisearch/backup.js +167 -0
  304. package/dist/engines/meilisearch/backup.js.map +1 -0
  305. package/dist/engines/meilisearch/binary-manager.js +31 -0
  306. package/dist/engines/meilisearch/binary-manager.js.map +1 -0
  307. package/dist/engines/meilisearch/binary-urls.js +56 -0
  308. package/dist/engines/meilisearch/binary-urls.js.map +1 -0
  309. package/dist/engines/meilisearch/hostdb-releases.js +21 -0
  310. package/dist/engines/meilisearch/hostdb-releases.js.map +1 -0
  311. package/dist/engines/meilisearch/index.js +992 -0
  312. package/dist/engines/meilisearch/index.js.map +1 -0
  313. package/dist/engines/meilisearch/restore.js +167 -0
  314. package/dist/engines/meilisearch/restore.js.map +1 -0
  315. package/dist/engines/meilisearch/version-maps.js +67 -0
  316. package/dist/engines/meilisearch/version-maps.js.map +1 -0
  317. package/dist/engines/meilisearch/version-validator.js +109 -0
  318. package/dist/engines/meilisearch/version-validator.js.map +1 -0
  319. package/dist/engines/mongodb/backup.js +109 -0
  320. package/dist/engines/mongodb/backup.js.map +1 -0
  321. package/dist/engines/mongodb/binary-manager.js +36 -0
  322. package/dist/engines/mongodb/binary-manager.js.map +1 -0
  323. package/dist/engines/mongodb/binary-urls.js +46 -0
  324. package/dist/engines/mongodb/binary-urls.js.map +1 -0
  325. package/dist/engines/mongodb/cli-utils.js +131 -0
  326. package/dist/engines/mongodb/cli-utils.js.map +1 -0
  327. package/dist/engines/mongodb/hostdb-releases.js +77 -0
  328. package/dist/engines/mongodb/hostdb-releases.js.map +1 -0
  329. package/dist/engines/mongodb/index.js +873 -0
  330. package/dist/engines/mongodb/index.js.map +1 -0
  331. package/dist/engines/mongodb/restore.js +276 -0
  332. package/dist/engines/mongodb/restore.js.map +1 -0
  333. package/dist/engines/mongodb/version-maps.js +79 -0
  334. package/dist/engines/mongodb/version-maps.js.map +1 -0
  335. package/dist/engines/mongodb/version-validator.js +133 -0
  336. package/dist/engines/mongodb/version-validator.js.map +1 -0
  337. package/dist/engines/mysql/backup.js +210 -0
  338. package/dist/engines/mysql/backup.js.map +1 -0
  339. package/dist/engines/mysql/binary-detection.js +325 -0
  340. package/dist/engines/mysql/binary-detection.js.map +1 -0
  341. package/dist/engines/mysql/binary-manager.js +30 -0
  342. package/dist/engines/mysql/binary-manager.js.map +1 -0
  343. package/dist/engines/mysql/binary-urls.js +87 -0
  344. package/dist/engines/mysql/binary-urls.js.map +1 -0
  345. package/{engines/mysql/hostdb-releases.ts → dist/engines/mysql/hostdb-releases.js} +20 -23
  346. package/dist/engines/mysql/hostdb-releases.js.map +1 -0
  347. package/dist/engines/mysql/index.js +1066 -0
  348. package/dist/engines/mysql/index.js.map +1 -0
  349. package/dist/engines/mysql/restore.js +361 -0
  350. package/dist/engines/mysql/restore.js.map +1 -0
  351. package/dist/engines/mysql/version-maps.js +79 -0
  352. package/dist/engines/mysql/version-maps.js.map +1 -0
  353. package/dist/engines/mysql/version-validator.js +266 -0
  354. package/dist/engines/mysql/version-validator.js.map +1 -0
  355. package/dist/engines/postgresql/backup.js +118 -0
  356. package/dist/engines/postgresql/backup.js.map +1 -0
  357. package/dist/engines/postgresql/binary-manager.js +85 -0
  358. package/dist/engines/postgresql/binary-manager.js.map +1 -0
  359. package/dist/engines/postgresql/binary-urls.js +80 -0
  360. package/dist/engines/postgresql/binary-urls.js.map +1 -0
  361. package/dist/engines/postgresql/hostdb-releases.js +21 -0
  362. package/dist/engines/postgresql/hostdb-releases.js.map +1 -0
  363. package/dist/engines/postgresql/index.js +852 -0
  364. package/dist/engines/postgresql/index.js.map +1 -0
  365. package/dist/engines/postgresql/remote-version.js +109 -0
  366. package/dist/engines/postgresql/remote-version.js.map +1 -0
  367. package/dist/engines/postgresql/restore.js +254 -0
  368. package/dist/engines/postgresql/restore.js.map +1 -0
  369. package/dist/engines/postgresql/version-maps.js +73 -0
  370. package/dist/engines/postgresql/version-maps.js.map +1 -0
  371. package/dist/engines/postgresql/version-validator.js +286 -0
  372. package/dist/engines/postgresql/version-validator.js.map +1 -0
  373. package/dist/engines/qdrant/api-client.js +50 -0
  374. package/dist/engines/qdrant/api-client.js.map +1 -0
  375. package/dist/engines/qdrant/backup.js +115 -0
  376. package/dist/engines/qdrant/backup.js.map +1 -0
  377. package/dist/engines/qdrant/binary-manager.js +31 -0
  378. package/dist/engines/qdrant/binary-manager.js.map +1 -0
  379. package/dist/engines/qdrant/binary-urls.js +92 -0
  380. package/dist/engines/qdrant/binary-urls.js.map +1 -0
  381. package/dist/engines/qdrant/cli-utils.js +39 -0
  382. package/dist/engines/qdrant/cli-utils.js.map +1 -0
  383. package/dist/engines/qdrant/hostdb-releases.js +21 -0
  384. package/dist/engines/qdrant/hostdb-releases.js.map +1 -0
  385. package/dist/engines/qdrant/index.js +1002 -0
  386. package/dist/engines/qdrant/index.js.map +1 -0
  387. package/dist/engines/qdrant/restore.js +154 -0
  388. package/dist/engines/qdrant/restore.js.map +1 -0
  389. package/dist/engines/qdrant/version-maps.js +67 -0
  390. package/dist/engines/qdrant/version-maps.js.map +1 -0
  391. package/dist/engines/qdrant/version-validator.js +109 -0
  392. package/dist/engines/qdrant/version-validator.js.map +1 -0
  393. package/dist/engines/questdb/backup.js +191 -0
  394. package/dist/engines/questdb/backup.js.map +1 -0
  395. package/dist/engines/questdb/binary-manager.js +247 -0
  396. package/dist/engines/questdb/binary-manager.js.map +1 -0
  397. package/dist/engines/questdb/binary-urls.js +27 -0
  398. package/dist/engines/questdb/binary-urls.js.map +1 -0
  399. package/dist/engines/questdb/hostdb-releases.js +21 -0
  400. package/dist/engines/questdb/hostdb-releases.js.map +1 -0
  401. package/dist/engines/questdb/index.js +814 -0
  402. package/dist/engines/questdb/index.js.map +1 -0
  403. package/dist/engines/questdb/restore.js +202 -0
  404. package/dist/engines/questdb/restore.js.map +1 -0
  405. package/dist/engines/questdb/version-maps.js +33 -0
  406. package/dist/engines/questdb/version-maps.js.map +1 -0
  407. package/dist/engines/questdb/version-validator.js +99 -0
  408. package/dist/engines/questdb/version-validator.js.map +1 -0
  409. package/dist/engines/redis/backup.js +292 -0
  410. package/dist/engines/redis/backup.js.map +1 -0
  411. package/dist/engines/redis/binary-manager.js +32 -0
  412. package/dist/engines/redis/binary-manager.js.map +1 -0
  413. package/dist/engines/redis/binary-urls.js +96 -0
  414. package/dist/engines/redis/binary-urls.js.map +1 -0
  415. package/dist/engines/redis/cli-utils.js +38 -0
  416. package/dist/engines/redis/cli-utils.js.map +1 -0
  417. package/dist/engines/redis/hostdb-releases.js +21 -0
  418. package/dist/engines/redis/hostdb-releases.js.map +1 -0
  419. package/dist/engines/redis/index.js +1263 -0
  420. package/dist/engines/redis/index.js.map +1 -0
  421. package/dist/engines/redis/restore.js +338 -0
  422. package/dist/engines/redis/restore.js.map +1 -0
  423. package/dist/engines/redis/version-maps.js +70 -0
  424. package/dist/engines/redis/version-maps.js.map +1 -0
  425. package/dist/engines/redis/version-validator.js +109 -0
  426. package/dist/engines/redis/version-validator.js.map +1 -0
  427. package/dist/engines/sqlite/binary-manager.js +39 -0
  428. package/dist/engines/sqlite/binary-manager.js.map +1 -0
  429. package/{engines/sqlite/binary-urls.ts → dist/engines/sqlite/binary-urls.js} +11 -16
  430. package/dist/engines/sqlite/binary-urls.js.map +1 -0
  431. package/dist/engines/sqlite/hostdb-releases.js +21 -0
  432. package/dist/engines/sqlite/hostdb-releases.js.map +1 -0
  433. package/dist/engines/sqlite/index.js +493 -0
  434. package/dist/engines/sqlite/index.js.map +1 -0
  435. package/dist/engines/sqlite/registry.js +163 -0
  436. package/dist/engines/sqlite/registry.js.map +1 -0
  437. package/dist/engines/sqlite/scanner.js +12 -0
  438. package/dist/engines/sqlite/scanner.js.map +1 -0
  439. package/dist/engines/sqlite/version-maps.js +57 -0
  440. package/dist/engines/sqlite/version-maps.js.map +1 -0
  441. package/dist/engines/surrealdb/backup.js +97 -0
  442. package/dist/engines/surrealdb/backup.js.map +1 -0
  443. package/dist/engines/surrealdb/binary-manager.js +33 -0
  444. package/dist/engines/surrealdb/binary-manager.js.map +1 -0
  445. package/dist/engines/surrealdb/binary-urls.js +33 -0
  446. package/dist/engines/surrealdb/binary-urls.js.map +1 -0
  447. package/dist/engines/surrealdb/cli-utils.js +147 -0
  448. package/dist/engines/surrealdb/cli-utils.js.map +1 -0
  449. package/dist/engines/surrealdb/hostdb-releases.js +21 -0
  450. package/dist/engines/surrealdb/hostdb-releases.js.map +1 -0
  451. package/dist/engines/surrealdb/index.js +1022 -0
  452. package/dist/engines/surrealdb/index.js.map +1 -0
  453. package/dist/engines/surrealdb/restore.js +224 -0
  454. package/dist/engines/surrealdb/restore.js.map +1 -0
  455. package/dist/engines/surrealdb/version-maps.js +36 -0
  456. package/dist/engines/surrealdb/version-maps.js.map +1 -0
  457. package/dist/engines/tigerbeetle/backup.js +36 -0
  458. package/dist/engines/tigerbeetle/backup.js.map +1 -0
  459. package/dist/engines/tigerbeetle/binary-manager.js +72 -0
  460. package/dist/engines/tigerbeetle/binary-manager.js.map +1 -0
  461. package/dist/engines/tigerbeetle/binary-urls.js +49 -0
  462. package/dist/engines/tigerbeetle/binary-urls.js.map +1 -0
  463. package/dist/engines/tigerbeetle/hostdb-releases.js +21 -0
  464. package/dist/engines/tigerbeetle/hostdb-releases.js.map +1 -0
  465. package/dist/engines/tigerbeetle/index.js +559 -0
  466. package/dist/engines/tigerbeetle/index.js.map +1 -0
  467. package/dist/engines/tigerbeetle/restore.js +91 -0
  468. package/dist/engines/tigerbeetle/restore.js.map +1 -0
  469. package/{engines/tigerbeetle/version-maps.ts → dist/engines/tigerbeetle/version-maps.js} +22 -31
  470. package/dist/engines/tigerbeetle/version-maps.js.map +1 -0
  471. package/dist/engines/tigerbeetle/version-validator.js +108 -0
  472. package/dist/engines/tigerbeetle/version-validator.js.map +1 -0
  473. package/dist/engines/typedb/backup.js +129 -0
  474. package/dist/engines/typedb/backup.js.map +1 -0
  475. package/dist/engines/typedb/binary-manager.js +151 -0
  476. package/dist/engines/typedb/binary-manager.js.map +1 -0
  477. package/dist/engines/typedb/binary-urls.js +33 -0
  478. package/dist/engines/typedb/binary-urls.js.map +1 -0
  479. package/dist/engines/typedb/cli-utils.js +163 -0
  480. package/dist/engines/typedb/cli-utils.js.map +1 -0
  481. package/dist/engines/typedb/hostdb-releases.js +21 -0
  482. package/dist/engines/typedb/hostdb-releases.js.map +1 -0
  483. package/dist/engines/typedb/index.js +1003 -0
  484. package/dist/engines/typedb/index.js.map +1 -0
  485. package/dist/engines/typedb/restore.js +279 -0
  486. package/dist/engines/typedb/restore.js.map +1 -0
  487. package/dist/engines/typedb/version-maps.js +40 -0
  488. package/dist/engines/typedb/version-maps.js.map +1 -0
  489. package/dist/engines/typedb/version-validator.js +103 -0
  490. package/dist/engines/typedb/version-validator.js.map +1 -0
  491. package/dist/engines/valkey/backup.js +292 -0
  492. package/dist/engines/valkey/backup.js.map +1 -0
  493. package/dist/engines/valkey/binary-manager.js +33 -0
  494. package/dist/engines/valkey/binary-manager.js.map +1 -0
  495. package/dist/engines/valkey/binary-urls.js +98 -0
  496. package/dist/engines/valkey/binary-urls.js.map +1 -0
  497. package/dist/engines/valkey/cli-utils.js +38 -0
  498. package/dist/engines/valkey/cli-utils.js.map +1 -0
  499. package/dist/engines/valkey/hostdb-releases.js +21 -0
  500. package/dist/engines/valkey/hostdb-releases.js.map +1 -0
  501. package/dist/engines/valkey/index.js +1257 -0
  502. package/dist/engines/valkey/index.js.map +1 -0
  503. package/dist/engines/valkey/restore.js +340 -0
  504. package/dist/engines/valkey/restore.js.map +1 -0
  505. package/dist/engines/valkey/version-maps.js +70 -0
  506. package/dist/engines/valkey/version-maps.js.map +1 -0
  507. package/dist/engines/valkey/version-validator.js +112 -0
  508. package/dist/engines/valkey/version-validator.js.map +1 -0
  509. package/dist/engines/weaviate/api-client.js +50 -0
  510. package/dist/engines/weaviate/api-client.js.map +1 -0
  511. package/dist/engines/weaviate/backup.js +95 -0
  512. package/dist/engines/weaviate/backup.js.map +1 -0
  513. package/dist/engines/weaviate/binary-manager.js +58 -0
  514. package/dist/engines/weaviate/binary-manager.js.map +1 -0
  515. package/dist/engines/weaviate/binary-urls.js +92 -0
  516. package/dist/engines/weaviate/binary-urls.js.map +1 -0
  517. package/dist/engines/weaviate/cli-utils.js +39 -0
  518. package/dist/engines/weaviate/cli-utils.js.map +1 -0
  519. package/dist/engines/weaviate/hostdb-releases.js +21 -0
  520. package/dist/engines/weaviate/hostdb-releases.js.map +1 -0
  521. package/dist/engines/weaviate/index.js +871 -0
  522. package/dist/engines/weaviate/index.js.map +1 -0
  523. package/dist/engines/weaviate/restore.js +185 -0
  524. package/dist/engines/weaviate/restore.js.map +1 -0
  525. package/dist/engines/weaviate/version-maps.js +67 -0
  526. package/dist/engines/weaviate/version-maps.js.map +1 -0
  527. package/dist/engines/weaviate/version-validator.js +109 -0
  528. package/dist/engines/weaviate/version-validator.js.map +1 -0
  529. package/dist/types/index.js +102 -0
  530. package/dist/types/index.js.map +1 -0
  531. package/package.json +12 -9
  532. package/bin/cli.js +0 -68
  533. package/cli/bin.ts +0 -10
  534. package/cli/commands/attach.ts +0 -139
  535. package/cli/commands/backup.ts +0 -290
  536. package/cli/commands/backups.ts +0 -247
  537. package/cli/commands/clone.ts +0 -159
  538. package/cli/commands/config.ts +0 -367
  539. package/cli/commands/connect.ts +0 -684
  540. package/cli/commands/create.ts +0 -1201
  541. package/cli/commands/databases.ts +0 -630
  542. package/cli/commands/delete.ts +0 -133
  543. package/cli/commands/deps.ts +0 -342
  544. package/cli/commands/detach.ts +0 -107
  545. package/cli/commands/doctor.ts +0 -689
  546. package/cli/commands/duckdb.ts +0 -273
  547. package/cli/commands/edit.ts +0 -683
  548. package/cli/commands/engines.ts +0 -1914
  549. package/cli/commands/export.ts +0 -544
  550. package/cli/commands/info.ts +0 -340
  551. package/cli/commands/list.ts +0 -284
  552. package/cli/commands/logs.ts +0 -102
  553. package/cli/commands/menu/backup-handlers.ts +0 -1571
  554. package/cli/commands/menu/container-handlers.ts +0 -2288
  555. package/cli/commands/menu/engine-handlers.ts +0 -355
  556. package/cli/commands/menu/index.ts +0 -342
  557. package/cli/commands/menu/settings-handlers.ts +0 -365
  558. package/cli/commands/menu/shared.ts +0 -23
  559. package/cli/commands/menu/shell-handlers.ts +0 -1811
  560. package/cli/commands/menu/sql-handlers.ts +0 -231
  561. package/cli/commands/menu/update-handlers.ts +0 -378
  562. package/cli/commands/menu/validators.ts +0 -8
  563. package/cli/commands/ports.ts +0 -211
  564. package/cli/commands/pull.ts +0 -223
  565. package/cli/commands/query.ts +0 -241
  566. package/cli/commands/restore.ts +0 -587
  567. package/cli/commands/run.ts +0 -178
  568. package/cli/commands/self-update.ts +0 -121
  569. package/cli/commands/sqlite.ts +0 -273
  570. package/cli/commands/start.ts +0 -218
  571. package/cli/commands/stop.ts +0 -241
  572. package/cli/commands/url.ts +0 -104
  573. package/cli/commands/users.ts +0 -264
  574. package/cli/commands/version.ts +0 -55
  575. package/cli/commands/which.ts +0 -290
  576. package/cli/constants.ts +0 -233
  577. package/cli/helpers.ts +0 -1593
  578. package/cli/index.ts +0 -162
  579. package/cli/ui/prompts.ts +0 -1525
  580. package/cli/ui/spinner.ts +0 -88
  581. package/cli/ui/theme.ts +0 -128
  582. package/cli/utils/file-follower.ts +0 -93
  583. package/config/backup-formats.ts +0 -446
  584. package/config/defaults.ts +0 -56
  585. package/config/engine-defaults.ts +0 -336
  586. package/config/engines-registry.ts +0 -150
  587. package/config/engines.schema.json +0 -135
  588. package/config/os-dependencies.ts +0 -888
  589. package/config/paths.ts +0 -200
  590. package/core/backup-restore.ts +0 -330
  591. package/core/base-binary-manager.ts +0 -562
  592. package/core/base-document-binary-manager.ts +0 -523
  593. package/core/base-embedded-binary-manager.ts +0 -547
  594. package/core/base-server-binary-manager.ts +0 -523
  595. package/core/config-manager.ts +0 -652
  596. package/core/container-manager.ts +0 -787
  597. package/core/credential-generator.ts +0 -93
  598. package/core/credential-manager.ts +0 -259
  599. package/core/dblab-utils.ts +0 -113
  600. package/core/dependency-manager.ts +0 -512
  601. package/core/docker-exporter.ts +0 -1345
  602. package/core/error-handler.ts +0 -419
  603. package/core/fs-error-utils.ts +0 -82
  604. package/core/homebrew-version-manager.ts +0 -352
  605. package/core/hostdb-client.ts +0 -344
  606. package/core/hostdb-metadata.ts +0 -350
  607. package/core/hostdb-releases-factory.ts +0 -237
  608. package/core/library-env.ts +0 -118
  609. package/core/pgweb-utils.ts +0 -62
  610. package/core/platform-service.ts +0 -829
  611. package/core/port-manager.ts +0 -165
  612. package/core/process-manager.ts +0 -576
  613. package/core/pull-manager.ts +0 -511
  614. package/core/query-parser.ts +0 -514
  615. package/core/spawn-utils.ts +0 -122
  616. package/core/start-with-retry.ts +0 -130
  617. package/core/test-cleanup.ts +0 -108
  618. package/core/tls-generator.ts +0 -116
  619. package/core/transaction-manager.ts +0 -158
  620. package/core/update-manager.ts +0 -308
  621. package/core/version-migration.ts +0 -346
  622. package/core/version-utils.ts +0 -104
  623. package/engines/base-engine.ts +0 -340
  624. package/engines/clickhouse/README.md +0 -231
  625. package/engines/clickhouse/backup.ts +0 -398
  626. package/engines/clickhouse/binary-manager.ts +0 -201
  627. package/engines/clickhouse/binary-urls.ts +0 -125
  628. package/engines/clickhouse/cli-utils.ts +0 -176
  629. package/engines/clickhouse/hostdb-releases.ts +0 -30
  630. package/engines/clickhouse/index.ts +0 -1345
  631. package/engines/clickhouse/restore.ts +0 -466
  632. package/engines/clickhouse/version-maps.ts +0 -95
  633. package/engines/clickhouse/version-validator.ts +0 -154
  634. package/engines/cockroachdb/README.md +0 -170
  635. package/engines/cockroachdb/backup.ts +0 -376
  636. package/engines/cockroachdb/binary-manager.ts +0 -45
  637. package/engines/cockroachdb/binary-urls.ts +0 -40
  638. package/engines/cockroachdb/cli-utils.ts +0 -384
  639. package/engines/cockroachdb/hostdb-releases.ts +0 -26
  640. package/engines/cockroachdb/index.ts +0 -1276
  641. package/engines/cockroachdb/restore.ts +0 -455
  642. package/engines/cockroachdb/version-maps.ts +0 -42
  643. package/engines/couchdb/README.md +0 -257
  644. package/engines/couchdb/api-client.ts +0 -81
  645. package/engines/couchdb/backup.ts +0 -137
  646. package/engines/couchdb/binary-manager.ts +0 -86
  647. package/engines/couchdb/binary-urls.ts +0 -115
  648. package/engines/couchdb/hostdb-releases.ts +0 -23
  649. package/engines/couchdb/index.ts +0 -1429
  650. package/engines/couchdb/restore.ts +0 -290
  651. package/engines/couchdb/version-maps.ts +0 -78
  652. package/engines/couchdb/version-validator.ts +0 -111
  653. package/engines/duckdb/README.md +0 -154
  654. package/engines/duckdb/binary-manager.ts +0 -45
  655. package/engines/duckdb/hostdb-releases.ts +0 -23
  656. package/engines/duckdb/index.ts +0 -749
  657. package/engines/duckdb/registry.ts +0 -303
  658. package/engines/duckdb/scanner.ts +0 -22
  659. package/engines/duckdb/version-maps.ts +0 -78
  660. package/engines/duckdb/version-validator.ts +0 -78
  661. package/engines/ferretdb/README.md +0 -262
  662. package/engines/ferretdb/backup.ts +0 -173
  663. package/engines/ferretdb/binary-manager.ts +0 -1095
  664. package/engines/ferretdb/binary-urls.ts +0 -183
  665. package/engines/ferretdb/index.ts +0 -1907
  666. package/engines/ferretdb/restore.ts +0 -357
  667. package/engines/file-based-utils.ts +0 -262
  668. package/engines/index.ts +0 -131
  669. package/engines/influxdb/README.md +0 -180
  670. package/engines/influxdb/api-client.ts +0 -64
  671. package/engines/influxdb/backup.ts +0 -160
  672. package/engines/influxdb/binary-manager.ts +0 -110
  673. package/engines/influxdb/binary-urls.ts +0 -69
  674. package/engines/influxdb/hostdb-releases.ts +0 -23
  675. package/engines/influxdb/index.ts +0 -1272
  676. package/engines/influxdb/restore.ts +0 -417
  677. package/engines/influxdb/version-maps.ts +0 -75
  678. package/engines/influxdb/version-validator.ts +0 -128
  679. package/engines/mariadb/README.md +0 -141
  680. package/engines/mariadb/backup.ts +0 -233
  681. package/engines/mariadb/binary-manager.ts +0 -45
  682. package/engines/mariadb/hostdb-releases.ts +0 -23
  683. package/engines/mariadb/index.ts +0 -1300
  684. package/engines/mariadb/restore.ts +0 -447
  685. package/engines/mariadb/version-maps.ts +0 -72
  686. package/engines/mariadb/version-validator.ts +0 -181
  687. package/engines/meilisearch/README.md +0 -255
  688. package/engines/meilisearch/api-client.ts +0 -61
  689. package/engines/meilisearch/backup.ts +0 -233
  690. package/engines/meilisearch/binary-manager.ts +0 -43
  691. package/engines/meilisearch/binary-urls.ts +0 -69
  692. package/engines/meilisearch/hostdb-releases.ts +0 -26
  693. package/engines/meilisearch/index.ts +0 -1292
  694. package/engines/meilisearch/restore.ts +0 -219
  695. package/engines/meilisearch/version-maps.ts +0 -78
  696. package/engines/meilisearch/version-validator.ts +0 -128
  697. package/engines/mongodb/README.md +0 -162
  698. package/engines/mongodb/backup.ts +0 -127
  699. package/engines/mongodb/binary-manager.ts +0 -48
  700. package/engines/mongodb/binary-urls.ts +0 -63
  701. package/engines/mongodb/cli-utils.ts +0 -171
  702. package/engines/mongodb/hostdb-releases.ts +0 -91
  703. package/engines/mongodb/index.ts +0 -1118
  704. package/engines/mongodb/restore.ts +0 -361
  705. package/engines/mongodb/version-maps.ts +0 -91
  706. package/engines/mongodb/version-validator.ts +0 -160
  707. package/engines/mysql/README.md +0 -142
  708. package/engines/mysql/backup.ts +0 -270
  709. package/engines/mysql/binary-detection.ts +0 -408
  710. package/engines/mysql/binary-manager.ts +0 -42
  711. package/engines/mysql/binary-urls.ts +0 -104
  712. package/engines/mysql/index.ts +0 -1361
  713. package/engines/mysql/restore.ts +0 -500
  714. package/engines/mysql/version-maps.ts +0 -91
  715. package/engines/mysql/version-validator.ts +0 -369
  716. package/engines/postgresql/README.md +0 -158
  717. package/engines/postgresql/backup.ts +0 -151
  718. package/engines/postgresql/binary-manager.ts +0 -114
  719. package/engines/postgresql/binary-urls.ts +0 -99
  720. package/engines/postgresql/hostdb-releases.ts +0 -26
  721. package/engines/postgresql/index.ts +0 -1143
  722. package/engines/postgresql/remote-version.ts +0 -161
  723. package/engines/postgresql/restore.ts +0 -342
  724. package/engines/postgresql/version-maps.ts +0 -83
  725. package/engines/postgresql/version-validator.ts +0 -413
  726. package/engines/qdrant/README.md +0 -222
  727. package/engines/qdrant/api-client.ts +0 -61
  728. package/engines/qdrant/backup.ts +0 -165
  729. package/engines/qdrant/binary-manager.ts +0 -43
  730. package/engines/qdrant/binary-urls.ts +0 -115
  731. package/engines/qdrant/cli-utils.ts +0 -43
  732. package/engines/qdrant/hostdb-releases.ts +0 -23
  733. package/engines/qdrant/index.ts +0 -1312
  734. package/engines/qdrant/restore.ts +0 -203
  735. package/engines/qdrant/version-maps.ts +0 -78
  736. package/engines/qdrant/version-validator.ts +0 -128
  737. package/engines/questdb/README.md +0 -334
  738. package/engines/questdb/backup.ts +0 -220
  739. package/engines/questdb/binary-manager.ts +0 -310
  740. package/engines/questdb/binary-urls.ts +0 -34
  741. package/engines/questdb/hostdb-releases.ts +0 -23
  742. package/engines/questdb/index.ts +0 -1023
  743. package/engines/questdb/restore.ts +0 -260
  744. package/engines/questdb/version-maps.ts +0 -37
  745. package/engines/questdb/version-validator.ts +0 -121
  746. package/engines/redis/README.md +0 -173
  747. package/engines/redis/backup.ts +0 -389
  748. package/engines/redis/binary-manager.ts +0 -44
  749. package/engines/redis/binary-urls.ts +0 -117
  750. package/engines/redis/cli-utils.ts +0 -42
  751. package/engines/redis/hostdb-releases.ts +0 -23
  752. package/engines/redis/index.ts +0 -1583
  753. package/engines/redis/restore.ts +0 -443
  754. package/engines/redis/version-maps.ts +0 -81
  755. package/engines/redis/version-validator.ts +0 -131
  756. package/engines/sqlite/README.md +0 -162
  757. package/engines/sqlite/binary-manager.ts +0 -52
  758. package/engines/sqlite/hostdb-releases.ts +0 -23
  759. package/engines/sqlite/index.ts +0 -641
  760. package/engines/sqlite/registry.ts +0 -198
  761. package/engines/sqlite/scanner.ts +0 -22
  762. package/engines/sqlite/version-maps.ts +0 -64
  763. package/engines/surrealdb/README.md +0 -218
  764. package/engines/surrealdb/backup.ts +0 -131
  765. package/engines/surrealdb/binary-manager.ts +0 -45
  766. package/engines/surrealdb/binary-urls.ts +0 -40
  767. package/engines/surrealdb/cli-utils.ts +0 -173
  768. package/engines/surrealdb/hostdb-releases.ts +0 -23
  769. package/engines/surrealdb/index.ts +0 -1246
  770. package/engines/surrealdb/restore.ts +0 -302
  771. package/engines/surrealdb/version-maps.ts +0 -41
  772. package/engines/tigerbeetle/README.md +0 -61
  773. package/engines/tigerbeetle/backup.ts +0 -49
  774. package/engines/tigerbeetle/binary-manager.ts +0 -95
  775. package/engines/tigerbeetle/binary-urls.ts +0 -62
  776. package/engines/tigerbeetle/hostdb-releases.ts +0 -26
  777. package/engines/tigerbeetle/index.ts +0 -746
  778. package/engines/tigerbeetle/restore.ts +0 -130
  779. package/engines/tigerbeetle/version-validator.ts +0 -126
  780. package/engines/typedb/backup.ts +0 -167
  781. package/engines/typedb/binary-manager.ts +0 -200
  782. package/engines/typedb/binary-urls.ts +0 -40
  783. package/engines/typedb/cli-utils.ts +0 -210
  784. package/engines/typedb/hostdb-releases.ts +0 -23
  785. package/engines/typedb/index.ts +0 -1275
  786. package/engines/typedb/restore.ts +0 -377
  787. package/engines/typedb/version-maps.ts +0 -48
  788. package/engines/typedb/version-validator.ts +0 -127
  789. package/engines/valkey/README.md +0 -219
  790. package/engines/valkey/backup.ts +0 -389
  791. package/engines/valkey/binary-manager.ts +0 -45
  792. package/engines/valkey/binary-urls.ts +0 -122
  793. package/engines/valkey/cli-utils.ts +0 -42
  794. package/engines/valkey/hostdb-releases.ts +0 -23
  795. package/engines/valkey/index.ts +0 -1585
  796. package/engines/valkey/restore.ts +0 -446
  797. package/engines/valkey/version-maps.ts +0 -81
  798. package/engines/valkey/version-validator.ts +0 -131
  799. package/engines/weaviate/README.md +0 -302
  800. package/engines/weaviate/api-client.ts +0 -61
  801. package/engines/weaviate/backup.ts +0 -145
  802. package/engines/weaviate/binary-manager.ts +0 -80
  803. package/engines/weaviate/binary-urls.ts +0 -115
  804. package/engines/weaviate/cli-utils.ts +0 -43
  805. package/engines/weaviate/hostdb-releases.ts +0 -23
  806. package/engines/weaviate/index.ts +0 -1139
  807. package/engines/weaviate/restore.ts +0 -235
  808. package/engines/weaviate/version-maps.ts +0 -78
  809. package/engines/weaviate/version-validator.ts +0 -128
  810. package/types/index.ts +0 -624
  811. /package/{config → dist/config}/engines.json +0 -0
@@ -0,0 +1,1016 @@
1
+ /**
2
+ * CockroachDB Engine Implementation
3
+ *
4
+ * CockroachDB is a distributed SQL database with PostgreSQL wire protocol compatibility.
5
+ * It provides horizontal scaling, strong consistency, and built-in survivability.
6
+ *
7
+ * Key characteristics:
8
+ * - Default SQL port: 26257
9
+ * - HTTP UI port: SQL port + 1 (default 26258)
10
+ * - Uses PostgreSQL wire protocol for client connections
11
+ * - Single binary: `cockroach` (handles server, sql client, and admin tasks)
12
+ * - Default database: `defaultdb`
13
+ * - Default user: `root` (no password in insecure mode)
14
+ */
15
+ import { spawn } from 'child_process';
16
+ import { existsSync } from 'fs';
17
+ import { mkdir, writeFile, readFile, unlink } from 'fs/promises';
18
+ import { join } from 'path';
19
+ import { BaseEngine } from '../base-engine.js';
20
+ import { paths } from '../../config/paths.js';
21
+ import { getEngineDefaults } from '../../config/defaults.js';
22
+ import { platformService } from '../../core/platform-service.js';
23
+ import { configManager } from '../../core/config-manager.js';
24
+ import { logDebug, logWarning, assertValidUsername, } from '../../core/error-handler.js';
25
+ import { findBinary } from '../../core/dependency-manager.js';
26
+ import { processManager } from '../../core/process-manager.js';
27
+ import { cockroachdbBinaryManager } from './binary-manager.js';
28
+ import { getBinaryUrl } from './binary-urls.js';
29
+ import { normalizeVersion, SUPPORTED_MAJOR_VERSIONS, COCKROACHDB_VERSION_MAP, } from './version-maps.js';
30
+ import { fetchAvailableVersions as fetchHostdbVersions } from './hostdb-releases.js';
31
+ import { detectBackupFormat as detectBackupFormatImpl, restoreBackup, } from './restore.js';
32
+ import { createBackup } from './backup.js';
33
+ import { validateCockroachIdentifier, escapeCockroachIdentifier, escapeSqlValue, parseCsvLine, parseCsvRecords, isInsecureConnection, } from './cli-utils.js';
34
+ import { parseCSVToQueryResult } from '../../core/query-parser.js';
35
+ const ENGINE = 'cockroachdb';
36
+ const engineDef = getEngineDefaults(ENGINE);
37
+ export class CockroachDBEngine extends BaseEngine {
38
+ name = ENGINE;
39
+ displayName = 'CockroachDB';
40
+ defaultPort = engineDef.defaultPort;
41
+ supportedVersions = SUPPORTED_MAJOR_VERSIONS;
42
+ // Get platform info for binary operations
43
+ getPlatformInfo() {
44
+ return platformService.getPlatformInfo();
45
+ }
46
+ // Fetch available versions from hostdb (dynamically or from cache/fallback)
47
+ async fetchAvailableVersions() {
48
+ return fetchHostdbVersions();
49
+ }
50
+ // Get binary download URL from hostdb
51
+ getBinaryUrl(version, platform, arch) {
52
+ return getBinaryUrl(version, platform, arch);
53
+ }
54
+ // Resolves version string to full version (e.g., '25' -> '25.4.2')
55
+ resolveFullVersion(version) {
56
+ if (/^\d+\.\d+\.\d+$/.test(version)) {
57
+ return version;
58
+ }
59
+ return COCKROACHDB_VERSION_MAP[version] || version;
60
+ }
61
+ // Get the path where binaries for a version would be installed
62
+ getBinaryPath(version) {
63
+ const fullVersion = this.resolveFullVersion(version);
64
+ const { platform: p, arch: a } = this.getPlatformInfo();
65
+ return paths.getBinaryPath({
66
+ engine: 'cockroachdb',
67
+ version: fullVersion,
68
+ platform: p,
69
+ arch: a,
70
+ });
71
+ }
72
+ // Verify that CockroachDB binaries are available
73
+ async verifyBinary(binPath) {
74
+ const ext = platformService.getExecutableExtension();
75
+ const cockroachPath = join(binPath, 'bin', `cockroach${ext}`);
76
+ return existsSync(cockroachPath);
77
+ }
78
+ // Check if a specific CockroachDB version is installed (downloaded)
79
+ async isBinaryInstalled(version) {
80
+ const { platform, arch } = this.getPlatformInfo();
81
+ return cockroachdbBinaryManager.isInstalled(version, platform, arch);
82
+ }
83
+ /**
84
+ * Ensure CockroachDB binaries are available for a specific version
85
+ * Downloads from hostdb if not already installed
86
+ * Returns the path to the bin directory
87
+ */
88
+ async ensureBinaries(version, onProgress) {
89
+ const { platform, arch } = this.getPlatformInfo();
90
+ const binPath = await cockroachdbBinaryManager.ensureInstalled(version, platform, arch, onProgress);
91
+ // Register binary in config
92
+ const ext = platformService.getExecutableExtension();
93
+ const cockroachPath = join(binPath, 'bin', `cockroach${ext}`);
94
+ if (existsSync(cockroachPath)) {
95
+ await configManager.setBinaryPath('cockroach', cockroachPath, 'bundled');
96
+ }
97
+ return binPath;
98
+ }
99
+ /**
100
+ * Initialize a new CockroachDB data directory
101
+ * Creates the directory structure for CockroachDB's storage
102
+ */
103
+ async initDataDir(containerName, _version, _options = {}) {
104
+ const dataDir = paths.getContainerDataPath(containerName, {
105
+ engine: ENGINE,
106
+ });
107
+ // Create data directory
108
+ await mkdir(dataDir, { recursive: true });
109
+ logDebug(`Created CockroachDB data directory: ${dataDir}`);
110
+ return dataDir;
111
+ }
112
+ // Get the path to cockroach binary for a version
113
+ async getCockroachPath(version) {
114
+ const { platform, arch } = this.getPlatformInfo();
115
+ const fullVersion = normalizeVersion(version);
116
+ const ext = platformService.getExecutableExtension();
117
+ const binPath = paths.getBinaryPath({
118
+ engine: 'cockroachdb',
119
+ version: fullVersion,
120
+ platform,
121
+ arch,
122
+ });
123
+ const cockroachPath = join(binPath, 'bin', `cockroach${ext}`);
124
+ if (existsSync(cockroachPath)) {
125
+ return cockroachPath;
126
+ }
127
+ throw new Error(`CockroachDB ${version} is not installed. Run: spindb engines download cockroachdb ${version}`);
128
+ }
129
+ /**
130
+ * Start CockroachDB server
131
+ */
132
+ async start(container, onProgress) {
133
+ const { name, port, version, binaryPath } = container;
134
+ // Check if already running
135
+ const alreadyRunning = await processManager.isRunning(name, {
136
+ engine: ENGINE,
137
+ });
138
+ if (alreadyRunning) {
139
+ return {
140
+ port,
141
+ connectionString: this.getConnectionString(container),
142
+ };
143
+ }
144
+ // Get CockroachDB binary path
145
+ let cockroachBinary = null;
146
+ const ext = platformService.getExecutableExtension();
147
+ if (binaryPath && existsSync(binaryPath)) {
148
+ const serverPath = join(binaryPath, 'bin', `cockroach${ext}`);
149
+ if (existsSync(serverPath)) {
150
+ cockroachBinary = serverPath;
151
+ logDebug(`Using stored binary path: ${cockroachBinary}`);
152
+ }
153
+ }
154
+ if (!cockroachBinary) {
155
+ try {
156
+ cockroachBinary = await this.getCockroachPath(version);
157
+ }
158
+ catch (error) {
159
+ const originalMessage = error instanceof Error ? error.message : String(error);
160
+ throw new Error(`CockroachDB ${version} is not installed. Run: spindb engines download cockroachdb ${version}\n` +
161
+ ` Original error: ${originalMessage}`);
162
+ }
163
+ }
164
+ const containerDir = paths.getContainerPath(name, { engine: ENGINE });
165
+ const dataDir = paths.getContainerDataPath(name, { engine: ENGINE });
166
+ const logFile = join(containerDir, 'cockroach.log');
167
+ const pidFile = join(containerDir, 'cockroach.pid');
168
+ const httpPort = port + 1; // HTTP admin UI port
169
+ onProgress?.({ stage: 'starting', message: 'Starting CockroachDB...' });
170
+ logDebug(`Starting CockroachDB with data dir: ${dataDir}`);
171
+ // CockroachDB start command
172
+ // Using --insecure for local development (no TLS)
173
+ const args = [
174
+ 'start-single-node',
175
+ '--insecure',
176
+ '--store',
177
+ dataDir,
178
+ '--listen-addr',
179
+ `127.0.0.1:${port}`,
180
+ '--http-addr',
181
+ `127.0.0.1:${httpPort}`,
182
+ '--pid-file',
183
+ pidFile,
184
+ '--log-dir',
185
+ containerDir,
186
+ ];
187
+ // On Unix, use --background flag which forks a daemon process
188
+ // On Windows, don't use --background - Windows doesn't have the same fork model
189
+ // and CockroachDB's background mode can fail silently. Instead, we detach manually.
190
+ const isWindows = process.platform === 'win32';
191
+ if (!isWindows) {
192
+ args.push('--background');
193
+ }
194
+ // IMPORTANT: Use 'ignore' for all stdio on all platforms.
195
+ // Using 'pipe' keeps file descriptors open which prevents proc.unref() from
196
+ // allowing Node.js to exit, causing spawn timeouts even when the process starts successfully.
197
+ const proc = spawn(cockroachBinary, args, {
198
+ stdio: ['ignore', 'ignore', 'ignore'],
199
+ detached: true,
200
+ // On Windows, set cwd to container directory to ensure proper file handle behavior
201
+ cwd: isWindows ? containerDir : undefined,
202
+ // On Windows, hide the console window to prevent it from blocking
203
+ windowsHide: true,
204
+ });
205
+ // On Windows without --background, write PID file ourselves
206
+ // (On Unix, --background makes CockroachDB write the daemon PID)
207
+ if (isWindows && proc.pid) {
208
+ try {
209
+ await writeFile(pidFile, proc.pid.toString(), 'utf-8');
210
+ logDebug(`Wrote PID file: ${pidFile} (pid: ${proc.pid})`);
211
+ }
212
+ catch (err) {
213
+ // PID file write failed - kill the process and fail fast
214
+ // Without the PID file, we can't stop the container later
215
+ const errMsg = `Failed to write PID file: ${err instanceof Error ? err.message : String(err)}`;
216
+ logDebug(errMsg);
217
+ try {
218
+ process.kill(proc.pid, 'SIGTERM');
219
+ }
220
+ catch {
221
+ // Process may have already exited
222
+ }
223
+ throw new Error(errMsg);
224
+ }
225
+ }
226
+ // Wait for the process to spawn
227
+ // On Windows, the 'spawn' event doesn't fire reliably with detached processes,
228
+ // so we use a simple delay and let waitForReady() handle detection.
229
+ // On Unix with --background, we wait for the spawn event.
230
+ if (isWindows) {
231
+ // Add error handler to catch spawn failures on Windows
232
+ await new Promise((resolve, reject) => {
233
+ proc.on('error', (err) => {
234
+ logDebug(`CockroachDB spawn error on Windows: ${err}`);
235
+ reject(err);
236
+ });
237
+ proc.unref();
238
+ logDebug(`Windows: waiting fixed delay for CockroachDB to start (pid: ${proc.pid})`);
239
+ setTimeout(resolve, 3000);
240
+ });
241
+ }
242
+ else {
243
+ const spawnTimeout = 30000; // 30 seconds to spawn
244
+ await new Promise((resolve, reject) => {
245
+ const timeoutId = setTimeout(() => {
246
+ reject(new Error(`CockroachDB process failed to spawn within ${spawnTimeout}ms`));
247
+ }, spawnTimeout);
248
+ proc.on('error', (err) => {
249
+ clearTimeout(timeoutId);
250
+ logDebug(`CockroachDB spawn error: ${err}`);
251
+ reject(err);
252
+ });
253
+ proc.on('spawn', () => {
254
+ clearTimeout(timeoutId);
255
+ logDebug(`CockroachDB process spawned (pid: ${proc.pid})`);
256
+ proc.unref();
257
+ setTimeout(resolve, 500);
258
+ });
259
+ });
260
+ }
261
+ // Wait for server to be ready
262
+ // Windows needs a longer timeout since CockroachDB initialization takes more time
263
+ const timeout = isWindows ? 120000 : 60000;
264
+ logDebug(`Waiting for CockroachDB server to be ready on port ${port}... (timeout: ${timeout}ms)`);
265
+ const ready = await this.waitForReady(port, version, timeout);
266
+ logDebug(`waitForReady returned: ${ready}`);
267
+ if (!ready) {
268
+ // Clean up the spawned process and PID file before throwing
269
+ try {
270
+ const pidStr = await readFile(pidFile, 'utf-8').catch(() => null);
271
+ if (pidStr) {
272
+ const pid = parseInt(pidStr.trim(), 10);
273
+ if (!isNaN(pid)) {
274
+ logDebug(`Cleaning up failed CockroachDB process (pid: ${pid})`);
275
+ await platformService.terminateProcess(pid, true);
276
+ }
277
+ }
278
+ await unlink(pidFile).catch(() => { });
279
+ }
280
+ catch {
281
+ // Ignore cleanup errors
282
+ }
283
+ throw new Error(`CockroachDB failed to start within timeout. Check logs at: ${logFile}`);
284
+ }
285
+ return {
286
+ port,
287
+ connectionString: this.getConnectionString(container),
288
+ };
289
+ }
290
+ // Wait for CockroachDB to be ready
291
+ async waitForReady(port, version, timeoutMs = 60000) {
292
+ logDebug(`waitForReady called for port ${port}, version ${version}`);
293
+ const startTime = Date.now();
294
+ const checkInterval = 500;
295
+ let cockroach;
296
+ try {
297
+ logDebug('Getting cockroach binary path...');
298
+ cockroach = await this.getCockroachPath(version);
299
+ logDebug(`Got cockroach binary path: ${cockroach}`);
300
+ }
301
+ catch (err) {
302
+ const errorMessage = err instanceof Error ? err.message : String(err);
303
+ logDebug(`Error getting cockroach binary path: ${errorMessage}`);
304
+ logWarning(`CockroachDB binary not found, cannot verify server is ready: ${errorMessage}`);
305
+ return false;
306
+ }
307
+ logDebug(`Starting connection loop, timeout: ${timeoutMs}ms`);
308
+ let attempt = 0;
309
+ while (Date.now() - startTime < timeoutMs) {
310
+ attempt++;
311
+ logDebug(`Connection attempt ${attempt}...`);
312
+ try {
313
+ const args = [
314
+ 'sql',
315
+ '--insecure',
316
+ '--host',
317
+ `127.0.0.1:${port}`,
318
+ '--execute',
319
+ 'SELECT 1',
320
+ ];
321
+ await new Promise((resolve, reject) => {
322
+ const proc = spawn(cockroach, args, {
323
+ stdio: ['ignore', 'pipe', 'pipe'],
324
+ });
325
+ proc.on('close', (code) => {
326
+ logDebug(`Client process closed with code ${code}`);
327
+ if (code === 0)
328
+ resolve();
329
+ else
330
+ reject(new Error(`Exit code ${code}`));
331
+ });
332
+ proc.on('error', (err) => {
333
+ logDebug(`Client process error: ${err}`);
334
+ reject(err);
335
+ });
336
+ });
337
+ logDebug(`CockroachDB ready on port ${port}`);
338
+ return true;
339
+ }
340
+ catch (err) {
341
+ logDebug(`Attempt ${attempt} failed: ${err}`);
342
+ await new Promise((resolve) => setTimeout(resolve, checkInterval));
343
+ }
344
+ }
345
+ logWarning(`CockroachDB did not become ready within ${timeoutMs}ms`);
346
+ return false;
347
+ }
348
+ /**
349
+ * Stop CockroachDB server
350
+ */
351
+ async stop(container) {
352
+ const { name, port } = container;
353
+ const containerDir = paths.getContainerPath(name, { engine: ENGINE });
354
+ const pidFile = join(containerDir, 'cockroach.pid');
355
+ logDebug(`Stopping CockroachDB container "${name}" on port ${port}`);
356
+ // Find PID by checking the process using cross-platform helper
357
+ let pid = null;
358
+ // Try to find CockroachDB process by port
359
+ try {
360
+ const pids = await platformService.findProcessByPort(port);
361
+ if (pids.length > 0) {
362
+ pid = pids[0];
363
+ }
364
+ }
365
+ catch {
366
+ // Ignore
367
+ }
368
+ // Kill process if found
369
+ if (pid && platformService.isProcessRunning(pid)) {
370
+ logDebug(`Killing CockroachDB process ${pid}`);
371
+ try {
372
+ await platformService.terminateProcess(pid, false);
373
+ // Wait for graceful termination
374
+ // On Windows, CockroachDB's RocksDB uses memory-mapped files that
375
+ // take longer to release, so we wait longer to avoid EBUSY errors
376
+ const gracefulWait = process.platform === 'win32' ? 5000 : 2000;
377
+ await new Promise((resolve) => setTimeout(resolve, gracefulWait));
378
+ if (platformService.isProcessRunning(pid)) {
379
+ logWarning(`Graceful termination failed, force killing ${pid}`);
380
+ await platformService.terminateProcess(pid, true);
381
+ // Additional wait after force kill on Windows for file handle release
382
+ if (process.platform === 'win32') {
383
+ await new Promise((resolve) => setTimeout(resolve, 3000));
384
+ }
385
+ }
386
+ }
387
+ catch (error) {
388
+ logDebug(`Process termination error: ${error}`);
389
+ }
390
+ }
391
+ // Cleanup PID file
392
+ if (existsSync(pidFile)) {
393
+ try {
394
+ await unlink(pidFile);
395
+ }
396
+ catch {
397
+ // Ignore
398
+ }
399
+ }
400
+ // Kill pgweb if running for this container
401
+ await this.stopPgweb(name);
402
+ logDebug('CockroachDB stopped');
403
+ }
404
+ // Get CockroachDB server status
405
+ async status(container) {
406
+ const { port, version } = container;
407
+ // Try to connect
408
+ try {
409
+ const cockroach = await this.getCockroachPath(version);
410
+ const args = [
411
+ 'sql',
412
+ '--insecure',
413
+ '--host',
414
+ `127.0.0.1:${port}`,
415
+ '--execute',
416
+ 'SELECT 1',
417
+ ];
418
+ await new Promise((resolve, reject) => {
419
+ const proc = spawn(cockroach, args, {
420
+ stdio: ['ignore', 'pipe', 'pipe'],
421
+ });
422
+ proc.on('close', (code) => {
423
+ if (code === 0)
424
+ resolve();
425
+ else
426
+ reject(new Error(`Exit code ${code}`));
427
+ });
428
+ proc.on('error', reject);
429
+ });
430
+ return { running: true, message: 'CockroachDB is running' };
431
+ }
432
+ catch {
433
+ return { running: false, message: 'CockroachDB is not running' };
434
+ }
435
+ }
436
+ // Detect backup format
437
+ async detectBackupFormat(filePath) {
438
+ return detectBackupFormatImpl(filePath);
439
+ }
440
+ /**
441
+ * Restore a backup
442
+ */
443
+ async restore(container, backupPath, options = {}) {
444
+ const { name, port, version } = container;
445
+ return restoreBackup(backupPath, {
446
+ containerName: name,
447
+ port,
448
+ database: options.database || container.database || 'defaultdb',
449
+ version,
450
+ clean: options.clean,
451
+ });
452
+ }
453
+ /**
454
+ * Get connection string
455
+ * Format: postgresql://root@127.0.0.1:PORT/DATABASE?sslmode=disable
456
+ */
457
+ getConnectionString(container, database) {
458
+ const { port } = container;
459
+ const db = database || container.database || 'defaultdb';
460
+ return `postgresql://root@127.0.0.1:${port}/${db}?sslmode=disable`;
461
+ }
462
+ // Open cockroach sql interactive shell
463
+ async connect(container, database) {
464
+ const { port, version } = container;
465
+ const db = database || container.database || 'defaultdb';
466
+ const cockroach = await this.getCockroachPath(version);
467
+ const spawnOptions = {
468
+ stdio: 'inherit',
469
+ };
470
+ return new Promise((resolve, reject) => {
471
+ const proc = spawn(cockroach, ['sql', '--insecure', '--host', `127.0.0.1:${port}`, '--database', db], spawnOptions);
472
+ proc.on('error', reject);
473
+ proc.on('close', () => resolve());
474
+ });
475
+ }
476
+ /**
477
+ * Create a new database
478
+ */
479
+ async createDatabase(container, database) {
480
+ const { port, version } = container;
481
+ // Validate database identifier to prevent SQL injection
482
+ validateCockroachIdentifier(database, 'database');
483
+ const escapedDb = escapeCockroachIdentifier(database);
484
+ const cockroach = await this.getCockroachPath(version);
485
+ const args = [
486
+ 'sql',
487
+ '--insecure',
488
+ '--host',
489
+ `127.0.0.1:${port}`,
490
+ '--execute',
491
+ `CREATE DATABASE IF NOT EXISTS ${escapedDb}`,
492
+ ];
493
+ await new Promise((resolve, reject) => {
494
+ const proc = spawn(cockroach, args, {
495
+ stdio: ['ignore', 'pipe', 'pipe'],
496
+ });
497
+ let stderr = '';
498
+ proc.stderr?.on('data', (data) => {
499
+ stderr += data.toString();
500
+ });
501
+ proc.on('close', (code) => {
502
+ if (code === 0) {
503
+ logDebug(`Created CockroachDB database: ${database}`);
504
+ resolve();
505
+ }
506
+ else {
507
+ reject(new Error(`Failed to create database: ${stderr}`));
508
+ }
509
+ });
510
+ proc.on('error', reject);
511
+ });
512
+ }
513
+ /**
514
+ * Drop a database
515
+ */
516
+ async dropDatabase(container, database) {
517
+ const { port, version } = container;
518
+ // Don't allow dropping system databases
519
+ const systemDatabases = ['defaultdb', 'postgres', 'system'];
520
+ if (systemDatabases.includes(database.toLowerCase())) {
521
+ throw new Error(`Cannot drop system database: ${database}`);
522
+ }
523
+ // Validate database identifier to prevent SQL injection
524
+ validateCockroachIdentifier(database, 'database');
525
+ const escapedDb = escapeCockroachIdentifier(database);
526
+ const cockroach = await this.getCockroachPath(version);
527
+ const args = [
528
+ 'sql',
529
+ '--insecure',
530
+ '--host',
531
+ `127.0.0.1:${port}`,
532
+ '--execute',
533
+ `DROP DATABASE IF EXISTS ${escapedDb}`,
534
+ ];
535
+ await new Promise((resolve, reject) => {
536
+ const proc = spawn(cockroach, args, {
537
+ stdio: ['ignore', 'pipe', 'pipe'],
538
+ });
539
+ let stderr = '';
540
+ proc.stderr?.on('data', (data) => {
541
+ stderr += data.toString();
542
+ });
543
+ proc.on('close', (code) => {
544
+ if (code === 0) {
545
+ logDebug(`Dropped CockroachDB database: ${database}`);
546
+ resolve();
547
+ }
548
+ else {
549
+ reject(new Error(`Failed to drop database: ${stderr}`));
550
+ }
551
+ });
552
+ proc.on('error', reject);
553
+ });
554
+ }
555
+ /**
556
+ * Get the database size in bytes
557
+ */
558
+ async getDatabaseSize(container) {
559
+ const { port, version, database } = container;
560
+ const db = database || 'defaultdb';
561
+ try {
562
+ const cockroach = await this.getCockroachPath(version);
563
+ validateCockroachIdentifier(db, 'database');
564
+ // CockroachDB query to get database size
565
+ const query = `SELECT sum(range_size_mb) * 1024 * 1024 as size_bytes FROM [SHOW RANGES FROM DATABASE ${escapeCockroachIdentifier(db)}]`;
566
+ const result = await new Promise((resolve, reject) => {
567
+ const args = [
568
+ 'sql',
569
+ '--insecure',
570
+ '--host',
571
+ `127.0.0.1:${port}`,
572
+ '--database',
573
+ db,
574
+ '--execute',
575
+ query,
576
+ '--format=csv',
577
+ ];
578
+ const proc = spawn(cockroach, args, {
579
+ stdio: ['ignore', 'pipe', 'pipe'],
580
+ });
581
+ let stdout = '';
582
+ proc.stdout?.on('data', (data) => {
583
+ stdout += data.toString();
584
+ });
585
+ proc.on('close', (code) => {
586
+ if (code === 0)
587
+ resolve(stdout.trim());
588
+ else
589
+ reject(new Error(`Exit code ${code}`));
590
+ });
591
+ proc.on('error', reject);
592
+ });
593
+ // Parse CSV output - skip header
594
+ const lines = result.split('\n');
595
+ if (lines.length >= 2) {
596
+ const size = parseFloat(lines[1]);
597
+ return isNaN(size) ? null : Math.round(size);
598
+ }
599
+ return null;
600
+ }
601
+ catch {
602
+ return null;
603
+ }
604
+ }
605
+ /**
606
+ * Dump from a remote CockroachDB connection
607
+ * Uses cockroach sql to export schema and data
608
+ *
609
+ * Connection string format: postgresql://[user[:password]@]host[:port][/database][?sslmode=...]
610
+ *
611
+ * Supports both insecure (local dev) and secure (production) connections:
612
+ * - sslmode=disable or localhost without sslmode: uses --insecure flag
613
+ * - Other SSL modes: passes connection string directly (handles certs via URL params)
614
+ */
615
+ async dumpFromConnectionString(connectionString, outputPath) {
616
+ // Parse connection string
617
+ let url;
618
+ try {
619
+ url = new URL(connectionString);
620
+ }
621
+ catch {
622
+ // Redact credentials before including in error message
623
+ const sanitized = connectionString.replace(/\/\/([^@]+)@/, '//***@');
624
+ throw new Error(`Invalid connection string: ${sanitized}\n` +
625
+ 'Expected format: postgresql://[user[:password]@]host[:port][/database][?sslmode=...]');
626
+ }
627
+ const host = url.hostname || '127.0.0.1';
628
+ const port = parseInt(url.port, 10) || 26257;
629
+ const database = url.pathname.replace(/^\//, '') || 'defaultdb';
630
+ logDebug(`Connecting to remote CockroachDB at ${host}:${port} (db: ${database})`);
631
+ // For remote dump, we need a local cockroach binary
632
+ // Try multiple methods to find an installed version
633
+ let cockroach = null;
634
+ // 1. Try 'cockroach' key in config
635
+ const cachedCockroach = await configManager.getBinaryPath('cockroach');
636
+ if (cachedCockroach && existsSync(cachedCockroach)) {
637
+ cockroach = cachedCockroach;
638
+ logDebug(`Found cockroach binary via 'cockroach' config key: ${cockroach}`);
639
+ }
640
+ // 2. Try to find via dependency manager (checks config + system PATH)
641
+ if (!cockroach) {
642
+ const binaryResult = await findBinary('cockroach');
643
+ if (binaryResult?.path && existsSync(binaryResult.path)) {
644
+ cockroach = binaryResult.path;
645
+ logDebug(`Found cockroach binary via dependency manager: ${cockroach}`);
646
+ }
647
+ }
648
+ // 3. Try to use any downloaded version via getCockroachPath
649
+ if (!cockroach) {
650
+ for (const version of SUPPORTED_MAJOR_VERSIONS) {
651
+ try {
652
+ cockroach = await this.getCockroachPath(version);
653
+ logDebug(`Found cockroach binary for version ${version}: ${cockroach}`);
654
+ break;
655
+ }
656
+ catch {
657
+ // Version not installed, try next
658
+ }
659
+ }
660
+ }
661
+ if (!cockroach) {
662
+ throw new Error('CockroachDB binary not found. Run: spindb engines download cockroachdb 25\n' +
663
+ 'A local CockroachDB binary is needed to dump from remote connections.');
664
+ }
665
+ const lines = [];
666
+ lines.push('-- CockroachDB backup generated by SpinDB');
667
+ lines.push(`-- Source: ${host}:${port}`);
668
+ lines.push(`-- Database: ${database}`);
669
+ lines.push(`-- Date: ${new Date().toISOString()}`);
670
+ lines.push('');
671
+ // Build connection args using --url to preserve auth/SSL settings
672
+ const connArgs = ['sql', '--url', connectionString];
673
+ // Only add --insecure for local dev or explicit sslmode=disable
674
+ if (isInsecureConnection(connectionString)) {
675
+ connArgs.push('--insecure');
676
+ }
677
+ // Get list of tables
678
+ const tablesQuery = `SELECT table_name FROM information_schema.tables WHERE table_schema = 'public' AND table_type = 'BASE TABLE' ORDER BY table_name`;
679
+ const tablesResult = await this.execRemoteQuery(cockroach, connArgs, tablesQuery);
680
+ // Parse CSV output properly to handle quoted identifiers
681
+ const tableRecords = parseCsvRecords(tablesResult, true); // Skip header
682
+ const tables = tableRecords
683
+ .map((line) => {
684
+ const fields = parseCsvLine(line);
685
+ return fields.length > 0 ? fields[0].value : '';
686
+ })
687
+ .filter((t) => t);
688
+ logDebug(`Found ${tables.length} tables in database ${database}`);
689
+ for (const table of tables) {
690
+ // Table names from information_schema are safe (already unquoted by CSV parser)
691
+ // Only validate that we got a non-empty name
692
+ if (!table) {
693
+ continue;
694
+ }
695
+ lines.push(`-- Table: ${table}`);
696
+ lines.push('');
697
+ // Get CREATE TABLE - use proper identifier escaping
698
+ try {
699
+ const createQuery = `SHOW CREATE TABLE ${escapeCockroachIdentifier(table)}`;
700
+ const createResult = await this.execRemoteQuery(cockroach, connArgs, createQuery);
701
+ // Parse CSV output safely using record-aware parser
702
+ // Format is: table_name,create_statement (create statement may contain newlines)
703
+ const createRecords = parseCsvRecords(createResult, true); // Skip header
704
+ if (createRecords.length > 0) {
705
+ const columns = parseCsvLine(createRecords[0]);
706
+ if (columns.length >= 2) {
707
+ // Second column is the CREATE TABLE statement
708
+ const createStatement = columns[1].value.trim();
709
+ lines.push(createStatement + ';');
710
+ }
711
+ else {
712
+ logWarning(`Unexpected SHOW CREATE TABLE output for ${table}`);
713
+ }
714
+ }
715
+ lines.push('');
716
+ }
717
+ catch (error) {
718
+ logWarning(`Could not get CREATE TABLE for ${table}: ${error}`);
719
+ continue;
720
+ }
721
+ // Export table data
722
+ try {
723
+ // Get column names first
724
+ // Escape single quotes in table name for string literal comparison
725
+ const escapedTableForString = table.replace(/'/g, "''");
726
+ const columnsQuery = `SELECT column_name FROM information_schema.columns WHERE table_schema = 'public' AND table_name = '${escapedTableForString}' ORDER BY ordinal_position`;
727
+ const columnsResult = await this.execRemoteQuery(cockroach, connArgs, columnsQuery);
728
+ // Parse each CSV record properly to handle quoted column names
729
+ const columnRecords = parseCsvRecords(columnsResult, true); // Skip header
730
+ const columns = columnRecords
731
+ .map((record) => {
732
+ const fields = parseCsvLine(record);
733
+ return fields.length > 0 ? fields[0].value.trim() : '';
734
+ })
735
+ .filter((c) => c);
736
+ if (columns.length === 0) {
737
+ logDebug(`No columns found for table ${table}, skipping data export`);
738
+ continue;
739
+ }
740
+ // Get all rows - use proper identifier escaping
741
+ const dataQuery = `SELECT * FROM ${escapeCockroachIdentifier(table)}`;
742
+ const dataResult = await this.execRemoteQuery(cockroach, connArgs, dataQuery);
743
+ // Use record-aware parser to handle fields with embedded newlines
744
+ const dataRecords = parseCsvRecords(dataResult, true); // Skip header
745
+ if (dataRecords.length > 0) {
746
+ lines.push(`-- Data for ${table}`);
747
+ for (const dataRecord of dataRecords) {
748
+ const fields = parseCsvLine(dataRecord);
749
+ if (fields.length !== columns.length) {
750
+ logWarning(`Column count mismatch for table ${table}: expected ${columns.length}, got ${fields.length}`);
751
+ continue;
752
+ }
753
+ const escapedCols = columns
754
+ .map((c) => escapeCockroachIdentifier(c))
755
+ .join(', ');
756
+ const escapedVals = fields
757
+ .map((f) => escapeSqlValue(f.value, f.wasQuoted))
758
+ .join(', ');
759
+ lines.push(`INSERT INTO ${escapeCockroachIdentifier(table)} (${escapedCols}) VALUES (${escapedVals});`);
760
+ }
761
+ lines.push('');
762
+ }
763
+ }
764
+ catch (error) {
765
+ logWarning(`Could not export data for table ${table}: ${error}`);
766
+ }
767
+ }
768
+ // Write to file
769
+ const content = lines.join('\n');
770
+ await writeFile(outputPath, content, 'utf-8');
771
+ return {
772
+ filePath: outputPath,
773
+ warnings: tables.length === 0
774
+ ? [`Database '${database}' has no tables`]
775
+ : undefined,
776
+ };
777
+ }
778
+ // Helper to execute a query on a remote CockroachDB
779
+ async execRemoteQuery(cockroach, connArgs, query) {
780
+ return new Promise((resolve, reject) => {
781
+ const args = [...connArgs, '--execute', query, '--format=csv'];
782
+ const proc = spawn(cockroach, args, {
783
+ stdio: ['ignore', 'pipe', 'pipe'],
784
+ });
785
+ let stdout = '';
786
+ let stderr = '';
787
+ proc.stdout.on('data', (data) => {
788
+ stdout += data.toString();
789
+ });
790
+ proc.stderr.on('data', (data) => {
791
+ stderr += data.toString();
792
+ });
793
+ proc.on('close', (code) => {
794
+ if (code === 0) {
795
+ resolve(stdout);
796
+ }
797
+ else {
798
+ reject(new Error(stderr || `Exit code ${code}`));
799
+ }
800
+ });
801
+ proc.on('error', reject);
802
+ });
803
+ }
804
+ // Create a backup
805
+ async backup(container, outputPath, options) {
806
+ return createBackup(container, outputPath, options);
807
+ }
808
+ // Run a SQL file or inline SQL statement
809
+ async runScript(container, options) {
810
+ const { port, version } = container;
811
+ const db = options.database || container.database || 'defaultdb';
812
+ const cockroach = await this.getCockroachPath(version);
813
+ if (options.file) {
814
+ // Run SQL file
815
+ const args = [
816
+ 'sql',
817
+ '--insecure',
818
+ '--host',
819
+ `127.0.0.1:${port}`,
820
+ '--database',
821
+ db,
822
+ '--file',
823
+ options.file,
824
+ ];
825
+ await new Promise((resolve, reject) => {
826
+ const proc = spawn(cockroach, args, {
827
+ stdio: 'inherit',
828
+ });
829
+ proc.on('error', reject);
830
+ proc.on('close', (code) => {
831
+ if (code === 0) {
832
+ resolve();
833
+ }
834
+ else if (code === null) {
835
+ reject(new Error('cockroach sql was terminated by a signal'));
836
+ }
837
+ else {
838
+ reject(new Error(`cockroach sql exited with code ${code}`));
839
+ }
840
+ });
841
+ });
842
+ }
843
+ else if (options.sql) {
844
+ // Run inline SQL via stdin
845
+ const args = [
846
+ 'sql',
847
+ '--insecure',
848
+ '--host',
849
+ `127.0.0.1:${port}`,
850
+ '--database',
851
+ db,
852
+ ];
853
+ await new Promise((resolve, reject) => {
854
+ const proc = spawn(cockroach, args, {
855
+ stdio: ['pipe', 'inherit', 'inherit'],
856
+ });
857
+ proc.on('error', reject);
858
+ proc.on('close', (code) => {
859
+ if (code === 0) {
860
+ resolve();
861
+ }
862
+ else if (code === null) {
863
+ reject(new Error('cockroach sql was terminated by a signal'));
864
+ }
865
+ else {
866
+ reject(new Error(`cockroach sql exited with code ${code}`));
867
+ }
868
+ });
869
+ proc.stdin?.write(options.sql);
870
+ proc.stdin?.end();
871
+ });
872
+ }
873
+ else {
874
+ throw new Error('Either file or sql option must be provided');
875
+ }
876
+ }
877
+ /**
878
+ * Execute a SQL query and return structured results
879
+ */
880
+ async executeQuery(container, query, options) {
881
+ const { port, version } = container;
882
+ const db = options?.database || container.database || 'defaultdb';
883
+ const cockroach = await this.getCockroachPath(version);
884
+ return new Promise((resolve, reject) => {
885
+ const args = [
886
+ 'sql',
887
+ '--insecure',
888
+ '--host',
889
+ `127.0.0.1:${port}`,
890
+ '--database',
891
+ db,
892
+ '--execute',
893
+ query,
894
+ '--format=csv',
895
+ ];
896
+ const proc = spawn(cockroach, args, {
897
+ stdio: ['ignore', 'pipe', 'pipe'],
898
+ });
899
+ let stdout = '';
900
+ let stderr = '';
901
+ proc.stdout?.on('data', (data) => {
902
+ stdout += data.toString();
903
+ });
904
+ proc.stderr?.on('data', (data) => {
905
+ stderr += data.toString();
906
+ });
907
+ proc.on('error', reject);
908
+ proc.on('close', (code) => {
909
+ if (code !== 0) {
910
+ reject(new Error(stderr || `cockroach sql exited with code ${code}`));
911
+ return;
912
+ }
913
+ try {
914
+ resolve(parseCSVToQueryResult(stdout));
915
+ }
916
+ catch (error) {
917
+ reject(new Error(`Failed to parse query result: ${error instanceof Error ? error.message : error}`));
918
+ }
919
+ });
920
+ });
921
+ }
922
+ /**
923
+ * List all user databases, excluding system databases (defaultdb, postgres, system).
924
+ */
925
+ async listDatabases(container) {
926
+ const { port, version } = container;
927
+ const cockroach = await this.getCockroachPath(version);
928
+ return new Promise((resolve, reject) => {
929
+ const args = [
930
+ 'sql',
931
+ '--insecure',
932
+ '--host',
933
+ `127.0.0.1:${port}`,
934
+ '--execute',
935
+ `SHOW DATABASES`,
936
+ '--format=csv',
937
+ ];
938
+ const proc = spawn(cockroach, args, {
939
+ stdio: ['ignore', 'pipe', 'pipe'],
940
+ });
941
+ let stdout = '';
942
+ let stderr = '';
943
+ proc.stdout?.on('data', (data) => {
944
+ stdout += data.toString();
945
+ });
946
+ proc.stderr?.on('data', (data) => {
947
+ stderr += data.toString();
948
+ });
949
+ proc.on('error', reject);
950
+ proc.on('close', (code) => {
951
+ if (code !== 0) {
952
+ reject(new Error(stderr || `cockroach sql exited with code ${code}`));
953
+ return;
954
+ }
955
+ // Parse CSV output (first column is database_name, skip header)
956
+ const systemDatabases = ['defaultdb', 'postgres', 'system'];
957
+ const lines = stdout.trim().split('\n');
958
+ const databases = lines
959
+ .slice(1) // Skip header
960
+ .map((line) => line.split(',')[0].trim())
961
+ .filter((db) => db.length > 0 && !systemDatabases.includes(db));
962
+ resolve(databases);
963
+ });
964
+ });
965
+ }
966
+ async createUser(container, options) {
967
+ const { username, password, database } = options;
968
+ assertValidUsername(username);
969
+ const { port, version } = container;
970
+ const db = database || container.database || 'defaultdb';
971
+ validateCockroachIdentifier(username, 'user');
972
+ validateCockroachIdentifier(db, 'database');
973
+ const escapedUser = escapeCockroachIdentifier(username);
974
+ const escapedDb = escapeCockroachIdentifier(db);
975
+ const cockroach = await this.getCockroachPath(version);
976
+ // CockroachDB in insecure mode doesn't support passwords.
977
+ // Create user without password and grant privileges.
978
+ // SQL is sent via stdin to avoid shell escaping issues with --execute.
979
+ const sql = `CREATE USER IF NOT EXISTS ${escapedUser}; GRANT ALL ON DATABASE ${escapedDb} TO ${escapedUser};`;
980
+ const args = ['sql', '--insecure', '--host', `127.0.0.1:${port}`];
981
+ await new Promise((resolve, reject) => {
982
+ const proc = spawn(cockroach, args, {
983
+ stdio: ['pipe', 'pipe', 'pipe'],
984
+ });
985
+ let stderr = '';
986
+ proc.stderr?.on('data', (data) => {
987
+ stderr += data.toString();
988
+ });
989
+ proc.on('close', (code) => {
990
+ if (code === 0) {
991
+ resolve();
992
+ }
993
+ else {
994
+ reject(new Error(`Failed to create user: ${stderr}`));
995
+ }
996
+ });
997
+ proc.on('error', reject);
998
+ proc.stdin?.write(sql);
999
+ proc.stdin?.end();
1000
+ });
1001
+ // In insecure mode, connections don't use passwords
1002
+ const connectionString = `postgresql://${encodeURIComponent(username)}@127.0.0.1:${port}/${db}?sslmode=disable`;
1003
+ return {
1004
+ username,
1005
+ // CockroachDB insecure mode does not enforce password authentication,
1006
+ // but we return the caller-provided password for credential file consistency.
1007
+ password,
1008
+ connectionString,
1009
+ engine: container.engine,
1010
+ container: container.name,
1011
+ database: db,
1012
+ };
1013
+ }
1014
+ }
1015
+ export const cockroachdbEngine = new CockroachDBEngine();
1016
+ //# sourceMappingURL=index.js.map