@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,149 @@
1
+ import winston from "winston";
2
+ import fs from "fs";
3
+ import path from "path";
4
+
5
+ export interface LoggingConfig {
6
+ enabled: boolean;
7
+ level: string;
8
+ logDirectory?: string;
9
+ console: boolean;
10
+ }
11
+
12
+ /**
13
+ * Predefined logging configurations for common debugging scenarios
14
+ */
15
+ export const LOGGING_PRESETS = {
16
+ /** Minimal logging - errors only to console */
17
+ minimal: {
18
+ enabled: false,
19
+ level: 'error',
20
+ console: true
21
+ },
22
+ /** Standard logging - info level to file and console */
23
+ standard: {
24
+ enabled: true,
25
+ level: 'info',
26
+ console: true
27
+ },
28
+ /** Debug logging - verbose debug output for troubleshooting */
29
+ debug: {
30
+ enabled: true,
31
+ level: 'debug',
32
+ console: true
33
+ },
34
+ /** Silent - no logging output */
35
+ silent: {
36
+ enabled: false,
37
+ level: 'error',
38
+ console: false
39
+ }
40
+ } as const;
41
+
42
+ const DEFAULT_LOGGING_CONFIG: LoggingConfig = {
43
+ enabled: false,
44
+ level: "info",
45
+ console: false,
46
+ };
47
+
48
+ let loggingConfig: LoggingConfig = DEFAULT_LOGGING_CONFIG;
49
+
50
+ export const configureLogging = (config: Partial<LoggingConfig> = {}) => {
51
+ loggingConfig = { ...DEFAULT_LOGGING_CONFIG, ...config };
52
+ };
53
+
54
+ /**
55
+ * Configure logging using a preset
56
+ */
57
+ export const configureLoggingPreset = (preset: keyof typeof LOGGING_PRESETS, logDirectory?: string) => {
58
+ const presetConfig = LOGGING_PRESETS[preset];
59
+ configureLogging({
60
+ ...presetConfig,
61
+ ...(logDirectory && { logDirectory })
62
+ });
63
+ updateLogger();
64
+ };
65
+
66
+ const createLogger = () => {
67
+ const transports: winston.transport[] = [];
68
+
69
+ // Add console transport if enabled
70
+ if (loggingConfig.console) {
71
+ transports.push(new winston.transports.Console({
72
+ format: winston.format.combine(
73
+ winston.format.colorize(),
74
+ winston.format.simple()
75
+ )
76
+ }));
77
+ }
78
+
79
+ // Add file transports if logging is enabled
80
+ if (loggingConfig.enabled) {
81
+ const logDir = loggingConfig.logDirectory || path.join(process.cwd(), "zlogs");
82
+
83
+ if (!fs.existsSync(logDir)) {
84
+ fs.mkdirSync(logDir, { recursive: true });
85
+ }
86
+
87
+ transports.push(
88
+ new winston.transports.File({
89
+ filename: path.join(logDir, "error.log"),
90
+ level: "error",
91
+ }),
92
+ new winston.transports.File({
93
+ filename: path.join(logDir, "combined.log"),
94
+ })
95
+ );
96
+ }
97
+
98
+ return winston.createLogger({
99
+ level: loggingConfig.level,
100
+ format: winston.format.combine(
101
+ winston.format.timestamp(),
102
+ winston.format.errors({ stack: true }),
103
+ winston.format.json()
104
+ ),
105
+ defaultMeta: { service: "@njdamstra/appwrite-utils-cli" },
106
+ transports,
107
+ silent: !loggingConfig.enabled && !loggingConfig.console,
108
+ });
109
+ };
110
+
111
+ export let logger = createLogger();
112
+
113
+ // Recreate logger when config changes
114
+ export const updateLogger = () => {
115
+ logger = createLogger();
116
+ };
117
+
118
+ /**
119
+ * Enable debug logging for troubleshooting push process issues
120
+ * This is a convenience function for quickly enabling comprehensive logging
121
+ */
122
+ export const enableDebugLogging = (logDirectory?: string) => {
123
+ configureLogging({
124
+ enabled: true,
125
+ level: 'debug',
126
+ console: true,
127
+ logDirectory
128
+ });
129
+ updateLogger();
130
+ logger.info('Debug logging enabled for push process troubleshooting', {
131
+ level: 'debug',
132
+ console: true,
133
+ logDirectory: logDirectory || 'zlogs',
134
+ operation: 'enableDebugLogging'
135
+ });
136
+ };
137
+
138
+ /**
139
+ * Disable logging (reset to default)
140
+ */
141
+ export const disableLogging = () => {
142
+ configureLogging(DEFAULT_LOGGING_CONFIG);
143
+ updateLogger();
144
+ };
145
+
146
+ /**
147
+ * Get current logging configuration
148
+ */
149
+ export const getLoggingConfig = () => ({ ...loggingConfig });
@@ -0,0 +1,208 @@
1
+ import chalk from "chalk";
2
+ import { logger } from "./logging.js";
3
+
4
+ export interface MessageOptions {
5
+ prefix?: string;
6
+ skipLogging?: boolean;
7
+ logLevel?: "info" | "warn" | "error" | "debug";
8
+ }
9
+
10
+ export class MessageFormatter {
11
+ static success(message: string, options: MessageOptions = {}) {
12
+ const formatted = `${chalk.green("✅")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
13
+ console.log(formatted);
14
+
15
+ if (!options.skipLogging) {
16
+ logger.info(`SUCCESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
17
+ }
18
+ }
19
+
20
+ static error(message: string, error?: Error | string, options: MessageOptions = {}) {
21
+ const errorDetails = error instanceof Error ? error.message : error;
22
+ const formatted = `${chalk.red("❌")} ${options.prefix ? `${options.prefix}: ` : ""}${message}${errorDetails ? `\n ${chalk.gray(errorDetails)}` : ""}`;
23
+ console.error(formatted);
24
+
25
+ if (!options.skipLogging) {
26
+ logger.error(`ERROR: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, {
27
+ error: errorDetails,
28
+ stack: error instanceof Error ? error.stack : undefined,
29
+ });
30
+ }
31
+ }
32
+
33
+ static warning(message: string, options: MessageOptions = {}) {
34
+ const formatted = `${chalk.yellow("⚠️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
35
+ console.log(formatted);
36
+
37
+ if (!options.skipLogging) {
38
+ logger.warn(`WARNING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
39
+ }
40
+ }
41
+
42
+ static info(message: string, options: MessageOptions = {}) {
43
+ const formatted = `${chalk.blue("ℹ️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
44
+ console.log(formatted);
45
+
46
+ if (!options.skipLogging) {
47
+ logger.info(`INFO: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
48
+ }
49
+ }
50
+
51
+ static step(step: number, total: number, message: string, options: MessageOptions = {}) {
52
+ const formatted = `${chalk.cyan(`[${step}/${total}]`)} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
53
+ console.log(formatted);
54
+
55
+ if (!options.skipLogging) {
56
+ logger.info(`STEP ${step}/${total}: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
57
+ }
58
+ }
59
+
60
+ static progress(message: string, options: MessageOptions = {}) {
61
+ const formatted = `${chalk.gray("⏳")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
62
+ console.log(formatted);
63
+
64
+ if (!options.skipLogging) {
65
+ logger.debug(`PROGRESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
66
+ }
67
+ }
68
+
69
+ static debug(message: string, data?: any, options: MessageOptions = {}) {
70
+ if (process.env.NODE_ENV === "development" || process.env.DEBUG) {
71
+ const formatted = `${chalk.magenta("🔍")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
72
+ console.log(formatted);
73
+ if (data) {
74
+ console.log(chalk.gray(JSON.stringify(data, null, 2)));
75
+ }
76
+ }
77
+
78
+ if (!options.skipLogging) {
79
+ logger.debug(`DEBUG: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, data);
80
+ }
81
+ }
82
+
83
+ static processing(message: string, options: MessageOptions = {}) {
84
+ const formatted = `${chalk.cyan("⚙️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
85
+ console.log(formatted);
86
+
87
+ if (!options.skipLogging) {
88
+ logger.info(`PROCESSING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
89
+ }
90
+ }
91
+
92
+ static divider() {
93
+ console.log(chalk.gray("─".repeat(60)));
94
+ }
95
+
96
+ static banner(title: string, subtitle?: string) {
97
+ const divider = chalk.cyan("═".repeat(60));
98
+ console.log(`\n${divider}`);
99
+ console.log(chalk.cyan.bold(` ${title}`));
100
+ if (subtitle) {
101
+ console.log(chalk.gray(` ${subtitle}`));
102
+ }
103
+ console.log(`${divider}\n`);
104
+ }
105
+
106
+ static section(title: string) {
107
+ console.log(`\n${chalk.bold.underline(title)}`);
108
+ }
109
+
110
+ static list(items: string[], title?: string) {
111
+ if (title) {
112
+ console.log(chalk.bold(title));
113
+ }
114
+ items.forEach((item, index) => {
115
+ console.log(`${chalk.gray(` ${index + 1}.`)} ${item}`);
116
+ });
117
+ }
118
+
119
+ static table(data: Record<string, string | number>[], headers?: string[]) {
120
+ if (data.length === 0) return;
121
+
122
+ const keys = headers || Object.keys(data[0]);
123
+ const maxWidths = keys.map(key =>
124
+ Math.max(
125
+ key.length,
126
+ ...data.map(row => String(row[key]).length)
127
+ )
128
+ );
129
+
130
+ // Header
131
+ const headerRow = keys.map((key, i) =>
132
+ chalk.bold(key.padEnd(maxWidths[i]))
133
+ ).join(" │ ");
134
+ console.log(`┌─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┐`);
135
+ console.log(`│ ${headerRow} │`);
136
+ console.log(`├─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┤`);
137
+
138
+ // Rows
139
+ data.forEach(row => {
140
+ const dataRow = keys.map((key, i) =>
141
+ String(row[key]).padEnd(maxWidths[i])
142
+ ).join(" │ ");
143
+ console.log(`│ ${dataRow} │`);
144
+ });
145
+ console.log(`└─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┴─")}─┘`);
146
+ }
147
+
148
+ static operationSummary(title: string, stats: Record<string, string | number>, duration?: number) {
149
+ this.section(`${title} Summary`);
150
+
151
+ Object.entries(stats).forEach(([key, value]) => {
152
+ const formattedKey = key.replace(/([A-Z])/g, ' $1').replace(/^./, str => str.toUpperCase());
153
+ console.log(`${chalk.gray("●")} ${formattedKey}: ${chalk.cyan(String(value))}`);
154
+ });
155
+
156
+ if (duration) {
157
+ console.log(`${chalk.gray("●")} Duration: ${chalk.cyan(this.formatDuration(duration))}`);
158
+ }
159
+ console.log();
160
+ }
161
+
162
+ static formatBytes(bytes: number): string {
163
+ const units = ['B', 'KB', 'MB', 'GB', 'TB'];
164
+ let size = bytes;
165
+ let unitIndex = 0;
166
+
167
+ while (size >= 1024 && unitIndex < units.length - 1) {
168
+ size /= 1024;
169
+ unitIndex++;
170
+ }
171
+
172
+ return `${size.toFixed(1)} ${units[unitIndex]}`;
173
+ }
174
+
175
+ static formatDuration(ms: number): string {
176
+ const seconds = Math.floor(ms / 1000);
177
+ const minutes = Math.floor(seconds / 60);
178
+ const hours = Math.floor(minutes / 60);
179
+
180
+ if (hours > 0) {
181
+ return `${hours}h ${minutes % 60}m ${seconds % 60}s`;
182
+ } else if (minutes > 0) {
183
+ return `${minutes}m ${seconds % 60}s`;
184
+ } else {
185
+ return `${seconds}s`;
186
+ }
187
+ }
188
+
189
+ static formatNumber(num: number): string {
190
+ return num.toLocaleString();
191
+ }
192
+ }
193
+
194
+ export const Messages = {
195
+ CONFIG_NOT_FOUND: "Appwrite configuration not found. Run 'appwrite-migrate setup' first.",
196
+ CONFIG_LOADED: (type: string, path: string) => `Loaded ${type} configuration from ${path}`,
197
+ DATABASE_CONNECTION_FAILED: "Failed to connect to Appwrite. Check your endpoint and API key.",
198
+ OPERATION_CANCELLED: "Operation cancelled by user.",
199
+ OPERATION_COMPLETED: (operation: string) => `${operation} completed successfully`,
200
+ BACKUP_STARTED: (database: string) => `Starting backup for database: ${database}`,
201
+ BACKUP_COMPLETED: (database: string, size: number) => `Backup completed for ${database} (${MessageFormatter.formatBytes(size)})`,
202
+ IMPORT_STARTED: (collections: number) => `Starting import process for ${collections} collection(s)`,
203
+ IMPORT_COMPLETED: (documents: number) => `Import completed. Processed ${MessageFormatter.formatNumber(documents)} documents`,
204
+ FUNCTION_DEPLOYED: (name: string) => `Function '${name}' deployed successfully`,
205
+ FUNCTION_DEPLOYMENT_FAILED: (name: string, error: string) => `Function '${name}' deployment failed: ${error}`,
206
+ TRANSFER_STARTED: (source: string, target: string) => `Starting transfer from ${source} to ${target}`,
207
+ TRANSFER_COMPLETED: (items: number) => `Transfer completed. Moved ${MessageFormatter.formatNumber(items)} items`,
208
+ } as const;
@@ -0,0 +1,232 @@
1
+ import { ID, Query, type Databases } from "node-appwrite";
2
+ import { BatchSchema, OperationSchema, type Operation } from "../storage/schemas.js";
3
+ import { AttributeMappingsSchema } from "@njdamstra/appwrite-utils";
4
+ import { z } from "zod";
5
+ import { logger } from "./logging.js";
6
+ import { tryAwaitWithRetry } from "../utils/helperFunctions.js";
7
+ import {
8
+ findOrCreateOperation as findOrCreateOp,
9
+ updateOperation as updateOp,
10
+ getOperation as getOp
11
+ } from "./operationsTable.js";
12
+ import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
13
+ import { MessageFormatter } from "./messageFormatter.js";
14
+
15
+ /**
16
+ * Object that contains the context for an action that needs to be executed after import
17
+ * Used in the afterImportActionsDefinitions
18
+ * @type {ContextObject}
19
+ * @typedef {Object} ContextObject
20
+ * @property {string} collectionId - The ID of the collection
21
+ * @property {any} finalItem - The final item that was imported
22
+ * @property {string} action - The name of the action
23
+ * @property {string[]} params - The parameters for the action
24
+ * @property {Object} context - The context object for the action (all the data of this specific item)
25
+ */
26
+ export const ContextObject = z.object({
27
+ dbId: z.string(),
28
+ collectionId: z.string(),
29
+ finalItem: z.any(),
30
+ attributeMappings: AttributeMappingsSchema,
31
+ context: z.any(),
32
+ });
33
+
34
+ export type ContextObject = z.infer<typeof ContextObject>;
35
+
36
+ export const createOrFindAfterImportOperation = async (
37
+ database: Databases,
38
+ collectionId: string,
39
+ context: ContextObject
40
+ ) => {
41
+ let operation = await findOrCreateOperationLegacy(
42
+ database,
43
+ collectionId,
44
+ "afterImportAction"
45
+ );
46
+ if (!operation.batches) {
47
+ operation.batches = [];
48
+ }
49
+
50
+ // Directly create a new batch for the context without checking for an existing batch
51
+ const contextData = JSON.stringify(context);
52
+ // Create a new batch with the contextData
53
+ const newBatchId = await addBatch(database, contextData);
54
+ // Update the operation with the new batch's $id
55
+ operation.batches = [...operation.batches, newBatchId];
56
+ await database.updateDocument(
57
+ "migrations",
58
+ "currentOperations",
59
+ operation.$id,
60
+ { batches: operation.batches }
61
+ );
62
+ };
63
+
64
+ export const addBatch = async (database: Databases, data: string) => {
65
+ const batch = await database.createDocument(
66
+ "migrations",
67
+ "batches",
68
+ ID.unique(),
69
+ {
70
+ data,
71
+ processed: false,
72
+ }
73
+ );
74
+ return batch.$id;
75
+ };
76
+
77
+ export const getAfterImportOperations = async (
78
+ database: Databases,
79
+ collectionId: string
80
+ ) => {
81
+ let lastDocumentId: string | undefined;
82
+ const allOperations = [];
83
+ let total = 0;
84
+
85
+ do {
86
+ const query = [
87
+ Query.equal("collectionId", collectionId),
88
+ Query.equal("operationType", "afterImportAction"),
89
+ Query.limit(100),
90
+ ];
91
+
92
+ if (lastDocumentId) {
93
+ query.push(Query.cursorAfter(lastDocumentId));
94
+ }
95
+
96
+ const operations = await database.listDocuments(
97
+ "migrations",
98
+ "currentOperations",
99
+ query
100
+ );
101
+ total = operations.total; // Update total with the latest fetch
102
+ allOperations.push(...operations.documents);
103
+
104
+ if (operations.documents.length > 0 && operations.documents.length >= 100) {
105
+ lastDocumentId =
106
+ operations.documents[operations.documents.length - 1].$id;
107
+ }
108
+ } while (allOperations.length < total);
109
+
110
+ const allOps = allOperations.map((op) => OperationSchema.parse(op));
111
+ return allOps;
112
+ };
113
+
114
+ // Legacy function for backward compatibility with old migrations database
115
+ const findOrCreateOperationLegacy = async (
116
+ database: Databases,
117
+ collectionId: string,
118
+ operationType: string,
119
+ additionalQueries?: string[]
120
+ ) => {
121
+ const operations = await tryAwaitWithRetry(
122
+ async () =>
123
+ await database.listDocuments("migrations", "currentOperations", [
124
+ Query.equal("collectionId", collectionId),
125
+ Query.equal("operationType", operationType),
126
+ Query.equal("status", "pending"),
127
+ ...(additionalQueries || []),
128
+ ])
129
+ );
130
+
131
+ if (operations.documents.length > 0) {
132
+ return OperationSchema.parse(operations.documents[0]);
133
+ } else {
134
+ const op = await tryAwaitWithRetry(
135
+ async () =>
136
+ await database.createDocument(
137
+ "migrations",
138
+ "currentOperations",
139
+ ID.unique(),
140
+ {
141
+ operationType,
142
+ collectionId,
143
+ status: "pending",
144
+ batches: [],
145
+ progress: 0,
146
+ total: 0,
147
+ error: "",
148
+ }
149
+ )
150
+ );
151
+
152
+ return OperationSchema.parse(op);
153
+ }
154
+ };
155
+
156
+ export const findOrCreateOperation = async (
157
+ db: DatabaseAdapter,
158
+ databaseId: string,
159
+ operationType: string,
160
+ collectionId?: string,
161
+ data?: any
162
+ ): Promise<any> => {
163
+ // Use new operations table system
164
+ return await findOrCreateOp(db, databaseId, operationType, {
165
+ targetCollection: collectionId,
166
+ data: data
167
+ });
168
+ };
169
+
170
+ export const updateOperation = async (
171
+ db: DatabaseAdapter,
172
+ databaseId: string,
173
+ operationId: string,
174
+ updates: any
175
+ ): Promise<any> => {
176
+ // Use new operations table system
177
+ return await updateOp(db, databaseId, operationId, updates);
178
+ };
179
+
180
+ export const getOperation = async (
181
+ db: DatabaseAdapter,
182
+ databaseId: string,
183
+ operationId: string
184
+ ): Promise<any> => {
185
+ // Use new operations table system
186
+ return await getOp(db, databaseId, operationId);
187
+ };
188
+
189
+ // Actual max 1073741824
190
+ export const maxDataLength = 1073741820;
191
+ export const maxBatchItems = 25;
192
+
193
+ export const splitIntoBatches = (data: any[]): any[][] => {
194
+ let batches = [];
195
+ let currentBatch: any[] = [];
196
+ let currentBatchLength = 0;
197
+ let currentBatchItemCount = 0;
198
+
199
+ data.forEach((item, index) => {
200
+ const itemLength = JSON.stringify(item).length;
201
+ if (itemLength > maxDataLength) {
202
+ MessageFormatter.warning(
203
+ `Large item found at index ${index} with length ${itemLength}`,
204
+ { prefix: "Batch Splitter" }
205
+ );
206
+ logger.debug("Large item data:", item);
207
+ }
208
+ // Check if adding the current item would exceed the max length or max items per batch
209
+ if (
210
+ currentBatchLength + itemLength >= maxDataLength ||
211
+ currentBatchItemCount >= maxBatchItems
212
+ ) {
213
+ // If so, start a new batch
214
+ batches.push(currentBatch);
215
+ currentBatch = [item];
216
+ currentBatchLength = itemLength;
217
+ currentBatchItemCount = 1; // Reset item count for the new batch
218
+ } else {
219
+ // Otherwise, add the item to the current batch
220
+ currentBatch.push(item);
221
+ currentBatchLength += itemLength;
222
+ currentBatchItemCount++;
223
+ }
224
+ });
225
+
226
+ // Don't forget to add the last batch if it's not empty
227
+ if (currentBatch.length > 0) {
228
+ batches.push(currentBatch);
229
+ }
230
+
231
+ return batches;
232
+ };
@@ -0,0 +1,20 @@
1
+ import type { Databases, Models } from "node-appwrite";
2
+ import type { OperationCreate } from "../storage/schemas.js";
3
+
4
+ /**
5
+ * Legacy operation logger - deprecated
6
+ * This function is maintained for backward compatibility but no longer performs any logging.
7
+ * The operations table system has been refactored to use the dynamic adapter pattern.
8
+ *
9
+ * @deprecated This function will be removed in a future version
10
+ */
11
+ export const logOperation = async (
12
+ db: Databases,
13
+ dbId: string,
14
+ operationDetails: OperationCreate,
15
+ operationId?: string
16
+ ): Promise<Models.Document | null> => {
17
+ // No-op: Operations logging has been moved to the new operations table system
18
+ // Callers should migrate to using operationsTable.ts functions directly
19
+ return null;
20
+ };