@njdamstra/appwrite-utils-cli 1.8.9

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 (392) hide show
  1. package/CHANGELOG.md +19 -0
  2. package/README.md +1133 -0
  3. package/dist/adapters/AdapterFactory.d.ts +94 -0
  4. package/dist/adapters/AdapterFactory.js +405 -0
  5. package/dist/adapters/DatabaseAdapter.d.ts +233 -0
  6. package/dist/adapters/DatabaseAdapter.js +50 -0
  7. package/dist/adapters/LegacyAdapter.d.ts +50 -0
  8. package/dist/adapters/LegacyAdapter.js +612 -0
  9. package/dist/adapters/TablesDBAdapter.d.ts +45 -0
  10. package/dist/adapters/TablesDBAdapter.js +571 -0
  11. package/dist/adapters/index.d.ts +11 -0
  12. package/dist/adapters/index.js +12 -0
  13. package/dist/backups/operations/bucketBackup.d.ts +19 -0
  14. package/dist/backups/operations/bucketBackup.js +197 -0
  15. package/dist/backups/operations/collectionBackup.d.ts +30 -0
  16. package/dist/backups/operations/collectionBackup.js +201 -0
  17. package/dist/backups/operations/comprehensiveBackup.d.ts +25 -0
  18. package/dist/backups/operations/comprehensiveBackup.js +238 -0
  19. package/dist/backups/schemas/bucketManifest.d.ts +93 -0
  20. package/dist/backups/schemas/bucketManifest.js +33 -0
  21. package/dist/backups/schemas/comprehensiveManifest.d.ts +108 -0
  22. package/dist/backups/schemas/comprehensiveManifest.js +32 -0
  23. package/dist/backups/tracking/centralizedTracking.d.ts +34 -0
  24. package/dist/backups/tracking/centralizedTracking.js +274 -0
  25. package/dist/cli/commands/configCommands.d.ts +8 -0
  26. package/dist/cli/commands/configCommands.js +166 -0
  27. package/dist/cli/commands/databaseCommands.d.ts +13 -0
  28. package/dist/cli/commands/databaseCommands.js +554 -0
  29. package/dist/cli/commands/functionCommands.d.ts +7 -0
  30. package/dist/cli/commands/functionCommands.js +330 -0
  31. package/dist/cli/commands/schemaCommands.d.ts +7 -0
  32. package/dist/cli/commands/schemaCommands.js +169 -0
  33. package/dist/cli/commands/storageCommands.d.ts +5 -0
  34. package/dist/cli/commands/storageCommands.js +143 -0
  35. package/dist/cli/commands/transferCommands.d.ts +5 -0
  36. package/dist/cli/commands/transferCommands.js +384 -0
  37. package/dist/collections/attributes.d.ts +13 -0
  38. package/dist/collections/attributes.js +1364 -0
  39. package/dist/collections/indexes.d.ts +12 -0
  40. package/dist/collections/indexes.js +217 -0
  41. package/dist/collections/methods.d.ts +19 -0
  42. package/dist/collections/methods.js +682 -0
  43. package/dist/collections/tableOperations.d.ts +86 -0
  44. package/dist/collections/tableOperations.js +434 -0
  45. package/dist/collections/transferOperations.d.ts +8 -0
  46. package/dist/collections/transferOperations.js +412 -0
  47. package/dist/collections/wipeOperations.d.ts +16 -0
  48. package/dist/collections/wipeOperations.js +233 -0
  49. package/dist/config/ConfigManager.d.ts +445 -0
  50. package/dist/config/ConfigManager.js +625 -0
  51. package/dist/config/configMigration.d.ts +87 -0
  52. package/dist/config/configMigration.js +390 -0
  53. package/dist/config/configValidation.d.ts +66 -0
  54. package/dist/config/configValidation.js +358 -0
  55. package/dist/config/index.d.ts +8 -0
  56. package/dist/config/index.js +7 -0
  57. package/dist/config/services/ConfigDiscoveryService.d.ts +126 -0
  58. package/dist/config/services/ConfigDiscoveryService.js +374 -0
  59. package/dist/config/services/ConfigLoaderService.d.ts +129 -0
  60. package/dist/config/services/ConfigLoaderService.js +540 -0
  61. package/dist/config/services/ConfigMergeService.d.ts +208 -0
  62. package/dist/config/services/ConfigMergeService.js +308 -0
  63. package/dist/config/services/ConfigValidationService.d.ts +214 -0
  64. package/dist/config/services/ConfigValidationService.js +310 -0
  65. package/dist/config/services/SessionAuthService.d.ts +225 -0
  66. package/dist/config/services/SessionAuthService.js +456 -0
  67. package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +1 -0
  68. package/dist/config/services/__tests__/ConfigMergeService.test.js +271 -0
  69. package/dist/config/services/index.d.ts +13 -0
  70. package/dist/config/services/index.js +10 -0
  71. package/dist/config/yamlConfig.d.ts +722 -0
  72. package/dist/config/yamlConfig.js +702 -0
  73. package/dist/databases/methods.d.ts +6 -0
  74. package/dist/databases/methods.js +35 -0
  75. package/dist/databases/setup.d.ts +5 -0
  76. package/dist/databases/setup.js +45 -0
  77. package/dist/examples/yamlTerminologyExample.d.ts +42 -0
  78. package/dist/examples/yamlTerminologyExample.js +272 -0
  79. package/dist/functions/deployments.d.ts +4 -0
  80. package/dist/functions/deployments.js +146 -0
  81. package/dist/functions/fnConfigDiscovery.d.ts +3 -0
  82. package/dist/functions/fnConfigDiscovery.js +108 -0
  83. package/dist/functions/methods.d.ts +16 -0
  84. package/dist/functions/methods.js +162 -0
  85. package/dist/functions/pathResolution.d.ts +37 -0
  86. package/dist/functions/pathResolution.js +185 -0
  87. package/dist/functions/templates/count-docs-in-collection/README.md +54 -0
  88. package/dist/functions/templates/count-docs-in-collection/src/main.ts +159 -0
  89. package/dist/functions/templates/count-docs-in-collection/src/request.ts +9 -0
  90. package/dist/functions/templates/hono-typescript/README.md +286 -0
  91. package/dist/functions/templates/hono-typescript/src/adapters/request.ts +74 -0
  92. package/dist/functions/templates/hono-typescript/src/adapters/response.ts +106 -0
  93. package/dist/functions/templates/hono-typescript/src/app.ts +180 -0
  94. package/dist/functions/templates/hono-typescript/src/context.ts +103 -0
  95. package/dist/functions/templates/hono-typescript/src/index.ts +54 -0
  96. package/dist/functions/templates/hono-typescript/src/middleware/appwrite.ts +119 -0
  97. package/dist/functions/templates/typescript-node/README.md +32 -0
  98. package/dist/functions/templates/typescript-node/src/context.ts +103 -0
  99. package/dist/functions/templates/typescript-node/src/index.ts +29 -0
  100. package/dist/functions/templates/uv/README.md +31 -0
  101. package/dist/functions/templates/uv/pyproject.toml +30 -0
  102. package/dist/functions/templates/uv/src/__init__.py +0 -0
  103. package/dist/functions/templates/uv/src/context.py +125 -0
  104. package/dist/functions/templates/uv/src/index.py +46 -0
  105. package/dist/init.d.ts +2 -0
  106. package/dist/init.js +57 -0
  107. package/dist/interactiveCLI.d.ts +31 -0
  108. package/dist/interactiveCLI.js +898 -0
  109. package/dist/main.d.ts +2 -0
  110. package/dist/main.js +1172 -0
  111. package/dist/migrations/afterImportActions.d.ts +17 -0
  112. package/dist/migrations/afterImportActions.js +306 -0
  113. package/dist/migrations/appwriteToX.d.ts +211 -0
  114. package/dist/migrations/appwriteToX.js +491 -0
  115. package/dist/migrations/comprehensiveTransfer.d.ts +147 -0
  116. package/dist/migrations/comprehensiveTransfer.js +1317 -0
  117. package/dist/migrations/dataLoader.d.ts +753 -0
  118. package/dist/migrations/dataLoader.js +1250 -0
  119. package/dist/migrations/importController.d.ts +23 -0
  120. package/dist/migrations/importController.js +268 -0
  121. package/dist/migrations/importDataActions.d.ts +50 -0
  122. package/dist/migrations/importDataActions.js +230 -0
  123. package/dist/migrations/relationships.d.ts +29 -0
  124. package/dist/migrations/relationships.js +204 -0
  125. package/dist/migrations/services/DataTransformationService.d.ts +55 -0
  126. package/dist/migrations/services/DataTransformationService.js +158 -0
  127. package/dist/migrations/services/FileHandlerService.d.ts +75 -0
  128. package/dist/migrations/services/FileHandlerService.js +236 -0
  129. package/dist/migrations/services/ImportOrchestrator.d.ts +97 -0
  130. package/dist/migrations/services/ImportOrchestrator.js +485 -0
  131. package/dist/migrations/services/RateLimitManager.d.ts +138 -0
  132. package/dist/migrations/services/RateLimitManager.js +279 -0
  133. package/dist/migrations/services/RelationshipResolver.d.ts +120 -0
  134. package/dist/migrations/services/RelationshipResolver.js +332 -0
  135. package/dist/migrations/services/UserMappingService.d.ts +109 -0
  136. package/dist/migrations/services/UserMappingService.js +277 -0
  137. package/dist/migrations/services/ValidationService.d.ts +74 -0
  138. package/dist/migrations/services/ValidationService.js +260 -0
  139. package/dist/migrations/transfer.d.ts +26 -0
  140. package/dist/migrations/transfer.js +608 -0
  141. package/dist/migrations/yaml/YamlImportConfigLoader.d.ts +131 -0
  142. package/dist/migrations/yaml/YamlImportConfigLoader.js +383 -0
  143. package/dist/migrations/yaml/YamlImportIntegration.d.ts +93 -0
  144. package/dist/migrations/yaml/YamlImportIntegration.js +341 -0
  145. package/dist/migrations/yaml/generateImportSchemas.d.ts +30 -0
  146. package/dist/migrations/yaml/generateImportSchemas.js +1327 -0
  147. package/dist/schemas/authUser.d.ts +24 -0
  148. package/dist/schemas/authUser.js +17 -0
  149. package/dist/setup.d.ts +2 -0
  150. package/dist/setup.js +5 -0
  151. package/dist/setupCommands.d.ts +58 -0
  152. package/dist/setupCommands.js +490 -0
  153. package/dist/setupController.d.ts +9 -0
  154. package/dist/setupController.js +34 -0
  155. package/dist/shared/attributeMapper.d.ts +20 -0
  156. package/dist/shared/attributeMapper.js +203 -0
  157. package/dist/shared/backupMetadataSchema.d.ts +94 -0
  158. package/dist/shared/backupMetadataSchema.js +38 -0
  159. package/dist/shared/backupTracking.d.ts +18 -0
  160. package/dist/shared/backupTracking.js +176 -0
  161. package/dist/shared/confirmationDialogs.d.ts +75 -0
  162. package/dist/shared/confirmationDialogs.js +236 -0
  163. package/dist/shared/errorUtils.d.ts +54 -0
  164. package/dist/shared/errorUtils.js +95 -0
  165. package/dist/shared/functionManager.d.ts +48 -0
  166. package/dist/shared/functionManager.js +336 -0
  167. package/dist/shared/indexManager.d.ts +24 -0
  168. package/dist/shared/indexManager.js +151 -0
  169. package/dist/shared/jsonSchemaGenerator.d.ts +50 -0
  170. package/dist/shared/jsonSchemaGenerator.js +290 -0
  171. package/dist/shared/logging.d.ts +61 -0
  172. package/dist/shared/logging.js +116 -0
  173. package/dist/shared/messageFormatter.d.ts +39 -0
  174. package/dist/shared/messageFormatter.js +162 -0
  175. package/dist/shared/migrationHelpers.d.ts +61 -0
  176. package/dist/shared/migrationHelpers.js +145 -0
  177. package/dist/shared/operationLogger.d.ts +10 -0
  178. package/dist/shared/operationLogger.js +12 -0
  179. package/dist/shared/operationQueue.d.ts +40 -0
  180. package/dist/shared/operationQueue.js +311 -0
  181. package/dist/shared/operationsTable.d.ts +26 -0
  182. package/dist/shared/operationsTable.js +286 -0
  183. package/dist/shared/operationsTableSchema.d.ts +48 -0
  184. package/dist/shared/operationsTableSchema.js +35 -0
  185. package/dist/shared/progressManager.d.ts +62 -0
  186. package/dist/shared/progressManager.js +215 -0
  187. package/dist/shared/pydanticModelGenerator.d.ts +17 -0
  188. package/dist/shared/pydanticModelGenerator.js +615 -0
  189. package/dist/shared/relationshipExtractor.d.ts +56 -0
  190. package/dist/shared/relationshipExtractor.js +138 -0
  191. package/dist/shared/schemaGenerator.d.ts +40 -0
  192. package/dist/shared/schemaGenerator.js +556 -0
  193. package/dist/shared/selectionDialogs.d.ts +214 -0
  194. package/dist/shared/selectionDialogs.js +544 -0
  195. package/dist/storage/backupCompression.d.ts +20 -0
  196. package/dist/storage/backupCompression.js +67 -0
  197. package/dist/storage/methods.d.ts +32 -0
  198. package/dist/storage/methods.js +472 -0
  199. package/dist/storage/schemas.d.ts +842 -0
  200. package/dist/storage/schemas.js +175 -0
  201. package/dist/types.d.ts +4 -0
  202. package/dist/types.js +3 -0
  203. package/dist/users/methods.d.ts +16 -0
  204. package/dist/users/methods.js +277 -0
  205. package/dist/utils/ClientFactory.d.ts +87 -0
  206. package/dist/utils/ClientFactory.js +212 -0
  207. package/dist/utils/configDiscovery.d.ts +78 -0
  208. package/dist/utils/configDiscovery.js +472 -0
  209. package/dist/utils/configMigration.d.ts +1 -0
  210. package/dist/utils/configMigration.js +261 -0
  211. package/dist/utils/constantsGenerator.d.ts +31 -0
  212. package/dist/utils/constantsGenerator.js +321 -0
  213. package/dist/utils/dataConverters.d.ts +46 -0
  214. package/dist/utils/dataConverters.js +139 -0
  215. package/dist/utils/directoryUtils.d.ts +22 -0
  216. package/dist/utils/directoryUtils.js +59 -0
  217. package/dist/utils/getClientFromConfig.d.ts +39 -0
  218. package/dist/utils/getClientFromConfig.js +199 -0
  219. package/dist/utils/helperFunctions.d.ts +63 -0
  220. package/dist/utils/helperFunctions.js +156 -0
  221. package/dist/utils/index.d.ts +2 -0
  222. package/dist/utils/index.js +2 -0
  223. package/dist/utils/loadConfigs.d.ts +50 -0
  224. package/dist/utils/loadConfigs.js +358 -0
  225. package/dist/utils/pathResolvers.d.ts +53 -0
  226. package/dist/utils/pathResolvers.js +72 -0
  227. package/dist/utils/projectConfig.d.ts +119 -0
  228. package/dist/utils/projectConfig.js +171 -0
  229. package/dist/utils/retryFailedPromises.d.ts +2 -0
  230. package/dist/utils/retryFailedPromises.js +23 -0
  231. package/dist/utils/sessionAuth.d.ts +48 -0
  232. package/dist/utils/sessionAuth.js +164 -0
  233. package/dist/utils/setupFiles.d.ts +4 -0
  234. package/dist/utils/setupFiles.js +1192 -0
  235. package/dist/utils/typeGuards.d.ts +35 -0
  236. package/dist/utils/typeGuards.js +57 -0
  237. package/dist/utils/validationRules.d.ts +43 -0
  238. package/dist/utils/validationRules.js +42 -0
  239. package/dist/utils/versionDetection.d.ts +58 -0
  240. package/dist/utils/versionDetection.js +251 -0
  241. package/dist/utils/yamlConverter.d.ts +100 -0
  242. package/dist/utils/yamlConverter.js +428 -0
  243. package/dist/utils/yamlLoader.d.ts +70 -0
  244. package/dist/utils/yamlLoader.js +267 -0
  245. package/dist/utilsController.d.ts +106 -0
  246. package/dist/utilsController.js +863 -0
  247. package/package.json +75 -0
  248. package/scripts/copy-templates.ts +23 -0
  249. package/src/adapters/AdapterFactory.ts +510 -0
  250. package/src/adapters/DatabaseAdapter.ts +306 -0
  251. package/src/adapters/LegacyAdapter.ts +841 -0
  252. package/src/adapters/TablesDBAdapter.ts +773 -0
  253. package/src/adapters/index.ts +37 -0
  254. package/src/backups/operations/bucketBackup.ts +277 -0
  255. package/src/backups/operations/collectionBackup.ts +310 -0
  256. package/src/backups/operations/comprehensiveBackup.ts +342 -0
  257. package/src/backups/schemas/bucketManifest.ts +78 -0
  258. package/src/backups/schemas/comprehensiveManifest.ts +76 -0
  259. package/src/backups/tracking/centralizedTracking.ts +352 -0
  260. package/src/cli/commands/configCommands.ts +201 -0
  261. package/src/cli/commands/databaseCommands.ts +749 -0
  262. package/src/cli/commands/functionCommands.ts +418 -0
  263. package/src/cli/commands/schemaCommands.ts +200 -0
  264. package/src/cli/commands/storageCommands.ts +152 -0
  265. package/src/cli/commands/transferCommands.ts +457 -0
  266. package/src/collections/attributes.ts +2054 -0
  267. package/src/collections/attributes.ts.backup +1555 -0
  268. package/src/collections/indexes.ts +352 -0
  269. package/src/collections/methods.ts +745 -0
  270. package/src/collections/tableOperations.ts +506 -0
  271. package/src/collections/transferOperations.ts +590 -0
  272. package/src/collections/wipeOperations.ts +346 -0
  273. package/src/config/ConfigManager.ts +808 -0
  274. package/src/config/README.md +274 -0
  275. package/src/config/configMigration.ts +575 -0
  276. package/src/config/configValidation.ts +445 -0
  277. package/src/config/index.ts +10 -0
  278. package/src/config/services/ConfigDiscoveryService.ts +463 -0
  279. package/src/config/services/ConfigLoaderService.ts +740 -0
  280. package/src/config/services/ConfigMergeService.ts +388 -0
  281. package/src/config/services/ConfigValidationService.ts +394 -0
  282. package/src/config/services/SessionAuthService.ts +565 -0
  283. package/src/config/services/__tests__/ConfigMergeService.test.ts +351 -0
  284. package/src/config/services/index.ts +29 -0
  285. package/src/config/yamlConfig.ts +761 -0
  286. package/src/databases/methods.ts +49 -0
  287. package/src/databases/setup.ts +77 -0
  288. package/src/examples/yamlTerminologyExample.ts +346 -0
  289. package/src/functions/deployments.ts +220 -0
  290. package/src/functions/fnConfigDiscovery.ts +103 -0
  291. package/src/functions/methods.ts +271 -0
  292. package/src/functions/pathResolution.ts +227 -0
  293. package/src/functions/templates/count-docs-in-collection/README.md +54 -0
  294. package/src/functions/templates/count-docs-in-collection/src/main.ts +159 -0
  295. package/src/functions/templates/count-docs-in-collection/src/request.ts +9 -0
  296. package/src/functions/templates/hono-typescript/README.md +286 -0
  297. package/src/functions/templates/hono-typescript/src/adapters/request.ts +74 -0
  298. package/src/functions/templates/hono-typescript/src/adapters/response.ts +106 -0
  299. package/src/functions/templates/hono-typescript/src/app.ts +180 -0
  300. package/src/functions/templates/hono-typescript/src/context.ts +103 -0
  301. package/src/functions/templates/hono-typescript/src/index.ts +54 -0
  302. package/src/functions/templates/hono-typescript/src/middleware/appwrite.ts +119 -0
  303. package/src/functions/templates/typescript-node/README.md +32 -0
  304. package/src/functions/templates/typescript-node/src/context.ts +103 -0
  305. package/src/functions/templates/typescript-node/src/index.ts +29 -0
  306. package/src/functions/templates/uv/README.md +31 -0
  307. package/src/functions/templates/uv/pyproject.toml +30 -0
  308. package/src/functions/templates/uv/src/__init__.py +0 -0
  309. package/src/functions/templates/uv/src/context.py +125 -0
  310. package/src/functions/templates/uv/src/index.py +46 -0
  311. package/src/init.ts +62 -0
  312. package/src/interactiveCLI.ts +1136 -0
  313. package/src/main.ts +1661 -0
  314. package/src/migrations/afterImportActions.ts +580 -0
  315. package/src/migrations/appwriteToX.ts +664 -0
  316. package/src/migrations/comprehensiveTransfer.ts +2285 -0
  317. package/src/migrations/dataLoader.ts +1702 -0
  318. package/src/migrations/importController.ts +428 -0
  319. package/src/migrations/importDataActions.ts +315 -0
  320. package/src/migrations/relationships.ts +334 -0
  321. package/src/migrations/services/DataTransformationService.ts +196 -0
  322. package/src/migrations/services/FileHandlerService.ts +311 -0
  323. package/src/migrations/services/ImportOrchestrator.ts +666 -0
  324. package/src/migrations/services/RateLimitManager.ts +363 -0
  325. package/src/migrations/services/RelationshipResolver.ts +461 -0
  326. package/src/migrations/services/UserMappingService.ts +345 -0
  327. package/src/migrations/services/ValidationService.ts +349 -0
  328. package/src/migrations/transfer.ts +1068 -0
  329. package/src/migrations/yaml/YamlImportConfigLoader.ts +439 -0
  330. package/src/migrations/yaml/YamlImportIntegration.ts +446 -0
  331. package/src/migrations/yaml/generateImportSchemas.ts +1354 -0
  332. package/src/schemas/authUser.ts +23 -0
  333. package/src/setup.ts +8 -0
  334. package/src/setupCommands.ts +603 -0
  335. package/src/setupController.ts +43 -0
  336. package/src/shared/attributeMapper.ts +229 -0
  337. package/src/shared/backupMetadataSchema.ts +93 -0
  338. package/src/shared/backupTracking.ts +211 -0
  339. package/src/shared/confirmationDialogs.ts +327 -0
  340. package/src/shared/errorUtils.ts +110 -0
  341. package/src/shared/functionManager.ts +525 -0
  342. package/src/shared/indexManager.ts +254 -0
  343. package/src/shared/jsonSchemaGenerator.ts +383 -0
  344. package/src/shared/logging.ts +149 -0
  345. package/src/shared/messageFormatter.ts +208 -0
  346. package/src/shared/migrationHelpers.ts +232 -0
  347. package/src/shared/operationLogger.ts +20 -0
  348. package/src/shared/operationQueue.ts +377 -0
  349. package/src/shared/operationsTable.ts +338 -0
  350. package/src/shared/operationsTableSchema.ts +60 -0
  351. package/src/shared/progressManager.ts +278 -0
  352. package/src/shared/pydanticModelGenerator.ts +618 -0
  353. package/src/shared/relationshipExtractor.ts +214 -0
  354. package/src/shared/schemaGenerator.ts +644 -0
  355. package/src/shared/selectionDialogs.ts +749 -0
  356. package/src/storage/backupCompression.ts +88 -0
  357. package/src/storage/methods.ts +698 -0
  358. package/src/storage/schemas.ts +205 -0
  359. package/src/types/node-appwrite-tablesdb.d.ts +44 -0
  360. package/src/types.ts +9 -0
  361. package/src/users/methods.ts +359 -0
  362. package/src/utils/ClientFactory.ts +240 -0
  363. package/src/utils/configDiscovery.ts +557 -0
  364. package/src/utils/configMigration.ts +348 -0
  365. package/src/utils/constantsGenerator.ts +369 -0
  366. package/src/utils/dataConverters.ts +159 -0
  367. package/src/utils/directoryUtils.ts +61 -0
  368. package/src/utils/getClientFromConfig.ts +257 -0
  369. package/src/utils/helperFunctions.ts +228 -0
  370. package/src/utils/index.ts +2 -0
  371. package/src/utils/loadConfigs.ts +449 -0
  372. package/src/utils/pathResolvers.ts +81 -0
  373. package/src/utils/projectConfig.ts +299 -0
  374. package/src/utils/retryFailedPromises.ts +29 -0
  375. package/src/utils/sessionAuth.ts +230 -0
  376. package/src/utils/setupFiles.ts +1238 -0
  377. package/src/utils/typeGuards.ts +65 -0
  378. package/src/utils/validationRules.ts +88 -0
  379. package/src/utils/versionDetection.ts +292 -0
  380. package/src/utils/yamlConverter.ts +542 -0
  381. package/src/utils/yamlLoader.ts +371 -0
  382. package/src/utilsController.ts +1203 -0
  383. package/tests/README.md +497 -0
  384. package/tests/adapters/AdapterFactory.test.ts +277 -0
  385. package/tests/integration/syncOperations.test.ts +463 -0
  386. package/tests/jest.config.js +25 -0
  387. package/tests/migration/configMigration.test.ts +546 -0
  388. package/tests/setup.ts +62 -0
  389. package/tests/testUtils.ts +340 -0
  390. package/tests/utils/loadConfigs.test.ts +350 -0
  391. package/tests/validation/configValidation.test.ts +412 -0
  392. package/tsconfig.json +44 -0
