@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,175 @@
1
+ import { z } from "zod";
2
+ import { attributeSchema, parseAttribute, CollectionCreateSchema, } from "@njdamstra/appwrite-utils";
3
+ export const BackupSchema = z.object({
4
+ $id: z.string(),
5
+ $createdAt: z.string(),
6
+ $updatedAt: z.string(),
7
+ database: z.string(),
8
+ collections: z.array(z.string()),
9
+ documents: z
10
+ .array(z.object({
11
+ collectionId: z.string(),
12
+ data: z.string(),
13
+ }))
14
+ .default([]),
15
+ });
16
+ export const BackupCreateSchema = BackupSchema.omit({
17
+ $id: true,
18
+ $createdAt: true,
19
+ $updatedAt: true,
20
+ });
21
+ export const BatchSchema = z.object({
22
+ $id: z.string(),
23
+ $createdAt: z.string(),
24
+ $updatedAt: z.string(),
25
+ data: z.string().describe("The serialized data for this batch"),
26
+ processed: z
27
+ .boolean()
28
+ .default(false)
29
+ .describe("Whether the batch has been processed"),
30
+ });
31
+ export const BatchCreateSchema = BatchSchema.omit({
32
+ $id: true,
33
+ $createdAt: true,
34
+ $updatedAt: true,
35
+ });
36
+ export const OperationSchema = z.object({
37
+ $id: z.string(),
38
+ $createdAt: z.string(),
39
+ $updatedAt: z.string(),
40
+ operationType: z.string(),
41
+ collectionId: z.string(),
42
+ data: z.any(),
43
+ batches: z.array(z.string()).default([]).optional(),
44
+ progress: z.number(),
45
+ total: z.number(),
46
+ error: z.string(),
47
+ status: z
48
+ .enum([
49
+ "pending",
50
+ "ready",
51
+ "in_progress",
52
+ "completed",
53
+ "error",
54
+ "cancelled",
55
+ ])
56
+ .default("pending"),
57
+ });
58
+ export const OperationCreateSchema = OperationSchema.omit({
59
+ $id: true,
60
+ $createdAt: true,
61
+ $updatedAt: true,
62
+ });
63
+ export const getMigrationCollectionSchemas = () => {
64
+ const currentOperationsAttributes = [
65
+ parseAttribute({
66
+ key: "operationType",
67
+ type: "string",
68
+ error: "Invalid Operation Type",
69
+ size: 50,
70
+ required: true,
71
+ array: false,
72
+ xdefault: null,
73
+ }),
74
+ attributeSchema.parse({
75
+ key: "collectionId",
76
+ type: "string",
77
+ error: "Invalid Collection Id",
78
+ size: 50,
79
+ array: false,
80
+ xdefault: null,
81
+ }),
82
+ attributeSchema.parse({
83
+ key: "batches",
84
+ type: "string",
85
+ error: "Invalid Batches",
86
+ size: 1073741824,
87
+ array: true,
88
+ }),
89
+ attributeSchema.parse({
90
+ key: "data",
91
+ type: "string",
92
+ error: "Invalid Data",
93
+ size: 1073741824,
94
+ }),
95
+ attributeSchema.parse({
96
+ key: "progress",
97
+ type: "integer",
98
+ error: "Invalid Progress",
99
+ required: true,
100
+ array: false,
101
+ }),
102
+ attributeSchema.parse({
103
+ key: "total",
104
+ type: "integer",
105
+ error: "Invalid Total",
106
+ required: true,
107
+ array: false,
108
+ }),
109
+ attributeSchema.parse({
110
+ key: "error",
111
+ type: "string",
112
+ error: "Operation Error",
113
+ required: false,
114
+ array: false,
115
+ }),
116
+ attributeSchema.parse({
117
+ key: "status",
118
+ type: "enum",
119
+ elements: [
120
+ "pending",
121
+ "ready",
122
+ "in_progress",
123
+ "completed",
124
+ "error",
125
+ "cancelled",
126
+ ],
127
+ error: "Invalid Status",
128
+ array: false,
129
+ xdefault: "pending",
130
+ }),
131
+ ];
132
+ const currentOperationsConfig = CollectionCreateSchema.parse({
133
+ name: "CurrentOperations",
134
+ enabled: true,
135
+ documentSecurity: false,
136
+ attributes: [],
137
+ indexes: [],
138
+ });
139
+ const batchesAttributes = [
140
+ attributeSchema.parse({
141
+ key: "data",
142
+ type: "string",
143
+ size: 1073741824,
144
+ error: "Invalid Data",
145
+ required: true,
146
+ array: false,
147
+ }),
148
+ attributeSchema.parse({
149
+ key: "processed",
150
+ type: "boolean",
151
+ error: "Invalid Processed",
152
+ required: true,
153
+ array: false,
154
+ xdefault: false,
155
+ }),
156
+ ];
157
+ const batchesConfig = CollectionCreateSchema.parse({
158
+ name: "Batches",
159
+ enabled: true,
160
+ documentSecurity: false,
161
+ attributes: [],
162
+ indexes: [],
163
+ });
164
+ const toReturn = {
165
+ CurrentOperations: {
166
+ collection: currentOperationsConfig,
167
+ attributes: currentOperationsAttributes,
168
+ },
169
+ Batches: {
170
+ collection: batchesConfig,
171
+ attributes: batchesAttributes,
172
+ },
173
+ };
174
+ return toReturn;
175
+ };
@@ -0,0 +1,4 @@
1
+ export type { ValidationRules } from "./utils/validationRules.js";
2
+ export { type AuthUserCreate, AuthUserCreateSchema, type AuthUser, AuthUserSchema, } from "./schemas/authUser.js";
3
+ export { validationRules } from "./utils/validationRules.js";
4
+ export { afterImportActions } from "./migrations/afterImportActions.js";
package/dist/types.js ADDED
@@ -0,0 +1,3 @@
1
+ export { AuthUserCreateSchema, AuthUserSchema, } from "./schemas/authUser.js";
2
+ export { validationRules } from "./utils/validationRules.js";
3
+ export { afterImportActions } from "./migrations/afterImportActions.js";
@@ -0,0 +1,16 @@
1
+ import type { AppwriteConfig } from "@njdamstra/appwrite-utils";
2
+ import { Databases, type Models } from "node-appwrite";
3
+ import { type AuthUserCreate } from "../schemas/authUser.js";
4
+ export declare class UsersController {
5
+ private config;
6
+ private users;
7
+ static userFields: string[];
8
+ constructor(config: AppwriteConfig, db: Databases);
9
+ wipeUsers(): Promise<void>;
10
+ getAllUsers(): Promise<Models.User<Models.Preferences>[]>;
11
+ createUsersAndReturn(items: AuthUserCreate[]): Promise<any[]>;
12
+ createUserAndReturn(item: AuthUserCreate): Promise<any>;
13
+ createAndCheckForUserAndReturn(item: AuthUserCreate): Promise<Models.User<Models.Preferences> | undefined>;
14
+ getUserIdByEmailOrPhone(email?: string, phone?: string): Promise<string | undefined>;
15
+ transferUsersBetweenDbsLocalToRemote: (endpoint: string, projectId: string, apiKey: string) => Promise<void>;
16
+ }
@@ -0,0 +1,277 @@
1
+ import { AppwriteException, Databases, ID, Query, Users, } from "node-appwrite";
2
+ import { AuthUserSchema, } from "../schemas/authUser.js";
3
+ import { logger } from "../shared/logging.js";
4
+ import { splitIntoBatches } from "../shared/migrationHelpers.js";
5
+ import { getAppwriteClient, tryAwaitWithRetry, } from "../utils/helperFunctions.js";
6
+ import { isUndefined } from "es-toolkit/compat";
7
+ import { isEmpty } from "es-toolkit/compat";
8
+ import { MessageFormatter } from "../shared/messageFormatter.js";
9
+ export class UsersController {
10
+ config;
11
+ users;
12
+ static userFields = [
13
+ "email",
14
+ "name",
15
+ "password",
16
+ "phone",
17
+ "labels",
18
+ "prefs",
19
+ "userId",
20
+ "$createdAt",
21
+ "$updatedAt",
22
+ ];
23
+ constructor(config, db) {
24
+ this.config = config;
25
+ this.users = new Users(this.config.appwriteClient);
26
+ }
27
+ async wipeUsers() {
28
+ const allUsers = await this.getAllUsers();
29
+ MessageFormatter.progress("Deleting all users...", { prefix: "Users" });
30
+ const createBatches = (finalData, batchSize) => {
31
+ const finalBatches = [];
32
+ for (let i = 0; i < finalData.length; i += batchSize) {
33
+ finalBatches.push(finalData.slice(i, i + batchSize));
34
+ }
35
+ return finalBatches;
36
+ };
37
+ let usersDeleted = 0;
38
+ if (allUsers.length > 0) {
39
+ const batchedUserPromises = createBatches(allUsers, 25); // Batch size of 25
40
+ for (const batch of batchedUserPromises) {
41
+ MessageFormatter.progress(`Deleting ${batch.length} users...`, { prefix: "Users" });
42
+ await Promise.all(batch.map((user) => tryAwaitWithRetry(async () => await this.users.delete(user.$id))));
43
+ usersDeleted += batch.length;
44
+ if (usersDeleted % 100 === 0) {
45
+ MessageFormatter.progress(`Deleted ${usersDeleted} users...`, { prefix: "Users" });
46
+ }
47
+ }
48
+ }
49
+ else {
50
+ MessageFormatter.info("No users to delete", { prefix: "Users" });
51
+ }
52
+ }
53
+ async getAllUsers() {
54
+ const allUsers = [];
55
+ const users = await tryAwaitWithRetry(async () => await this.users.list([Query.limit(200)]));
56
+ if (users.users.length === 0) {
57
+ return [];
58
+ }
59
+ if (users.users.length === 200) {
60
+ let lastDocumentId = users.users[users.users.length - 1].$id;
61
+ allUsers.push(...users.users);
62
+ while (lastDocumentId) {
63
+ const moreUsers = await tryAwaitWithRetry(async () => await this.users.list([
64
+ Query.limit(200),
65
+ Query.cursorAfter(lastDocumentId),
66
+ ]));
67
+ allUsers.push(...moreUsers.users);
68
+ if (moreUsers.users.length < 200) {
69
+ break;
70
+ }
71
+ lastDocumentId = moreUsers.users[moreUsers.users.length - 1].$id;
72
+ }
73
+ }
74
+ else {
75
+ allUsers.push(...users.users);
76
+ }
77
+ return allUsers;
78
+ }
79
+ async createUsersAndReturn(items) {
80
+ const users = await Promise.all(items.map((item) => this.createUserAndReturn(item)));
81
+ return users;
82
+ }
83
+ async createUserAndReturn(item) {
84
+ try {
85
+ const user = await tryAwaitWithRetry(async () => {
86
+ const createdUser = await this.users.create(item.userId || ID.unique(), item.email || undefined, item.phone && item.phone.length < 15 && item.phone.startsWith("+")
87
+ ? item.phone
88
+ : undefined, `changeMe${item.email?.toLowerCase()}` || `changeMePlease`, item.name || undefined);
89
+ if (item.labels) {
90
+ await this.users.updateLabels(createdUser.$id, item.labels);
91
+ }
92
+ if (item.prefs) {
93
+ await this.users.updatePrefs(createdUser.$id, item.prefs);
94
+ }
95
+ return createdUser;
96
+ }); // Set throwError to true since we want to handle errors
97
+ return user;
98
+ }
99
+ catch (e) {
100
+ if (e instanceof Error) {
101
+ logger.error("FAILED CREATING USER: ", e.message, item);
102
+ }
103
+ }
104
+ }
105
+ async createAndCheckForUserAndReturn(item) {
106
+ let userToReturn = undefined;
107
+ try {
108
+ // Attempt to find an existing user by email or phone.
109
+ let foundUsers = [];
110
+ if (item.email) {
111
+ const foundUsersByEmail = await this.users.list([
112
+ Query.equal("email", item.email),
113
+ ]);
114
+ foundUsers = foundUsersByEmail.users;
115
+ }
116
+ if (item.phone) {
117
+ const foundUsersByPhone = await this.users.list([
118
+ Query.equal("phone", item.phone),
119
+ ]);
120
+ foundUsers = foundUsers.length
121
+ ? foundUsers.concat(foundUsersByPhone.users)
122
+ : foundUsersByPhone.users;
123
+ }
124
+ userToReturn = foundUsers[0] || undefined;
125
+ if (!userToReturn) {
126
+ userToReturn = await this.users.create(item.userId || ID.unique(), item.email || undefined, item.phone && item.phone.length < 15 && item.phone.startsWith("+")
127
+ ? item.phone
128
+ : undefined, item.password?.toLowerCase() ||
129
+ `changeMe${item.email?.toLowerCase()}` ||
130
+ `changeMePlease`, item.name || undefined);
131
+ }
132
+ else {
133
+ // Update user details as necessary, ensuring email uniqueness if attempting an update.
134
+ if (item.email &&
135
+ item.email !== userToReturn.email &&
136
+ !isEmpty(item.email) &&
137
+ !isUndefined(item.email)) {
138
+ const emailExists = await this.users.list([
139
+ Query.equal("email", item.email),
140
+ ]);
141
+ if (emailExists.users.length === 0) {
142
+ userToReturn = await this.users.updateEmail(userToReturn.$id, item.email);
143
+ }
144
+ else {
145
+ MessageFormatter.warning("Email update skipped: Email already exists.", { prefix: "Users" });
146
+ }
147
+ }
148
+ if (item.password) {
149
+ userToReturn = await this.users.updatePassword(userToReturn.$id, item.password.toLowerCase());
150
+ }
151
+ if (item.name && item.name !== userToReturn.name) {
152
+ userToReturn = await this.users.updateName(userToReturn.$id, item.name);
153
+ }
154
+ if (item.phone &&
155
+ item.phone !== userToReturn.phone &&
156
+ item.phone.length < 15 &&
157
+ item.phone.startsWith("+") &&
158
+ (isUndefined(userToReturn.phone) || isEmpty(userToReturn.phone))) {
159
+ const userFoundWithPhone = await this.users.list([
160
+ Query.equal("phone", item.phone),
161
+ ]);
162
+ if (userFoundWithPhone.total === 0) {
163
+ userToReturn = await this.users.updatePhone(userToReturn.$id, item.phone);
164
+ }
165
+ }
166
+ }
167
+ if (item.$createdAt && item.$updatedAt) {
168
+ MessageFormatter.warning("$createdAt and $updatedAt are not yet supported, sorry about that!", { prefix: "Users" });
169
+ }
170
+ if (item.labels && item.labels.length) {
171
+ userToReturn = await this.users.updateLabels(userToReturn.$id, item.labels);
172
+ }
173
+ if (item.prefs && Object.keys(item.prefs).length) {
174
+ await this.users.updatePrefs(userToReturn.$id, item.prefs);
175
+ userToReturn.prefs = item.prefs;
176
+ }
177
+ return userToReturn;
178
+ }
179
+ catch (error) {
180
+ return userToReturn;
181
+ }
182
+ }
183
+ async getUserIdByEmailOrPhone(email, phone) {
184
+ if (!email && !phone) {
185
+ return undefined;
186
+ }
187
+ if (email && phone) {
188
+ const foundUsersByEmail = await this.users.list([
189
+ // @ts-ignore
190
+ Query.or([Query.equal("email", email), Query.equal("phone", phone)]),
191
+ ]);
192
+ if (foundUsersByEmail.users.length > 0) {
193
+ return foundUsersByEmail.users[0]?.$id;
194
+ }
195
+ }
196
+ else if (email) {
197
+ const foundUsersByEmail = await this.users.list([
198
+ Query.equal("email", email),
199
+ ]);
200
+ if (foundUsersByEmail.users.length > 0) {
201
+ return foundUsersByEmail.users[0]?.$id;
202
+ }
203
+ else {
204
+ if (!phone) {
205
+ return undefined;
206
+ }
207
+ else {
208
+ const foundUsersByPhone = await this.users.list([
209
+ Query.equal("phone", phone),
210
+ ]);
211
+ if (foundUsersByPhone.users.length > 0) {
212
+ return foundUsersByPhone.users[0]?.$id;
213
+ }
214
+ else {
215
+ return undefined;
216
+ }
217
+ }
218
+ }
219
+ }
220
+ if (phone) {
221
+ const foundUsersByPhone = await this.users.list([
222
+ Query.equal("phone", phone),
223
+ ]);
224
+ if (foundUsersByPhone.users.length > 0) {
225
+ return foundUsersByPhone.users[0]?.$id;
226
+ }
227
+ else {
228
+ return undefined;
229
+ }
230
+ }
231
+ }
232
+ transferUsersBetweenDbsLocalToRemote = async (endpoint, projectId, apiKey) => {
233
+ const localUsers = this.users;
234
+ const client = getAppwriteClient(endpoint, projectId, apiKey);
235
+ const remoteUsers = new Users(client);
236
+ let fromUsers = await localUsers.list([Query.limit(50)]);
237
+ if (fromUsers.users.length === 0) {
238
+ MessageFormatter.info("No users found", { prefix: "Users" });
239
+ return;
240
+ }
241
+ else if (fromUsers.users.length < 50) {
242
+ MessageFormatter.progress(`Transferring ${fromUsers.users.length} users to remote`, { prefix: "Users" });
243
+ const batchedPromises = fromUsers.users.map((user) => {
244
+ return tryAwaitWithRetry(async () => {
245
+ const toCreateObject = {
246
+ ...user,
247
+ };
248
+ delete toCreateObject.$id;
249
+ delete toCreateObject.$createdAt;
250
+ delete toCreateObject.$updatedAt;
251
+ await remoteUsers.create(user.$id, user.email, user.phone, user.password, user.name);
252
+ });
253
+ });
254
+ await Promise.all(batchedPromises);
255
+ }
256
+ else {
257
+ while (fromUsers.users.length === 50) {
258
+ fromUsers = await localUsers.list([
259
+ Query.limit(50),
260
+ Query.cursorAfter(fromUsers.users[fromUsers.users.length - 1].$id),
261
+ ]);
262
+ const batchedPromises = fromUsers.users.map((user) => {
263
+ return tryAwaitWithRetry(async () => {
264
+ const toCreateObject = {
265
+ ...user,
266
+ };
267
+ delete toCreateObject.$id;
268
+ delete toCreateObject.$createdAt;
269
+ delete toCreateObject.$updatedAt;
270
+ await remoteUsers.create(user.$id, user.email, user.phone, user.password, user.name);
271
+ });
272
+ });
273
+ await Promise.all(batchedPromises);
274
+ }
275
+ }
276
+ };
277
+ }
@@ -0,0 +1,87 @@
1
+ import { Client } from "node-appwrite";
2
+ import type { AppwriteConfig } from "@njdamstra/appwrite-utils";
3
+ import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
4
+ /**
5
+ * Factory for creating authenticated Appwrite clients and database adapters.
6
+ *
7
+ * This factory provides a clean separation of concerns by taking pre-configured
8
+ * AppwriteConfig objects (with authentication already resolved by ConfigManager)
9
+ * and creating the necessary client and adapter instances.
10
+ *
11
+ * Key features:
12
+ * - Takes pre-authenticated config from ConfigManager
13
+ * - Creates client with appropriate authentication method
14
+ * - Creates adapter with automatic version detection
15
+ * - Leverages AdapterFactory's internal caching for performance
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * const configManager = ConfigManager.getInstance();
20
+ * const config = await configManager.loadConfig();
21
+ *
22
+ * // Config already has session or API key resolved
23
+ * const { client, adapter } = await ClientFactory.createFromConfig(config);
24
+ * ```
25
+ */
26
+ export declare class ClientFactory {
27
+ /**
28
+ * Create authenticated client and database adapter from configuration.
29
+ *
30
+ * This method expects the config to have authentication already resolved:
31
+ * - Either `sessionCookie` is set (from ConfigManager's session loading)
32
+ * - Or `appwriteKey` is set (from config file or CLI overrides)
33
+ *
34
+ * The ConfigManager handles all session discovery and authentication priority,
35
+ * so this factory simply applies the resolved authentication to the client.
36
+ *
37
+ * @param config - AppwriteConfig with resolved authentication
38
+ * @returns Object containing authenticated client and database adapter
39
+ * @throws Error if no authentication method is available in config
40
+ *
41
+ * @example
42
+ * ```typescript
43
+ * const config = await ConfigManager.getInstance().loadConfig();
44
+ * const { client, adapter } = await ClientFactory.createFromConfig(config);
45
+ *
46
+ * // Client is now authenticated and ready to use
47
+ * const databases = new Databases(client);
48
+ * const collections = await adapter.listCollections(databaseId);
49
+ * ```
50
+ */
51
+ static createFromConfig(config: AppwriteConfig): Promise<{
52
+ client: Client;
53
+ adapter: DatabaseAdapter;
54
+ }>;
55
+ /**
56
+ * Create client and adapter from individual parameters.
57
+ *
58
+ * This is a lower-level method for cases where you don't have a full
59
+ * AppwriteConfig object. For most use cases, prefer createFromConfig().
60
+ *
61
+ * @param endpoint - Appwrite endpoint URL
62
+ * @param project - Appwrite project ID
63
+ * @param options - Authentication and API mode options
64
+ * @returns Object containing authenticated client and database adapter
65
+ * @throws Error if no authentication method is provided
66
+ *
67
+ * @example
68
+ * ```typescript
69
+ * const { client, adapter } = await ClientFactory.create(
70
+ * "https://cloud.appwrite.io/v1",
71
+ * "my-project-id",
72
+ * {
73
+ * apiKey: "my-api-key",
74
+ * apiMode: "auto"
75
+ * }
76
+ * );
77
+ * ```
78
+ */
79
+ static create(endpoint: string, project: string, options?: {
80
+ apiKey?: string;
81
+ sessionCookie?: string;
82
+ apiMode?: "auto" | "legacy" | "tablesdb";
83
+ }): Promise<{
84
+ client: Client;
85
+ adapter: DatabaseAdapter;
86
+ }>;
87
+ }