@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,428 @@
1
+ import {
2
+ AppwriteException,
3
+ ID,
4
+ Query,
5
+ type Databases,
6
+ type Models,
7
+ type Storage,
8
+ } from "node-appwrite";
9
+ import type {
10
+ AppwriteConfig,
11
+ ConfigCollection,
12
+ ConfigDatabase,
13
+ AttributeMappings,
14
+ } from "@njdamstra/appwrite-utils";
15
+ import type { ImportDataActions } from "./importDataActions.js";
16
+ import { areCollectionNamesSame, tryAwaitWithRetry } from "../utils/index.js";
17
+ import type { SetupOptions } from "../utilsController.js";
18
+ import { resolveAndUpdateRelationships } from "./relationships.js";
19
+ import { UsersController } from "../users/methods.js";
20
+ import { logger } from "../shared/logging.js";
21
+ import { updateOperation } from "../shared/migrationHelpers.js";
22
+ import { LegacyAdapter } from "../adapters/LegacyAdapter.js";
23
+ import {
24
+ BatchSchema,
25
+ OperationCreateSchema,
26
+ OperationSchema,
27
+ } from "../storage/schemas.js";
28
+ import { DataLoader, type CollectionImportData } from "./dataLoader.js";
29
+ import {
30
+ transferDatabaseLocalToLocal,
31
+ transferStorageLocalToLocal,
32
+ } from "./transfer.js";
33
+ import { MessageFormatter } from "../shared/messageFormatter.js";
34
+ import { ProgressManager } from "../shared/progressManager.js";
35
+
36
+ export class ImportController {
37
+ private config: AppwriteConfig;
38
+ private database: Databases;
39
+ private storage: Storage;
40
+ private appwriteFolderPath: string;
41
+ private importDataActions: ImportDataActions;
42
+ private setupOptions: SetupOptions;
43
+ private documentCache: Map<string, any>;
44
+ private batchLimit: number = 25; // Define batch size limit
45
+ private hasImportedUsers = false;
46
+ private postImportActionsQueue: {
47
+ context: any;
48
+ finalItem: any;
49
+ attributeMappings: AttributeMappings;
50
+ }[] = [];
51
+ private databasesToRun: Models.Database[];
52
+
53
+ constructor(
54
+ config: AppwriteConfig,
55
+ database: Databases,
56
+ storage: Storage,
57
+ appwriteFolderPath: string,
58
+ importDataActions: ImportDataActions,
59
+ setupOptions: SetupOptions,
60
+ databasesToRun?: Models.Database[]
61
+ ) {
62
+ this.config = config;
63
+ this.database = database;
64
+ this.storage = storage;
65
+ this.appwriteFolderPath = appwriteFolderPath;
66
+ this.importDataActions = importDataActions;
67
+ this.setupOptions = setupOptions;
68
+ this.documentCache = new Map();
69
+ this.databasesToRun = databasesToRun || [];
70
+ }
71
+
72
+ async run(specificCollections?: string[]) {
73
+ let databasesToProcess: Models.Database[];
74
+
75
+ if (this.databasesToRun.length > 0) {
76
+ // Use the provided databases
77
+ databasesToProcess = this.databasesToRun;
78
+ } else {
79
+ // If no databases are specified, fetch all databases
80
+ const allDatabases = await this.database.list();
81
+ databasesToProcess = allDatabases.databases;
82
+ }
83
+
84
+ let dataLoader: DataLoader | undefined;
85
+ let databaseRan: Models.Database | undefined;
86
+
87
+ for (let db of databasesToProcess) {
88
+ MessageFormatter.banner(`Starting import data for database: ${db.name}`, "Database Import");
89
+
90
+ if (!databaseRan) {
91
+ databaseRan = db;
92
+ dataLoader = new DataLoader(
93
+ this.appwriteFolderPath,
94
+ this.importDataActions,
95
+ this.database,
96
+ this.config,
97
+ this.setupOptions.shouldWriteFile
98
+ );
99
+ await dataLoader.setupMaps(db.$id);
100
+ await dataLoader.start(db.$id);
101
+ await this.importCollections(db, dataLoader, specificCollections);
102
+ await resolveAndUpdateRelationships(db.$id, this.database, this.config);
103
+ await this.executePostImportActions(
104
+ db.$id,
105
+ dataLoader,
106
+ specificCollections
107
+ );
108
+ } else if (databaseRan.$id !== db.$id) {
109
+ await this.updateOthersToFinalData(databaseRan, db);
110
+ }
111
+
112
+ MessageFormatter.divider();
113
+ MessageFormatter.success(`Finished import data for database: ${db.name}`, { prefix: "Import" });
114
+ MessageFormatter.divider();
115
+ }
116
+ }
117
+
118
+ async updateOthersToFinalData(
119
+ updatedDb: Models.Database,
120
+ targetDb: Models.Database
121
+ ) {
122
+ if (this.database) {
123
+ await transferDatabaseLocalToLocal(
124
+ this.database,
125
+ updatedDb.$id,
126
+ targetDb.$id
127
+ );
128
+ }
129
+
130
+ if (this.storage) {
131
+ // Find the corresponding database configs
132
+ const updatedDbConfig = this.config.databases.find(
133
+ (db) => db.$id === updatedDb.$id
134
+ );
135
+ const targetDbConfig = this.config.databases.find(
136
+ (db) => db.$id === targetDb.$id
137
+ );
138
+
139
+ const allBuckets = await this.storage.listBuckets([Query.limit(1000)]);
140
+ const bucketsWithDbIdInThem = allBuckets.buckets.filter((bucket) =>
141
+ bucket.name.toLowerCase().includes(updatedDb.$id.toLowerCase())
142
+ );
143
+ const configuredUpdatedBucketId = `${
144
+ this.config.documentBucketId
145
+ }_${updatedDb.$id.toLowerCase().trim().replace(" ", "")}`;
146
+ const configuredTargetBucketId = `${
147
+ this.config.documentBucketId
148
+ }_${targetDb.$id.toLowerCase().trim().replace(" ", "")}`;
149
+
150
+ let sourceBucketId: string | undefined;
151
+ let targetBucketId: string | undefined;
152
+
153
+ if (
154
+ bucketsWithDbIdInThem.find(
155
+ (bucket) => bucket.$id === configuredUpdatedBucketId
156
+ )
157
+ ) {
158
+ sourceBucketId = configuredUpdatedBucketId;
159
+ } else if (
160
+ bucketsWithDbIdInThem.find(
161
+ (bucket) => bucket.$id === configuredTargetBucketId
162
+ )
163
+ ) {
164
+ targetBucketId = configuredTargetBucketId;
165
+ }
166
+
167
+ if (!sourceBucketId) {
168
+ sourceBucketId =
169
+ updatedDbConfig?.bucket?.$id || bucketsWithDbIdInThem[0]?.$id;
170
+ }
171
+
172
+ if (!targetBucketId) {
173
+ targetBucketId =
174
+ targetDbConfig?.bucket?.$id || bucketsWithDbIdInThem[0]?.$id;
175
+ }
176
+
177
+ if (sourceBucketId && targetBucketId) {
178
+ await transferStorageLocalToLocal(
179
+ this.storage,
180
+ sourceBucketId,
181
+ targetBucketId
182
+ );
183
+ }
184
+ }
185
+ }
186
+
187
+ async importCollections(
188
+ db: ConfigDatabase,
189
+ dataLoader: DataLoader,
190
+ specificCollections?: string[]
191
+ ) {
192
+ const collectionsToImport =
193
+ specificCollections ||
194
+ (this.config.collections
195
+ ? this.config.collections.map((c) => c.name)
196
+ : []);
197
+
198
+ for (const collection of this.config.collections || []) {
199
+ if (collectionsToImport.includes(collection.name)) {
200
+ let isUsersCollection =
201
+ this.config.usersCollectionName &&
202
+ dataLoader.getCollectionKey(this.config.usersCollectionName) ===
203
+ dataLoader.getCollectionKey(collection.name);
204
+ const importOperationId = dataLoader.collectionImportOperations.get(
205
+ dataLoader.getCollectionKey(collection.name)
206
+ );
207
+ const createBatches = (finalData: CollectionImportData["data"]) => {
208
+ let maxBatchLength = 50;
209
+ const finalBatches: CollectionImportData["data"][] = [];
210
+ for (let i = 0; i < finalData.length; i++) {
211
+ if (i % maxBatchLength === 0) {
212
+ finalBatches.push([]);
213
+ }
214
+ finalBatches[finalBatches.length - 1].push(finalData[i]);
215
+ }
216
+ return finalBatches;
217
+ };
218
+
219
+ if (isUsersCollection && !this.hasImportedUsers) {
220
+ const usersDataMap = dataLoader.importMap.get(
221
+ dataLoader.getCollectionKey("users")
222
+ );
223
+ const usersData = usersDataMap?.data;
224
+ const usersController = new UsersController(
225
+ this.config,
226
+ this.database
227
+ );
228
+ if (usersData) {
229
+ console.log("Found users data", usersData.length);
230
+ const userDataBatches = createBatches(usersData);
231
+ for (const batch of userDataBatches) {
232
+ console.log("Importing users batch", batch.length);
233
+ const userBatchPromises = batch
234
+ .filter((item) => {
235
+ let itemId: string | undefined;
236
+ if (item.finalData.userId) {
237
+ itemId = item.finalData.userId;
238
+ } else if (item.finalData.docId) {
239
+ itemId = item.finalData.docId;
240
+ }
241
+ if (!itemId) {
242
+ return false;
243
+ }
244
+ return (
245
+ item &&
246
+ item.finalData &&
247
+ !dataLoader.userExistsMap.has(itemId)
248
+ );
249
+ })
250
+ .map((item) => {
251
+ dataLoader.userExistsMap.set(
252
+ item.finalData.userId ||
253
+ item.finalData.docId ||
254
+ item.context.userId ||
255
+ item.context.docId,
256
+ true
257
+ );
258
+ return usersController.createUserAndReturn(item.finalData);
259
+ });
260
+ const promiseResults = await Promise.allSettled(
261
+ userBatchPromises
262
+ );
263
+ for (const item of batch) {
264
+ if (item && item.finalData) {
265
+ dataLoader.userExistsMap.set(
266
+ item.finalData.userId ||
267
+ item.finalData.docId ||
268
+ item.context.userId ||
269
+ item.context.docId,
270
+ true
271
+ );
272
+ }
273
+ }
274
+ MessageFormatter.success("Finished importing users batch", { prefix: "Import" });
275
+ }
276
+ this.hasImportedUsers = true;
277
+ MessageFormatter.success("Finished importing users", { prefix: "Import" });
278
+ }
279
+ }
280
+
281
+ if (!importOperationId) {
282
+ // Skip further processing if no import operation is found
283
+ continue;
284
+ }
285
+
286
+ let importOperation: any = null;
287
+ importOperation = await this.database.getDocument(
288
+ "migrations",
289
+ "currentOperations",
290
+ importOperationId
291
+ );
292
+ const adapter = new LegacyAdapter(this.database.client);
293
+ await updateOperation(adapter, db.$id, importOperation.$id, {
294
+ status: "in_progress",
295
+ });
296
+
297
+ const collectionData = dataLoader.importMap.get(
298
+ dataLoader.getCollectionKey(collection.name)
299
+ );
300
+ MessageFormatter.processing(`Processing collection: ${collection.name}...`, { prefix: "Import" });
301
+ if (!collectionData) {
302
+ MessageFormatter.warning(`No collection data for ${collection.name}`, { prefix: "Import" });
303
+ continue;
304
+ }
305
+
306
+ const dataSplit = createBatches(collectionData.data);
307
+ let processedItems = 0;
308
+ for (let i = 0; i < dataSplit.length; i++) {
309
+ const batches = dataSplit[i];
310
+ MessageFormatter.progress(`Processing batch ${i + 1} of ${dataSplit.length}`, { prefix: "Import" });
311
+
312
+ const batchPromises = batches.map((item, index) => {
313
+ try {
314
+ const id =
315
+ item.finalData.docId ||
316
+ item.finalData.userId ||
317
+ item.context.docId ||
318
+ item.context.userId;
319
+
320
+ if (item.finalData.hasOwnProperty("userId")) {
321
+ delete item.finalData.userId;
322
+ }
323
+ if (item.finalData.hasOwnProperty("docId")) {
324
+ delete item.finalData.docId;
325
+ }
326
+ if (!item.finalData) {
327
+ return Promise.resolve();
328
+ }
329
+ return tryAwaitWithRetry(
330
+ async () =>
331
+ await this.database.createDocument(
332
+ db.$id,
333
+ collection.$id!,
334
+ id,
335
+ item.finalData
336
+ )
337
+ );
338
+ } catch (error) {
339
+ MessageFormatter.error(
340
+ "Error creating document",
341
+ error instanceof Error ? error : new Error(String(error)),
342
+ { prefix: "Import" }
343
+ );
344
+ return Promise.resolve();
345
+ }
346
+ });
347
+
348
+ // Wait for all promises in the current batch to resolve
349
+ await Promise.all(batchPromises);
350
+ MessageFormatter.success(`Completed batch ${i + 1} of ${dataSplit.length}`, { prefix: "Import" });
351
+ if (importOperation) {
352
+ const adapter = new LegacyAdapter(this.database.client);
353
+ await updateOperation(adapter, db.$id, importOperation.$id, {
354
+ progress: processedItems,
355
+ });
356
+ }
357
+ }
358
+ // After all batches are processed, update the operation status to completed
359
+ if (importOperation) {
360
+ const adapter = new LegacyAdapter(this.database.client);
361
+ await updateOperation(adapter, db.$id, importOperation.$id, {
362
+ status: "completed",
363
+ });
364
+ }
365
+ }
366
+ }
367
+ }
368
+
369
+ async executePostImportActions(
370
+ dbId: string,
371
+ dataLoader: DataLoader,
372
+ specificCollections?: string[]
373
+ ) {
374
+ MessageFormatter.info("Executing post-import actions...", { prefix: "Import" });
375
+ const collectionsToProcess =
376
+ specificCollections && specificCollections.length > 0
377
+ ? specificCollections
378
+ : this.config.collections
379
+ ? this.config.collections.map((c) => c.name)
380
+ : Array.from(dataLoader.importMap.keys());
381
+ MessageFormatter.info(`Collections to process: ${collectionsToProcess.join(", ")}`, { prefix: "Import" });
382
+ // Iterate over each collection in the importMap
383
+ for (const [
384
+ collectionKey,
385
+ collectionData,
386
+ ] of dataLoader.importMap.entries()) {
387
+ const allCollectionKeys = collectionsToProcess.map((c) =>
388
+ dataLoader.getCollectionKey(c)
389
+ );
390
+ if (allCollectionKeys.includes(collectionKey)) {
391
+ MessageFormatter.processing(
392
+ `Processing post-import actions for collection: ${collectionKey}`,
393
+ { prefix: "Import" }
394
+ );
395
+
396
+ // Iterate over each item in the collectionData.data
397
+ for (const item of collectionData.data) {
398
+ // Assuming each item has attributeMappings that contain actions to be executed
399
+ if (item.importDef && item.importDef.attributeMappings) {
400
+ // Use item.context as the context for action execution
401
+ const context = item.context; // Directly use item.context as the context for action execution
402
+ // Iterate through attributeMappings to execute actions
403
+ try {
404
+ // Execute post-import actions for the current attributeMapping
405
+ // Pass item.finalData as the data to be processed along with the context
406
+ await this.importDataActions.executeAfterImportActions(
407
+ item.finalData,
408
+ item.importDef.attributeMappings,
409
+ context
410
+ );
411
+ } catch (error) {
412
+ MessageFormatter.error(
413
+ `Failed to execute post-import actions for item in collection ${collectionKey}`,
414
+ error instanceof Error ? error : new Error(String(error)),
415
+ { prefix: "Import" }
416
+ );
417
+ }
418
+ }
419
+ }
420
+ } else {
421
+ MessageFormatter.info(
422
+ `Skipping collection: ${collectionKey} because it's not valid for post-import actions`,
423
+ { prefix: "Import" }
424
+ );
425
+ }
426
+ }
427
+ }
428
+ }