@@ -0,0 +1,342 @@
1
+ import type { Storage, Databases, Models } from "node-appwrite";
2
+ import { ID } from "node-appwrite";
3
+ import { InputFile } from "node-appwrite/file";
4
+ import { ulid } from "ulidx";
5
+ import { MessageFormatter } from "../../shared/messageFormatter.js";
6
+ import { logger } from "../../shared/logging.js";
7
+ import type { DatabaseAdapter } from "../../adapters/DatabaseAdapter.js";
8
+ import { backupDatabase } from "../../storage/methods.js";
9
+ import { backupBucket } from "./bucketBackup.js";
10
+ import {
11
+ recordCentralizedBackup,
12
+ createCentralizedBackupTrackingTable
13
+ } from "../tracking/centralizedTracking.js";
14
+ import type {
15
+ ComprehensiveManifest,
16
+ DatabaseBackupReference,
17
+ BucketBackupReference
18
+ } from "../schemas/comprehensiveManifest.js";
19
+ import type { AppwriteConfig } from "@njdamstra/appwrite-utils";
20
+ import { fetchAllDatabases } from "../../databases/methods.js";
21
+
22
+ export interface ComprehensiveBackupOptions {
23
+ trackingDatabaseId: string; // Database to store backup tracking
24
+ backupFormat?: 'json' | 'zip';
25
+ skipDatabases?: boolean;
26
+ skipBuckets?: boolean;
27
+ parallelDownloads?: number;
28
+ onProgress?: (message: string) => void;
29
+ }
30
+
31
+ export interface ComprehensiveBackupResult {
32
+ backupId: string;
33
+ manifestFileId: string;
34
+ databaseBackups: DatabaseBackupReference[];
35
+ bucketBackups: BucketBackupReference[];
36
+ totalSizeBytes: number;
37
+ status: 'completed' | 'partial' | 'failed';
38
+ errors: string[];
39
+ }
40
+
41
+ /**
42
+ * Orchestrates comprehensive backup of ALL databases and ALL storage buckets
43
+ */
44
+ export async function comprehensiveBackup(
45
+ config: AppwriteConfig,
46
+ databases: Databases,
47
+ storage: Storage,
48
+ adapter: DatabaseAdapter,
49
+ options: ComprehensiveBackupOptions
50
+ ): Promise<ComprehensiveBackupResult> {
51
+ const startTime = Date.now();
52
+ const backupId = ulid();
53
+ const errors: string[] = [];
54
+ const databaseBackups: DatabaseBackupReference[] = [];
55
+ const bucketBackups: BucketBackupReference[] = [];
56
+ let totalSizeBytes = 0;
57
+
58
+ try {
59
+ // Ensure tracking table exists
60
+ await createCentralizedBackupTrackingTable(adapter, options.trackingDatabaseId);
61
+
62
+ // Initialize backup bucket
63
+ const backupBucketId = "appwrite-backups";
64
+ MessageFormatter.info(`Starting comprehensive backup ${backupId}`, { prefix: "Backup" });
65
+
66
+ // Phase 1: Backup ALL databases
67
+ if (!options.skipDatabases) {
68
+ MessageFormatter.info("Phase 1: Backing up ALL databases", { prefix: "Backup" });
69
+
70
+ const allDatabases = await fetchAllDatabases(databases);
71
+
72
+ // Validate each database exists before attempting backup
73
+ const validDatabases: Models.Database[] = [];
74
+ const skippedDatabases: string[] = [];
75
+
76
+ MessageFormatter.info(`Validating ${allDatabases.length} databases...`, { prefix: "Backup" });
77
+
78
+ for (const db of allDatabases) {
79
+ try {
80
+ await databases.get(db.$id); // Validate existence
81
+ validDatabases.push(db);
82
+ } catch (error) {
83
+ skippedDatabases.push(`${db.name} (${db.$id})`);
84
+ MessageFormatter.warning(
85
+ `Database ${db.name} not found - skipping`,
86
+ { prefix: "Backup" }
87
+ );
88
+ logger.warn('Database validation failed', {
89
+ databaseId: db.$id,
90
+ databaseName: db.name,
91
+ error: error instanceof Error ? error.message : String(error)
92
+ });
93
+ }
94
+ }
95
+
96
+ if (skippedDatabases.length > 0) {
97
+ MessageFormatter.info(
98
+ `Skipped ${skippedDatabases.length} invalid databases: ${skippedDatabases.join(', ')}`,
99
+ { prefix: "Backup" }
100
+ );
101
+ }
102
+
103
+ MessageFormatter.info(`Found ${validDatabases.length} valid databases to backup`, { prefix: "Backup" });
104
+
105
+ for (const db of validDatabases) {
106
+ try {
107
+ if (options.onProgress) {
108
+ options.onProgress(`Backing up database: ${db.name}`);
109
+ }
110
+
111
+ MessageFormatter.info(`Backing up database: ${db.name} (${db.$id})`, { prefix: "Backup" });
112
+
113
+ // Use existing backupDatabase function
114
+ const dbBackupResult = await backupDatabase(
115
+ config,
116
+ databases,
117
+ db.$id,
118
+ storage,
119
+ options.backupFormat || 'zip'
120
+ );
121
+
122
+ // Create database manifest with complete data
123
+ const manifestData = {
124
+ version: "1.0",
125
+ databaseId: dbBackupResult.databaseId,
126
+ databaseName: dbBackupResult.databaseName,
127
+ format: dbBackupResult.format,
128
+ collectionCount: dbBackupResult.collectionCount,
129
+ documentCount: dbBackupResult.documentCount,
130
+ backupFileId: dbBackupResult.backupFileId,
131
+ createdAt: new Date().toISOString()
132
+ };
133
+
134
+ const manifestBuffer = Buffer.from(JSON.stringify(manifestData, null, 2), 'utf-8');
135
+ const manifestFile = await storage.createFile(
136
+ backupBucketId,
137
+ ID.unique(),
138
+ InputFile.fromBuffer(new Uint8Array(manifestBuffer), `${db.$id}-manifest.json`)
139
+ );
140
+
141
+ databaseBackups.push({
142
+ databaseId: dbBackupResult.databaseId,
143
+ databaseName: dbBackupResult.databaseName,
144
+ backupFileId: dbBackupResult.backupFileId,
145
+ manifestFileId: manifestFile.$id,
146
+ collectionCount: dbBackupResult.collectionCount,
147
+ documentCount: dbBackupResult.documentCount,
148
+ sizeBytes: dbBackupResult.backupSizeBytes,
149
+ status: 'completed'
150
+ });
151
+
152
+ totalSizeBytes += dbBackupResult.backupSizeBytes;
153
+
154
+ // Record individual database backup in tracking
155
+ await recordCentralizedBackup(adapter, options.trackingDatabaseId, {
156
+ backupType: 'database',
157
+ backupId: dbBackupResult.backupFileId,
158
+ manifestFileId: manifestFile.$id,
159
+ format: dbBackupResult.format,
160
+ sizeBytes: dbBackupResult.backupSizeBytes,
161
+ databaseId: dbBackupResult.databaseId,
162
+ collections: dbBackupResult.collectionCount,
163
+ documents: dbBackupResult.documentCount,
164
+ status: 'completed',
165
+ restorationStatus: 'not_restored'
166
+ });
167
+
168
+ MessageFormatter.success(`Database ${db.name} backed up successfully`, { prefix: "Backup" });
169
+ } catch (error) {
170
+ const errorMsg = `Failed to backup database ${db.name}: ${error instanceof Error ? error.message : String(error)}`;
171
+ errors.push(errorMsg);
172
+ logger.error(errorMsg);
173
+
174
+ databaseBackups.push({
175
+ databaseId: db.$id,
176
+ databaseName: db.name,
177
+ backupFileId: '',
178
+ manifestFileId: '',
179
+ collectionCount: 0,
180
+ documentCount: 0,
181
+ sizeBytes: 0,
182
+ status: 'failed',
183
+ error: errorMsg
184
+ });
185
+ }
186
+ }
187
+ }
188
+
189
+ // Phase 2: Backup ALL storage buckets
190
+ if (!options.skipBuckets) {
191
+ MessageFormatter.info("Phase 2: Backing up ALL storage buckets", { prefix: "Backup" });
192
+
193
+ const allBuckets = await storage.listBuckets();
194
+ const bucketsToBackup = allBuckets.buckets.filter(b => b.$id !== backupBucketId);
195
+
196
+ MessageFormatter.info(`Found ${bucketsToBackup.length} buckets to backup`, { prefix: "Backup" });
197
+
198
+ for (const bucket of bucketsToBackup) {
199
+ try {
200
+ if (options.onProgress) {
201
+ options.onProgress(`Backing up bucket: ${bucket.name}`);
202
+ }
203
+
204
+ MessageFormatter.info(`Backing up bucket: ${bucket.name} (${bucket.$id})`, { prefix: "Backup" });
205
+
206
+ const bucketBackupResult = await backupBucket(
207
+ storage,
208
+ bucket.$id,
209
+ backupBucketId,
210
+ {
211
+ parallelDownloads: options.parallelDownloads || 10,
212
+ onProgress: (current, total, fileName) => {
213
+ if (options.onProgress) {
214
+ options.onProgress(`Downloading ${fileName} (${current}/${total})`);
215
+ }
216
+ }
217
+ }
218
+ );
219
+
220
+ bucketBackups.push({
221
+ bucketId: bucket.$id,
222
+ bucketName: bucket.name,
223
+ backupFileId: bucketBackupResult.backupFileId,
224
+ manifestFileId: bucketBackupResult.manifestFileId,
225
+ fileCount: bucketBackupResult.fileCount,
226
+ sizeBytes: bucketBackupResult.totalSizeBytes,
227
+ status: bucketBackupResult.status,
228
+ error: bucketBackupResult.errors?.join('; ')
229
+ });
230
+
231
+ totalSizeBytes += bucketBackupResult.zipSizeBytes;
232
+
233
+ // Record individual bucket backup in tracking
234
+ await recordCentralizedBackup(adapter, options.trackingDatabaseId, {
235
+ backupType: 'bucket',
236
+ backupId: bucketBackupResult.backupFileId,
237
+ manifestFileId: bucketBackupResult.manifestFileId,
238
+ format: 'zip',
239
+ sizeBytes: bucketBackupResult.zipSizeBytes,
240
+ bucketId: bucket.$id,
241
+ fileCount: bucketBackupResult.fileCount,
242
+ status: bucketBackupResult.status,
243
+ error: bucketBackupResult.errors?.join('; '),
244
+ restorationStatus: 'not_restored'
245
+ });
246
+
247
+ MessageFormatter.success(`Bucket ${bucket.name} backed up successfully`, { prefix: "Backup" });
248
+ } catch (error) {
249
+ const errorMsg = `Failed to backup bucket ${bucket.name}: ${error instanceof Error ? error.message : String(error)}`;
250
+ errors.push(errorMsg);
251
+ logger.error(errorMsg);
252
+
253
+ bucketBackups.push({
254
+ bucketId: bucket.$id,
255
+ bucketName: bucket.name,
256
+ backupFileId: '',
257
+ manifestFileId: '',
258
+ fileCount: 0,
259
+ sizeBytes: 0,
260
+ status: 'failed',
261
+ error: errorMsg
262
+ });
263
+ }
264
+ }
265
+ }
266
+
267
+ // Phase 3: Create comprehensive manifest
268
+ MessageFormatter.info("Creating comprehensive backup manifest", { prefix: "Backup" });
269
+
270
+ const comprehensiveStatus: 'completed' | 'partial' | 'failed' =
271
+ errors.length === 0 ? 'completed' :
272
+ (databaseBackups.length > 0 || bucketBackups.length > 0) ? 'partial' :
273
+ 'failed';
274
+
275
+ const manifest: ComprehensiveManifest = {
276
+ version: "1.0",
277
+ backupId,
278
+ createdAt: new Date().toISOString(),
279
+ databases: databaseBackups,
280
+ buckets: bucketBackups,
281
+ totalSizeBytes,
282
+ status: comprehensiveStatus,
283
+ errors: errors.length > 0 ? errors : undefined
284
+ };
285
+
286
+ // Upload comprehensive manifest
287
+ const manifestFileName = `comprehensive-${backupId}.json`;
288
+ const manifestBuffer = Buffer.from(JSON.stringify(manifest, null, 2), 'utf-8');
289
+ const manifestFile = await storage.createFile(
290
+ backupBucketId,
291
+ ID.unique(),
292
+ InputFile.fromBuffer(new Uint8Array(manifestBuffer), manifestFileName)
293
+ );
294
+
295
+ // Record comprehensive backup in tracking
296
+ await recordCentralizedBackup(adapter, options.trackingDatabaseId, {
297
+ backupType: 'comprehensive',
298
+ backupId,
299
+ manifestFileId: manifestFile.$id,
300
+ format: 'zip',
301
+ sizeBytes: totalSizeBytes,
302
+ comprehensiveBackupId: backupId,
303
+ status: comprehensiveStatus,
304
+ error: errors.length > 0 ? errors.join('; ') : undefined,
305
+ restorationStatus: 'not_restored'
306
+ });
307
+
308
+ const duration = Date.now() - startTime;
309
+ MessageFormatter.success(
310
+ `Comprehensive backup ${comprehensiveStatus} in ${(duration / 1000).toFixed(2)}s`,
311
+ { prefix: "Backup" }
312
+ );
313
+
314
+ MessageFormatter.info(
315
+ `Backed up ${databaseBackups.length} databases and ${bucketBackups.length} buckets (${MessageFormatter.formatBytes(totalSizeBytes)})`,
316
+ { prefix: "Backup" }
317
+ );
318
+
319
+ return {
320
+ backupId,
321
+ manifestFileId: manifestFile.$id,
322
+ databaseBackups,
323
+ bucketBackups,
324
+ totalSizeBytes,
325
+ status: comprehensiveStatus,
326
+ errors
327
+ };
328
+ } catch (error) {
329
+ const errorMsg = `Comprehensive backup failed: ${error instanceof Error ? error.message : String(error)}`;
330
+ MessageFormatter.error(errorMsg, error instanceof Error ? error : new Error(errorMsg), { prefix: "Backup" });
331
+
332
+ return {
333
+ backupId,
334
+ manifestFileId: '',
335
+ databaseBackups,
336
+ bucketBackups,
337
+ totalSizeBytes,
338
+ status: 'failed',
339
+ errors: [errorMsg, ...errors]
340
+ };
341
+ }
342
+ }
@@ -0,0 +1,78 @@
1
+ import { z } from "zod";
2
+
3
+ /**
4
+ * Schema for bucket backup manifest
5
+ *
6
+ * This manifest is stored alongside bucket backup ZIPs to describe
7
+ * the bucket configuration and files that were backed up.
8
+ */
9
+
10
+ export interface BucketFileMetadata {
11
+ $id: string;
12
+ name: string;
13
+ size: number;
14
+ mimeType: string;
15
+ $permissions: string[];
16
+ chunksCount: number;
17
+ signature: string;
18
+ $createdAt: string;
19
+ $updatedAt: string;
20
+ }
21
+
22
+ export interface BucketConfiguration {
23
+ $permissions: string[];
24
+ fileSecurity: boolean;
25
+ enabled: boolean;
26
+ maximumFileSize: number;
27
+ allowedFileExtensions: string[];
28
+ compression: string;
29
+ encryption: boolean;
30
+ antivirus: boolean;
31
+ }
32
+
33
+ export interface BucketManifest {
34
+ version: string;
35
+ bucketId: string;
36
+ bucketName: string;
37
+ createdAt: string;
38
+ fileCount: number;
39
+ totalSizeBytes: number;
40
+ compression: 'gzip' | 'none';
41
+ files: BucketFileMetadata[];
42
+ bucketConfiguration: BucketConfiguration;
43
+ }
44
+
45
+ export const BucketFileMetadataSchema = z.object({
46
+ $id: z.string(),
47
+ name: z.string(),
48
+ size: z.number(),
49
+ mimeType: z.string(),
50
+ $permissions: z.array(z.string()),
51
+ chunksCount: z.number(),
52
+ signature: z.string(),
53
+ $createdAt: z.string(),
54
+ $updatedAt: z.string()
55
+ });
56
+
57
+ export const BucketConfigurationSchema = z.object({
58
+ $permissions: z.array(z.string()),
59
+ fileSecurity: z.boolean(),
60
+ enabled: z.boolean(),
61
+ maximumFileSize: z.number(),
62
+ allowedFileExtensions: z.array(z.string()),
63
+ compression: z.string(),
64
+ encryption: z.boolean(),
65
+ antivirus: z.boolean()
66
+ });
67
+
68
+ export const BucketManifestSchema = z.object({
69
+ version: z.string().default("1.0"),
70
+ bucketId: z.string(),
71
+ bucketName: z.string(),
72
+ createdAt: z.string(),
73
+ fileCount: z.number(),
74
+ totalSizeBytes: z.number(),
75
+ compression: z.enum(['gzip', 'none']),
76
+ files: z.array(BucketFileMetadataSchema),
77
+ bucketConfiguration: BucketConfigurationSchema
78
+ });
@@ -0,0 +1,76 @@
1
+ import { z } from "zod";
2
+
3
+ /**
4
+ * Schema for comprehensive backup manifest
5
+ *
6
+ * This manifest tracks all databases and buckets included in a comprehensive backup,
7
+ * allowing for complete system restoration.
8
+ */
9
+
10
+ export interface DatabaseBackupReference {
11
+ databaseId: string;
12
+ databaseName: string;
13
+ backupFileId: string; // Storage file ID for the database backup ZIP/JSON
14
+ manifestFileId: string; // Storage file ID for the database manifest JSON
15
+ collectionCount: number;
16
+ documentCount: number;
17
+ sizeBytes: number;
18
+ status: 'completed' | 'partial' | 'failed';
19
+ error?: string;
20
+ }
21
+
22
+ export interface BucketBackupReference {
23
+ bucketId: string;
24
+ bucketName: string;
25
+ backupFileId: string; // Storage file ID for the bucket backup ZIP
26
+ manifestFileId: string; // Storage file ID for the bucket manifest JSON
27
+ fileCount: number;
28
+ sizeBytes: number;
29
+ status: 'completed' | 'partial' | 'failed';
30
+ error?: string;
31
+ }
32
+
33
+ export interface ComprehensiveManifest {
34
+ version: string;
35
+ backupId: string; // Unique ID for this comprehensive backup
36
+ createdAt: string; // ISO timestamp
37
+ databases: DatabaseBackupReference[];
38
+ buckets: BucketBackupReference[];
39
+ totalSizeBytes: number;
40
+ status: 'completed' | 'partial' | 'failed';
41
+ errors?: string[];
42
+ }
43
+
44
+ export const DatabaseBackupReferenceSchema = z.object({
45
+ databaseId: z.string(),
46
+ databaseName: z.string(),
47
+ backupFileId: z.string(),
48
+ manifestFileId: z.string(),
49
+ collectionCount: z.number(),
50
+ documentCount: z.number(),
51
+ sizeBytes: z.number(),
52
+ status: z.enum(['completed', 'partial', 'failed']),
53
+ error: z.string().optional()
54
+ });
55
+
56
+ export const BucketBackupReferenceSchema = z.object({
57
+ bucketId: z.string(),
58
+ bucketName: z.string(),
59
+ backupFileId: z.string(),
60
+ manifestFileId: z.string(),
61
+ fileCount: z.number(),
62
+ sizeBytes: z.number(),
63
+ status: z.enum(['completed', 'partial', 'failed']),
64
+ error: z.string().optional()
65
+ });
66
+
67
+ export const ComprehensiveManifestSchema = z.object({
68
+ version: z.string().default("1.0"),
69
+ backupId: z.string(),
70
+ createdAt: z.string(),
71
+ databases: z.array(DatabaseBackupReferenceSchema),
72
+ buckets: z.array(BucketBackupReferenceSchema),
73
+ totalSizeBytes: z.number(),
74
+ status: z.enum(['completed', 'partial', 'failed']),
75
+ errors: z.array(z.string()).optional()
76
+ });