@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,286 @@
1
+ import { logger } from "./logging.js";
2
+ import { tryAwaitWithRetry } from "../utils/helperFunctions.js";
3
+ import { Query, ID } from "node-appwrite";
4
+ import { OPERATIONS_TABLE_ID, OPERATIONS_TABLE_NAME, OperationRecordSchema, } from "./operationsTableSchema.js";
5
+ /**
6
+ * Operations Table Manager
7
+ *
8
+ * Manages dynamic operations tracking tables in each database.
9
+ * Creates _appwrite_operations table on-demand for tracking imports, exports, transfers, etc.
10
+ */
11
+ /**
12
+ * Checks if operations table exists in database
13
+ */
14
+ async function tableExists(db, databaseId) {
15
+ try {
16
+ await db.getTable({ databaseId, tableId: OPERATIONS_TABLE_ID });
17
+ return true;
18
+ }
19
+ catch (error) {
20
+ return false;
21
+ }
22
+ }
23
+ /**
24
+ * Creates the operations tracking table in the specified database
25
+ * Table is created with underscore prefix to indicate it's a system table
26
+ */
27
+ export async function createOperationsTable(db, databaseId) {
28
+ // Check if table already exists
29
+ const exists = await tableExists(db, databaseId);
30
+ if (exists) {
31
+ logger.debug("Operations table already exists", {
32
+ databaseId,
33
+ tableId: OPERATIONS_TABLE_ID,
34
+ });
35
+ return;
36
+ }
37
+ logger.info("Creating operations tracking table", {
38
+ databaseId,
39
+ tableId: OPERATIONS_TABLE_ID,
40
+ });
41
+ // Create table
42
+ await tryAwaitWithRetry(async () => {
43
+ await db.createTable({
44
+ databaseId,
45
+ id: OPERATIONS_TABLE_ID,
46
+ name: OPERATIONS_TABLE_NAME,
47
+ });
48
+ });
49
+ // Create attributes with retry logic
50
+ const attributes = [
51
+ {
52
+ key: "operationType",
53
+ type: "string",
54
+ size: 50,
55
+ required: true,
56
+ },
57
+ {
58
+ key: "targetCollection",
59
+ type: "string",
60
+ size: 50,
61
+ required: false,
62
+ },
63
+ {
64
+ key: "status",
65
+ type: "enum",
66
+ elements: ["pending", "in_progress", "completed", "failed", "cancelled"],
67
+ required: true,
68
+ default: "pending",
69
+ },
70
+ {
71
+ key: "progress",
72
+ type: "integer",
73
+ required: true,
74
+ default: 0,
75
+ },
76
+ {
77
+ key: "total",
78
+ type: "integer",
79
+ required: true,
80
+ default: 0,
81
+ },
82
+ {
83
+ key: "data",
84
+ type: "string",
85
+ size: 1048576, // 1MB for serialized data
86
+ required: false,
87
+ },
88
+ {
89
+ key: "error",
90
+ type: "string",
91
+ size: 10000,
92
+ required: false,
93
+ },
94
+ ];
95
+ for (const attr of attributes) {
96
+ await tryAwaitWithRetry(async () => {
97
+ await db.createAttribute({
98
+ databaseId,
99
+ tableId: OPERATIONS_TABLE_ID,
100
+ ...attr,
101
+ });
102
+ });
103
+ }
104
+ logger.info("Operations tracking table created successfully", {
105
+ databaseId,
106
+ tableId: OPERATIONS_TABLE_ID,
107
+ attributes: attributes.length,
108
+ });
109
+ }
110
+ /**
111
+ * Finds an existing operation or creates a new one
112
+ * Useful for resuming interrupted operations
113
+ */
114
+ export async function findOrCreateOperation(db, databaseId, operationType, params) {
115
+ // Ensure operations table exists
116
+ await createOperationsTable(db, databaseId);
117
+ // Try to find existing pending operation
118
+ try {
119
+ const queries = [
120
+ Query.equal("operationType", operationType),
121
+ Query.equal("status", "pending"),
122
+ ];
123
+ if (params?.targetCollection) {
124
+ queries.push(Query.equal("targetCollection", params.targetCollection));
125
+ }
126
+ const response = await db.listRows({
127
+ databaseId,
128
+ tableId: OPERATIONS_TABLE_ID,
129
+ queries,
130
+ });
131
+ if (response.rows && response.rows.length > 0) {
132
+ logger.debug("Found existing operation", {
133
+ operationId: response.rows[0].$id,
134
+ operationType,
135
+ });
136
+ return response.rows[0];
137
+ }
138
+ }
139
+ catch (error) {
140
+ logger.debug("No existing operation found, creating new one", {
141
+ operationType,
142
+ error: error instanceof Error ? error.message : String(error),
143
+ });
144
+ }
145
+ // Create new operation
146
+ const newOperation = {
147
+ operationType,
148
+ targetCollection: params?.targetCollection,
149
+ status: "pending",
150
+ progress: params?.progress ?? 0,
151
+ total: params?.total ?? 0,
152
+ data: params?.data ? JSON.stringify(params.data) : undefined,
153
+ error: params?.error,
154
+ };
155
+ const result = await db.createRow({
156
+ databaseId,
157
+ tableId: OPERATIONS_TABLE_ID,
158
+ id: ID.unique(),
159
+ data: newOperation,
160
+ });
161
+ logger.info("Created new operation", {
162
+ operationId: result.data?.$id,
163
+ operationType,
164
+ });
165
+ return result.data;
166
+ }
167
+ /**
168
+ * Updates an existing operation record
169
+ */
170
+ export async function updateOperation(db, databaseId, operationId, updates) {
171
+ // Prepare update data (exclude system fields like $id, $createdAt, $updatedAt)
172
+ const updateData = {};
173
+ if (updates.operationType !== undefined)
174
+ updateData.operationType = updates.operationType;
175
+ if (updates.targetCollection !== undefined)
176
+ updateData.targetCollection = updates.targetCollection;
177
+ if (updates.status !== undefined)
178
+ updateData.status = updates.status;
179
+ if (updates.progress !== undefined)
180
+ updateData.progress = updates.progress;
181
+ if (updates.total !== undefined)
182
+ updateData.total = updates.total;
183
+ if (updates.error !== undefined)
184
+ updateData.error = updates.error;
185
+ if (updates.data !== undefined) {
186
+ updateData.data =
187
+ typeof updates.data === "string"
188
+ ? updates.data
189
+ : JSON.stringify(updates.data);
190
+ }
191
+ try {
192
+ const result = await db.updateRow({
193
+ databaseId,
194
+ tableId: OPERATIONS_TABLE_ID,
195
+ id: operationId,
196
+ data: updateData,
197
+ });
198
+ logger.debug("Updated operation", {
199
+ operationId,
200
+ updates: Object.keys(updateData),
201
+ });
202
+ return result.data;
203
+ }
204
+ catch (error) {
205
+ logger.error("Failed to update operation", {
206
+ operationId,
207
+ error: error instanceof Error ? error.message : String(error),
208
+ });
209
+ throw error;
210
+ }
211
+ }
212
+ /**
213
+ * Gets a single operation by ID
214
+ */
215
+ export async function getOperation(db, databaseId, operationId) {
216
+ try {
217
+ const result = await db.getRow({
218
+ databaseId,
219
+ tableId: OPERATIONS_TABLE_ID,
220
+ id: operationId,
221
+ });
222
+ return result.data;
223
+ }
224
+ catch (error) {
225
+ logger.debug("Operation not found", {
226
+ operationId,
227
+ error: error instanceof Error ? error.message : String(error),
228
+ });
229
+ return null;
230
+ }
231
+ }
232
+ /**
233
+ * Cleans up old completed operations
234
+ * @param olderThan - Optional date, defaults to operations older than 7 days
235
+ * @returns Number of operations deleted
236
+ */
237
+ export async function cleanupOperations(db, databaseId, olderThan) {
238
+ const cutoffDate = olderThan || new Date(Date.now() - 7 * 24 * 60 * 60 * 1000); // 7 days ago
239
+ const cutoffIso = cutoffDate.toISOString();
240
+ try {
241
+ // Query for completed operations older than cutoff
242
+ const response = await db.listRows({
243
+ databaseId,
244
+ tableId: OPERATIONS_TABLE_ID,
245
+ queries: [
246
+ Query.equal("status", ["completed", "failed", "cancelled"]),
247
+ Query.lessThan("$createdAt", cutoffIso),
248
+ ],
249
+ });
250
+ if (!response.rows || response.rows.length === 0) {
251
+ logger.debug("No old operations to clean up", { databaseId });
252
+ return 0;
253
+ }
254
+ // Delete in batches
255
+ let deletedCount = 0;
256
+ for (const operation of response.rows) {
257
+ try {
258
+ await db.deleteRow({
259
+ databaseId,
260
+ tableId: OPERATIONS_TABLE_ID,
261
+ id: operation.$id,
262
+ });
263
+ deletedCount++;
264
+ }
265
+ catch (error) {
266
+ logger.warn("Failed to delete operation", {
267
+ operationId: operation.$id,
268
+ error: error instanceof Error ? error.message : String(error),
269
+ });
270
+ }
271
+ }
272
+ logger.info("Cleaned up old operations", {
273
+ databaseId,
274
+ deletedCount,
275
+ cutoffDate: cutoffIso,
276
+ });
277
+ return deletedCount;
278
+ }
279
+ catch (error) {
280
+ logger.error("Failed to cleanup operations", {
281
+ databaseId,
282
+ error: error instanceof Error ? error.message : String(error),
283
+ });
284
+ return 0;
285
+ }
286
+ }
@@ -0,0 +1,48 @@
1
+ /**
2
+ * Schema for operation tracking table (_appwrite_operations)
3
+ *
4
+ * This table is created dynamically in each database to track long-running operations
5
+ * like imports, exports, transfers, and backups.
6
+ */
7
+ import { z } from "zod";
8
+ export interface OperationRecord {
9
+ $id: string;
10
+ $createdAt: string;
11
+ $updatedAt: string;
12
+ operationType: string;
13
+ targetCollection?: string;
14
+ status: OperationStatus;
15
+ progress: number;
16
+ total: number;
17
+ data?: any;
18
+ error?: string;
19
+ }
20
+ export type OperationStatus = 'pending' | 'in_progress' | 'completed' | 'failed' | 'cancelled';
21
+ export declare const OPERATION_STATUSES: readonly ["pending", "in_progress", "completed", "failed", "cancelled"];
22
+ export declare const OperationStatusSchema: z.ZodEnum<{
23
+ pending: "pending";
24
+ in_progress: "in_progress";
25
+ completed: "completed";
26
+ cancelled: "cancelled";
27
+ failed: "failed";
28
+ }>;
29
+ export declare const OperationRecordSchema: z.ZodObject<{
30
+ $id: z.ZodString;
31
+ $createdAt: z.ZodString;
32
+ $updatedAt: z.ZodString;
33
+ operationType: z.ZodString;
34
+ targetCollection: z.ZodOptional<z.ZodString>;
35
+ status: z.ZodEnum<{
36
+ pending: "pending";
37
+ in_progress: "in_progress";
38
+ completed: "completed";
39
+ cancelled: "cancelled";
40
+ failed: "failed";
41
+ }>;
42
+ progress: z.ZodNumber;
43
+ total: z.ZodNumber;
44
+ data: z.ZodOptional<z.ZodAny>;
45
+ error: z.ZodOptional<z.ZodString>;
46
+ }, z.core.$strip>;
47
+ export declare const OPERATIONS_TABLE_ID = "_appwrite_operations";
48
+ export declare const OPERATIONS_TABLE_NAME = "Operations Tracking";
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Schema for operation tracking table (_appwrite_operations)
3
+ *
4
+ * This table is created dynamically in each database to track long-running operations
5
+ * like imports, exports, transfers, and backups.
6
+ */
7
+ import { z } from "zod";
8
+ export const OPERATION_STATUSES = [
9
+ 'pending',
10
+ 'in_progress',
11
+ 'completed',
12
+ 'failed',
13
+ 'cancelled'
14
+ ];
15
+ export const OperationStatusSchema = z.enum([
16
+ 'pending',
17
+ 'in_progress',
18
+ 'completed',
19
+ 'failed',
20
+ 'cancelled'
21
+ ]);
22
+ export const OperationRecordSchema = z.object({
23
+ $id: z.string(),
24
+ $createdAt: z.string(),
25
+ $updatedAt: z.string(),
26
+ operationType: z.string(),
27
+ targetCollection: z.string().optional(),
28
+ status: OperationStatusSchema,
29
+ progress: z.number(),
30
+ total: z.number(),
31
+ data: z.any().optional(),
32
+ error: z.string().optional()
33
+ });
34
+ export const OPERATIONS_TABLE_ID = "_appwrite_operations";
35
+ export const OPERATIONS_TABLE_NAME = "Operations Tracking";
@@ -0,0 +1,62 @@
1
+ export interface ProgressOptions {
2
+ title?: string;
3
+ showETA?: boolean;
4
+ showSpeed?: boolean;
5
+ showPercentage?: boolean;
6
+ width?: number;
7
+ format?: string;
8
+ }
9
+ export declare class ProgressManager {
10
+ private static instances;
11
+ private bar;
12
+ private startTime;
13
+ private totalItems;
14
+ private completed;
15
+ private id;
16
+ private title;
17
+ private constructor();
18
+ static create(id: string, total: number, options?: ProgressOptions): ProgressManager;
19
+ static get(id: string): ProgressManager | undefined;
20
+ update(current: number, detail?: string): void;
21
+ increment(amount?: number, detail?: string): void;
22
+ setTotal(total: number): void;
23
+ stop(showSummary?: boolean): void;
24
+ fail(error: string): void;
25
+ getStats(): {
26
+ completed: number;
27
+ total: number;
28
+ percentage: number;
29
+ duration: number;
30
+ rate: number;
31
+ remaining: number;
32
+ eta: number;
33
+ };
34
+ static stopAll(): void;
35
+ }
36
+ export declare class MultiProgressManager {
37
+ private multiBar;
38
+ private bars;
39
+ private startTime;
40
+ constructor(options?: ProgressOptions);
41
+ addTask(id: string, total: number, title: string): void;
42
+ updateTask(id: string, current: number, detail?: string): void;
43
+ incrementTask(id: string, amount?: number, detail?: string): void;
44
+ completeTask(id: string): void;
45
+ failTask(id: string, error: string): void;
46
+ stop(showSummary?: boolean): void;
47
+ getTaskStats(id: string): {
48
+ completed: number;
49
+ total: number;
50
+ percentage: number;
51
+ remaining: number;
52
+ } | null;
53
+ getAllStats(): Map<string, any>;
54
+ }
55
+ export declare const ProgressUtils: {
56
+ withProgress<T>(id: string, total: number, title: string, operation: (progress: ProgressManager) => Promise<T>): Promise<T>;
57
+ processArrayWithProgress<T, R>(items: T[], processor: (item: T, index: number) => Promise<R>, options?: {
58
+ title?: string;
59
+ batchSize?: number;
60
+ showDetail?: boolean;
61
+ }): Promise<R[]>;
62
+ };
@@ -0,0 +1,215 @@
1
+ import cliProgress from "cli-progress";
2
+ import chalk from "chalk";
3
+ import { MessageFormatter } from "./messageFormatter.js";
4
+ export class ProgressManager {
5
+ static instances = new Map();
6
+ bar;
7
+ startTime;
8
+ totalItems;
9
+ completed = 0;
10
+ id;
11
+ title;
12
+ constructor(id, total, options = {}) {
13
+ this.id = id;
14
+ this.totalItems = total;
15
+ this.startTime = Date.now();
16
+ this.title = options.title || "Processing";
17
+ const format = options.format ||
18
+ `${chalk.cyan(this.title)} ${chalk.yellow("[{bar}]")} {percentage}% | {value}/{total} | ETA: {eta}s | Speed: {speed}/s`;
19
+ this.bar = new cliProgress.SingleBar({
20
+ format,
21
+ barCompleteChar: '█',
22
+ barIncompleteChar: '░',
23
+ hideCursor: true,
24
+ clearOnComplete: false,
25
+ stopOnComplete: true,
26
+ ...options,
27
+ }, cliProgress.Presets.shades_classic);
28
+ this.bar.start(total, 0);
29
+ }
30
+ static create(id, total, options = {}) {
31
+ if (ProgressManager.instances.has(id)) {
32
+ const existing = ProgressManager.instances.get(id);
33
+ existing.stop();
34
+ }
35
+ const instance = new ProgressManager(id, total, options);
36
+ ProgressManager.instances.set(id, instance);
37
+ return instance;
38
+ }
39
+ static get(id) {
40
+ return ProgressManager.instances.get(id);
41
+ }
42
+ update(current, detail) {
43
+ this.completed = current;
44
+ // Calculate speed
45
+ const elapsed = (Date.now() - this.startTime) / 1000;
46
+ const speed = elapsed > 0 ? Math.round(current / elapsed) : 0;
47
+ this.bar.update(current, {
48
+ speed,
49
+ detail: detail || '',
50
+ });
51
+ if (detail) {
52
+ // Update the payload for custom formatting
53
+ this.bar.update(current, { detail });
54
+ }
55
+ }
56
+ increment(amount = 1, detail) {
57
+ this.update(this.completed + amount, detail);
58
+ }
59
+ setTotal(total) {
60
+ this.totalItems = total;
61
+ this.bar.setTotal(total);
62
+ }
63
+ stop(showSummary = true) {
64
+ this.bar.stop();
65
+ if (showSummary) {
66
+ const duration = Date.now() - this.startTime;
67
+ const rate = this.completed / (duration / 1000);
68
+ MessageFormatter.success(`${this.title} completed`, {
69
+ prefix: `${this.completed}/${this.totalItems} items in ${MessageFormatter.formatDuration(duration)} (${rate.toFixed(1)}/s)`
70
+ });
71
+ }
72
+ ProgressManager.instances.delete(this.id);
73
+ }
74
+ fail(error) {
75
+ this.bar.stop();
76
+ MessageFormatter.error(`${this.title} failed: ${error}`);
77
+ ProgressManager.instances.delete(this.id);
78
+ }
79
+ getStats() {
80
+ const duration = Date.now() - this.startTime;
81
+ const rate = this.completed / (duration / 1000);
82
+ return {
83
+ completed: this.completed,
84
+ total: this.totalItems,
85
+ percentage: (this.completed / this.totalItems) * 100,
86
+ duration,
87
+ rate,
88
+ remaining: this.totalItems - this.completed,
89
+ eta: this.completed > 0 ? ((this.totalItems - this.completed) / rate) * 1000 : 0,
90
+ };
91
+ }
92
+ static stopAll() {
93
+ for (const [id, instance] of ProgressManager.instances) {
94
+ instance.stop(false);
95
+ }
96
+ ProgressManager.instances.clear();
97
+ }
98
+ }
99
+ export class MultiProgressManager {
100
+ multiBar;
101
+ bars = new Map();
102
+ startTime;
103
+ constructor(options = {}) {
104
+ this.startTime = Date.now();
105
+ this.multiBar = new cliProgress.MultiBar({
106
+ clearOnComplete: false,
107
+ hideCursor: true,
108
+ format: options.format || `${chalk.cyan("{title}")} ${chalk.yellow("[{bar}]")} {percentage}% | {value}/{total} | {detail}`,
109
+ barCompleteChar: '█',
110
+ barIncompleteChar: '░',
111
+ }, cliProgress.Presets.shades_classic);
112
+ }
113
+ addTask(id, total, title) {
114
+ const bar = this.multiBar.create(total, 0, {
115
+ title: title.padEnd(20),
116
+ detail: '',
117
+ });
118
+ this.bars.set(id, bar);
119
+ }
120
+ updateTask(id, current, detail) {
121
+ const bar = this.bars.get(id);
122
+ if (bar) {
123
+ bar.update(current, {
124
+ detail: detail || '',
125
+ });
126
+ }
127
+ }
128
+ incrementTask(id, amount = 1, detail) {
129
+ const bar = this.bars.get(id);
130
+ if (bar) {
131
+ const currentValue = bar.getProgress() * bar.getTotal();
132
+ this.updateTask(id, currentValue + amount, detail);
133
+ }
134
+ }
135
+ completeTask(id) {
136
+ const bar = this.bars.get(id);
137
+ if (bar) {
138
+ bar.update(bar.getTotal());
139
+ }
140
+ }
141
+ failTask(id, error) {
142
+ const bar = this.bars.get(id);
143
+ if (bar) {
144
+ bar.update(bar.getProgress() * bar.getTotal(), {
145
+ detail: chalk.red(`Failed: ${error}`),
146
+ });
147
+ }
148
+ }
149
+ stop(showSummary = true) {
150
+ this.multiBar.stop();
151
+ if (showSummary) {
152
+ const duration = Date.now() - this.startTime;
153
+ MessageFormatter.success(`All tasks completed in ${MessageFormatter.formatDuration(duration)}`);
154
+ }
155
+ }
156
+ getTaskStats(id) {
157
+ const bar = this.bars.get(id);
158
+ if (!bar)
159
+ return null;
160
+ const progress = bar.getProgress();
161
+ const total = bar.getTotal();
162
+ const completed = Math.floor(progress * total);
163
+ return {
164
+ completed,
165
+ total,
166
+ percentage: progress * 100,
167
+ remaining: total - completed,
168
+ };
169
+ }
170
+ getAllStats() {
171
+ const stats = new Map();
172
+ for (const [id, bar] of this.bars) {
173
+ stats.set(id, this.getTaskStats(id));
174
+ }
175
+ return stats;
176
+ }
177
+ }
178
+ // Utility functions for common progress scenarios
179
+ export const ProgressUtils = {
180
+ async withProgress(id, total, title, operation) {
181
+ const progress = ProgressManager.create(id, total, { title });
182
+ try {
183
+ const result = await operation(progress);
184
+ progress.stop();
185
+ return result;
186
+ }
187
+ catch (error) {
188
+ progress.fail(error instanceof Error ? error.message : String(error));
189
+ throw error;
190
+ }
191
+ },
192
+ async processArrayWithProgress(items, processor, options = {}) {
193
+ const { title = "Processing items", batchSize = 1, showDetail = true } = options;
194
+ const progress = ProgressManager.create(`process-${Date.now()}`, items.length, { title });
195
+ const results = [];
196
+ try {
197
+ for (let i = 0; i < items.length; i += batchSize) {
198
+ const batch = items.slice(i, i + batchSize);
199
+ const batchResults = await Promise.all(batch.map(async (item, batchIndex) => {
200
+ const result = await processor(item, i + batchIndex);
201
+ const detail = showDetail ? `Item ${i + batchIndex + 1}: ${String(item).slice(0, 30)}...` : undefined;
202
+ progress.update(i + batchIndex + 1, detail);
203
+ return result;
204
+ }));
205
+ results.push(...batchResults);
206
+ }
207
+ progress.stop();
208
+ return results;
209
+ }
210
+ catch (error) {
211
+ progress.fail(error instanceof Error ? error.message : String(error));
212
+ throw error;
213
+ }
214
+ },
215
+ };
@@ -0,0 +1,17 @@
1
+ import type { AppwriteConfig } from '@njdamstra/appwrite-utils';
2
+ export declare class PydanticModelGenerator {
3
+ private config;
4
+ private appwriteFolderPath;
5
+ constructor(config: AppwriteConfig, appwriteFolderPath: string);
6
+ generatePydanticModels(options: {
7
+ baseOutputDirectory: string;
8
+ verbose?: boolean;
9
+ }): void;
10
+ private writeBase;
11
+ private generateModel;
12
+ private composeHeader;
13
+ private defaultInitializer;
14
+ private mapAttributeToPythonType;
15
+ private toSnake;
16
+ private toPascal;
17
+ }