@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,369 @@
1
+ import fs from "fs/promises";
2
+ import path from "path";
3
+ import { type AppwriteConfig } from "@njdamstra/appwrite-utils";
4
+ import { MessageFormatter } from "../shared/messageFormatter.js";
5
+
6
+ export type SupportedLanguage =
7
+ | "typescript"
8
+ | "javascript"
9
+ | "python"
10
+ | "php"
11
+ | "dart"
12
+ | "json"
13
+ | "env";
14
+
15
+ interface Constants {
16
+ databases: Record<string, string>;
17
+ collections: Record<string, string>;
18
+ buckets: Record<string, string>;
19
+ functions: Record<string, string>;
20
+ }
21
+
22
+ export class ConstantsGenerator {
23
+ private config: AppwriteConfig;
24
+ private constants: Constants;
25
+
26
+ constructor(config: AppwriteConfig) {
27
+ this.config = config;
28
+ this.constants = this.extractConstants();
29
+ }
30
+
31
+ private extractConstants(): Constants {
32
+ const constants: Constants = {
33
+ databases: {},
34
+ collections: {},
35
+ buckets: {},
36
+ functions: {}
37
+ };
38
+
39
+ // Extract database IDs
40
+ this.config.databases?.forEach(db => {
41
+ if (db.$id) {
42
+ const key = this.toConstantName(db.name || db.$id);
43
+ constants.databases[key] = db.$id;
44
+ }
45
+ });
46
+
47
+ // Extract collection IDs
48
+ this.config.collections?.forEach(collection => {
49
+ if (collection.$id) {
50
+ const key = this.toConstantName(collection.name || collection.$id);
51
+ constants.collections[key] = collection.$id;
52
+ }
53
+ });
54
+
55
+ // Extract bucket IDs
56
+ this.config.buckets?.forEach(bucket => {
57
+ if (bucket.$id) {
58
+ const key = this.toConstantName(bucket.name || bucket.$id);
59
+ constants.buckets[key] = bucket.$id;
60
+ }
61
+ });
62
+
63
+ // Extract function IDs
64
+ this.config.functions?.forEach(func => {
65
+ if (func.$id) {
66
+ const key = this.toConstantName(func.name || func.$id);
67
+ constants.functions[key] = func.$id;
68
+ }
69
+ });
70
+
71
+ return constants;
72
+ }
73
+
74
+ private toConstantName(name: string): string {
75
+ return name
76
+ .replace(/[^a-zA-Z0-9]/g, '_')
77
+ .replace(/_+/g, '_')
78
+ .replace(/^_|_$/g, '')
79
+ .toUpperCase();
80
+ }
81
+
82
+ private toCamelCase(name: string): string {
83
+ return name
84
+ .toLowerCase()
85
+ .replace(/_([a-z])/g, (_, letter) => letter.toUpperCase());
86
+ }
87
+
88
+ private toSnakeCase(name: string): string {
89
+ return name.toLowerCase();
90
+ }
91
+
92
+ generateTypeScript(constantsOverride?: Constants): string {
93
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
94
+
95
+ return `// Auto-generated Appwrite constants
96
+ // Generated on ${new Date().toISOString()}
97
+
98
+ export const DATABASE_IDS = {
99
+ ${Object.entries(databases).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
100
+ } as const;
101
+
102
+ export const COLLECTION_IDS = {
103
+ ${Object.entries(collections).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
104
+ } as const;
105
+
106
+ export const BUCKET_IDS = {
107
+ ${Object.entries(buckets).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
108
+ } as const;
109
+
110
+ export const FUNCTION_IDS = {
111
+ ${Object.entries(functions).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
112
+ } as const;
113
+
114
+ // Type helpers
115
+ export type DatabaseId = typeof DATABASE_IDS[keyof typeof DATABASE_IDS];
116
+ export type CollectionId = typeof COLLECTION_IDS[keyof typeof COLLECTION_IDS];
117
+ export type BucketId = typeof BUCKET_IDS[keyof typeof BUCKET_IDS];
118
+ export type FunctionId = typeof FUNCTION_IDS[keyof typeof FUNCTION_IDS];
119
+
120
+ // Helper objects for runtime use
121
+ export const ALL_DATABASE_IDS = Object.values(DATABASE_IDS);
122
+ export const ALL_COLLECTION_IDS = Object.values(COLLECTION_IDS);
123
+ export const ALL_BUCKET_IDS = Object.values(BUCKET_IDS);
124
+ export const ALL_FUNCTION_IDS = Object.values(FUNCTION_IDS);
125
+ `;
126
+ }
127
+
128
+ generateJavaScript(constantsOverride?: Constants): string {
129
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
130
+
131
+ return `// Auto-generated Appwrite constants
132
+ // Generated on ${new Date().toISOString()}
133
+
134
+ export const DATABASE_IDS = {
135
+ ${Object.entries(databases).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
136
+ };
137
+
138
+ export const COLLECTION_IDS = {
139
+ ${Object.entries(collections).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
140
+ };
141
+
142
+ export const BUCKET_IDS = {
143
+ ${Object.entries(buckets).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
144
+ };
145
+
146
+ export const FUNCTION_IDS = {
147
+ ${Object.entries(functions).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
148
+ };
149
+
150
+ // Helper arrays for runtime use
151
+ export const ALL_DATABASE_IDS = Object.values(DATABASE_IDS);
152
+ export const ALL_COLLECTION_IDS = Object.values(COLLECTION_IDS);
153
+ export const ALL_BUCKET_IDS = Object.values(BUCKET_IDS);
154
+ export const ALL_FUNCTION_IDS = Object.values(FUNCTION_IDS);
155
+ `;
156
+ }
157
+
158
+ generatePython(constantsOverride?: Constants): string {
159
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
160
+
161
+ return `# Auto-generated Appwrite constants
162
+ # Generated on ${new Date().toISOString()}
163
+
164
+ class DatabaseIds:
165
+ """Database ID constants"""
166
+ ${Object.entries(databases).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
167
+
168
+ class CollectionIds:
169
+ """Collection ID constants"""
170
+ ${Object.entries(collections).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
171
+
172
+ class BucketIds:
173
+ """Bucket ID constants"""
174
+ ${Object.entries(buckets).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
175
+
176
+ class FunctionIds:
177
+ """Function ID constants"""
178
+ ${Object.entries(functions).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
179
+
180
+ # Helper dictionaries for runtime use
181
+ DATABASE_ID_MAP = {
182
+ ${Object.entries(databases).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
183
+ }
184
+
185
+ COLLECTION_ID_MAP = {
186
+ ${Object.entries(collections).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
187
+ }
188
+
189
+ BUCKET_ID_MAP = {
190
+ ${Object.entries(buckets).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
191
+ }
192
+
193
+ FUNCTION_ID_MAP = {
194
+ ${Object.entries(functions).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
195
+ }
196
+ `;
197
+ }
198
+
199
+ generatePHP(constantsOverride?: Constants): string {
200
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
201
+
202
+ return `<?php
203
+ // Auto-generated Appwrite constants
204
+ // Generated on ${new Date().toISOString()}
205
+
206
+ class AppwriteConstants {
207
+
208
+ const DATABASE_IDS = [
209
+ ${Object.entries(databases).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
210
+ ];
211
+
212
+ const COLLECTION_IDS = [
213
+ ${Object.entries(collections).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
214
+ ];
215
+
216
+ const BUCKET_IDS = [
217
+ ${Object.entries(buckets).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
218
+ ];
219
+
220
+ const FUNCTION_IDS = [
221
+ ${Object.entries(functions).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
222
+ ];
223
+
224
+ /**
225
+ * Get all database IDs as array
226
+ */
227
+ public static function getAllDatabaseIds(): array {
228
+ return array_values(self::DATABASE_IDS);
229
+ }
230
+
231
+ /**
232
+ * Get all collection IDs as array
233
+ */
234
+ public static function getAllCollectionIds(): array {
235
+ return array_values(self::COLLECTION_IDS);
236
+ }
237
+
238
+ /**
239
+ * Get all bucket IDs as array
240
+ */
241
+ public static function getAllBucketIds(): array {
242
+ return array_values(self::BUCKET_IDS);
243
+ }
244
+
245
+ /**
246
+ * Get all function IDs as array
247
+ */
248
+ public static function getAllFunctionIds(): array {
249
+ return array_values(self::FUNCTION_IDS);
250
+ }
251
+ }
252
+ `;
253
+ }
254
+
255
+ generateDart(constantsOverride?: Constants): string {
256
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
257
+
258
+ return `// Auto-generated Appwrite constants
259
+ // Generated on ${new Date().toISOString()}
260
+
261
+ class AppwriteConstants {
262
+
263
+ static const Map<String, String> databaseIds = {
264
+ ${Object.entries(databases).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
265
+ };
266
+
267
+ static const Map<String, String> collectionIds = {
268
+ ${Object.entries(collections).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
269
+ };
270
+
271
+ static const Map<String, String> bucketIds = {
272
+ ${Object.entries(buckets).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
273
+ };
274
+
275
+ static const Map<String, String> functionIds = {
276
+ ${Object.entries(functions).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
277
+ };
278
+
279
+ // Helper getters for individual IDs
280
+ ${Object.entries(databases).map(([key, value]) => ` static String get ${this.toCamelCase(key)}DatabaseId => '${value}';`).join('\n')}
281
+
282
+ ${Object.entries(collections).map(([key, value]) => ` static String get ${this.toCamelCase(key)}CollectionId => '${value}';`).join('\n')}
283
+
284
+ ${Object.entries(buckets).map(([key, value]) => ` static String get ${this.toCamelCase(key)}BucketId => '${value}';`).join('\n')}
285
+
286
+ ${Object.entries(functions).map(([key, value]) => ` static String get ${this.toCamelCase(key)}FunctionId => '${value}';`).join('\n')}
287
+ }
288
+ `;
289
+ }
290
+
291
+ generateJSON(constantsOverride?: Constants): string {
292
+ const c = constantsOverride || this.constants;
293
+ return JSON.stringify({
294
+ meta: {
295
+ generated: new Date().toISOString(),
296
+ generator: "@njdamstra/appwrite-utils-cli"
297
+ },
298
+ databases: c.databases,
299
+ collections: c.collections,
300
+ buckets: c.buckets,
301
+ functions: c.functions
302
+ }, null, 2);
303
+ }
304
+
305
+ generateEnv(constantsOverride?: Constants): string {
306
+ const { databases, collections, buckets, functions } = constantsOverride || this.constants;
307
+
308
+ const lines = [
309
+ "# Auto-generated Appwrite constants",
310
+ `# Generated on ${new Date().toISOString()}`,
311
+ "",
312
+ "# Database IDs",
313
+ ...Object.entries(databases).map(([key, value]) => `DATABASE_${key}=${value}`),
314
+ "",
315
+ "# Collection IDs",
316
+ ...Object.entries(collections).map(([key, value]) => `COLLECTION_${key}=${value}`),
317
+ "",
318
+ "# Bucket IDs",
319
+ ...Object.entries(buckets).map(([key, value]) => `BUCKET_${key}=${value}`),
320
+ "",
321
+ "# Function IDs",
322
+ ...Object.entries(functions).map(([key, value]) => `FUNCTION_${key}=${value}`)
323
+ ];
324
+
325
+ return lines.join('\n');
326
+ }
327
+
328
+ async generateFiles(
329
+ languages: SupportedLanguage[],
330
+ outputDir: string,
331
+ include?: { databases?: boolean; collections?: boolean; buckets?: boolean; functions?: boolean }
332
+ ): Promise<void> {
333
+ await fs.mkdir(outputDir, { recursive: true });
334
+
335
+ const filterConstants = (): Constants => {
336
+ if (!include) return this.constants;
337
+ return {
338
+ databases: include.databases === false ? {} : this.constants.databases,
339
+ collections: include.collections === false ? {} : this.constants.collections,
340
+ buckets: include.buckets === false ? {} : this.constants.buckets,
341
+ functions: include.functions === false ? {} : this.constants.functions,
342
+ };
343
+ };
344
+
345
+ const subset = filterConstants();
346
+
347
+ const generators = {
348
+ typescript: () => ({ content: this.generateTypeScript(subset), filename: "appwrite-constants.ts" }),
349
+ javascript: () => ({ content: this.generateJavaScript(subset), filename: "appwrite-constants.js" }),
350
+ python: () => ({ content: this.generatePython(subset), filename: "appwrite_constants.py" }),
351
+ php: () => ({ content: this.generatePHP(subset), filename: "AppwriteConstants.php" }),
352
+ dart: () => ({ content: this.generateDart(subset), filename: "appwrite_constants.dart" }),
353
+ json: () => ({ content: this.generateJSON(subset), filename: "appwrite-constants.json" }),
354
+ env: () => ({ content: this.generateEnv(subset), filename: ".env.appwrite" })
355
+ };
356
+
357
+ for (const language of languages) {
358
+ const generator = generators[language];
359
+ if (generator) {
360
+ const { content, filename } = generator();
361
+ const filePath = path.join(outputDir, filename);
362
+ await fs.writeFile(filePath, content, 'utf-8');
363
+ MessageFormatter.success(`Generated ${language} constants: ${filePath}`, { prefix: "Constants" });
364
+ } else {
365
+ MessageFormatter.error(`Unsupported language: ${language}`, undefined, { prefix: "Constants" });
366
+ }
367
+ }
368
+ }
369
+ }
@@ -0,0 +1,159 @@
1
+ import { converterFunctions, type AttributeMappings } from "@njdamstra/appwrite-utils";
2
+ import { cloneDeep, isPlainObject } from "es-toolkit";
3
+
4
+ /**
5
+ * Deeply converts all properties of an object (or array) to strings.
6
+ * @param data The input data to convert.
7
+ * @returns The data with all its properties converted to strings.
8
+ */
9
+ export const deepAnyToString = (data: any): any => {
10
+ if (Array.isArray(data)) {
11
+ return data.map((item) => deepAnyToString(item));
12
+ } else if (isPlainObject(data)) {
13
+ return Object.keys(data).reduce((acc, key) => {
14
+ acc[key] = deepAnyToString(data[key as keyof typeof data]);
15
+ return acc;
16
+ }, {} as Record<string, any>);
17
+ } else {
18
+ return converterFunctions.anyToString(data);
19
+ }
20
+ };
21
+
22
+ /**
23
+ * Performs a deep conversion of all values in a nested structure to the specified type.
24
+ * Uses a conversion function like anyToString, anyToNumber, etc.
25
+ * @param data The data to convert.
26
+ * @param convertFn The conversion function to apply.
27
+ * @returns The converted data.
28
+ */
29
+ export const deepConvert = <T>(
30
+ data: any,
31
+ convertFn: (value: any) => T
32
+ ): any => {
33
+ if (Array.isArray(data)) {
34
+ return data.map((item) => deepConvert(item, convertFn));
35
+ } else if (isPlainObject(data)) {
36
+ return Object.keys(data).reduce((acc: Record<string, T>, key: string) => {
37
+ acc[key] = deepConvert(data[key as keyof typeof data], convertFn);
38
+ return acc;
39
+ }, {});
40
+ } else {
41
+ return convertFn(data);
42
+ }
43
+ };
44
+
45
+ /**
46
+ * Converts an entire object's properties to different types based on a provided schema.
47
+ * @param obj The object to convert.
48
+ * @param schema A mapping of object keys to conversion functions.
49
+ * @returns The converted object.
50
+ */
51
+ export const convertObjectBySchema = (
52
+ obj: Record<string, any>,
53
+ schema: Record<string, (value: any) => any>
54
+ ): Record<string, any> => {
55
+ return Object.keys(obj).reduce((acc: Record<string, any>, key: string) => {
56
+ const convertFn = schema[key];
57
+ acc[key] = convertFn ? convertFn(obj[key]) : obj[key];
58
+ return acc;
59
+ }, {});
60
+ };
61
+
62
+ /**
63
+ * Converts the keys of an object based on a provided attributeMappings.
64
+ * Each key in the object is checked against attributeMappings; if a matching entry is found,
65
+ * the key is renamed to the targetKey specified in attributeMappings.
66
+ *
67
+ * @param obj The object to convert.
68
+ * @param attributeMappings The attributeMappings defining how keys in the object should be converted.
69
+ * @returns The converted object with keys renamed according to attributeMappings.
70
+ */
71
+ export const convertObjectByAttributeMappings = (
72
+ obj: Record<string, any>,
73
+ attributeMappings: AttributeMappings
74
+ ): Record<string, any> => {
75
+ const result: Record<string, any> = {};
76
+
77
+ // Correctly handle [any] notation by mapping or aggregating over all elements or keys
78
+ const resolveValue = (obj: Record<string, any>, path: string): any => {
79
+ const parts = path.split(".");
80
+ let current = obj;
81
+
82
+ for (let i = 0; i < parts.length; i++) {
83
+ if (parts[i] === "[any]") {
84
+ if (Array.isArray(current)) {
85
+ // If current is an array, apply resolution to each item
86
+ return current.map((item) =>
87
+ resolveValue(item, parts.slice(i + 1).join("."))
88
+ );
89
+ } else if (typeof current === "object" && current !== null) {
90
+ // If current is an object, aggregate values from all keys
91
+ return Object.values(current).map((value) =>
92
+ resolveValue(value, parts.slice(i + 1).join("."))
93
+ );
94
+ }
95
+ } else {
96
+ current = current[parts[i]];
97
+ if (current === undefined) return undefined;
98
+ }
99
+ }
100
+ return current;
101
+ };
102
+
103
+ for (const mapping of attributeMappings) {
104
+ if (mapping.valueToSet !== undefined) {
105
+ result[mapping.targetKey] = mapping.valueToSet;
106
+ } else if (Array.isArray(mapping.oldKeys)) {
107
+ // Collect and flatten values from multiple oldKeys
108
+ const values = mapping.oldKeys
109
+ .map((oldKey) => resolveValue(obj, oldKey))
110
+ .flat(Infinity);
111
+ if (values.length > 0) {
112
+ result[mapping.targetKey] = values.filter(
113
+ (value) => value !== undefined
114
+ );
115
+ } else {
116
+ result[mapping.targetKey] = null;
117
+ }
118
+ } else if (mapping.oldKey) {
119
+ // Resolve single oldKey
120
+ const value = resolveValue(obj, mapping.oldKey);
121
+ if (value !== undefined) {
122
+ result[mapping.targetKey] = Array.isArray(value)
123
+ ? value.flat(Infinity)
124
+ : value;
125
+ } else {
126
+ result[mapping.targetKey] = value ? value : null;
127
+ }
128
+ }
129
+ }
130
+
131
+ return result;
132
+ };
133
+
134
+ /**
135
+ * Ensures data conversion without mutating the original input.
136
+ * @param data The data to convert.
137
+ * @param convertFn The conversion function to apply.
138
+ * @returns The converted data.
139
+ */
140
+ export const immutableConvert = <T>(
141
+ data: any,
142
+ convertFn: (value: any) => T
143
+ ): T => {
144
+ const clonedData = cloneDeep(data);
145
+ return convertFn(clonedData);
146
+ };
147
+
148
+ /**
149
+ * Validates a string against a regular expression and returns the string if valid, or null.
150
+ * @param value The string to validate.
151
+ * @param pattern The regex pattern to validate against.
152
+ * @returns The original string if valid, otherwise null.
153
+ */
154
+ export const validateString = (
155
+ value: string,
156
+ pattern: RegExp
157
+ ): string | null => {
158
+ return pattern.test(value) ? value : null;
159
+ };
@@ -0,0 +1,61 @@
1
+ /**
2
+ * Directory utility functions for filtering and managing directory traversal
3
+ */
4
+
5
+ /**
6
+ * List of directories that should be ignored during recursive searches
7
+ * Includes common build outputs, dependencies, caches, and system folders
8
+ */
9
+ export const IGNORED_DIRECTORIES = [
10
+ 'node_modules',
11
+ 'dist',
12
+ 'build',
13
+ 'coverage',
14
+ '.next',
15
+ '.nuxt',
16
+ '.cache',
17
+ '.git',
18
+ '.svn',
19
+ '.hg',
20
+ '__pycache__',
21
+ '.pytest_cache',
22
+ '.mypy_cache',
23
+ 'venv',
24
+ '.venv',
25
+ 'env',
26
+ '.env',
27
+ 'target',
28
+ 'out',
29
+ 'bin',
30
+ 'obj',
31
+ '.vs',
32
+ '.vscode',
33
+ '.idea',
34
+ 'temp',
35
+ 'tmp',
36
+ '.tmp',
37
+ 'logs',
38
+ 'log',
39
+ '.DS_Store',
40
+ 'Thumbs.db'
41
+ ];
42
+
43
+ /**
44
+ * Determines if a directory should be ignored during recursive file operations
45
+ *
46
+ * @param dirName - The name of the directory to check
47
+ * @returns true if the directory should be ignored, false otherwise
48
+ *
49
+ * @remarks
50
+ * A directory is ignored if:
51
+ * - It matches one of the entries in IGNORED_DIRECTORIES
52
+ * - It starts with '.git' prefix
53
+ * - It starts with 'node_modules' prefix
54
+ * - It starts with '.' (hidden directory) except for '.appwrite'
55
+ */
56
+ export const shouldIgnoreDirectory = (dirName: string): boolean => {
57
+ return IGNORED_DIRECTORIES.includes(dirName) ||
58
+ dirName.startsWith('.git') ||
59
+ dirName.startsWith('node_modules') ||
60
+ (dirName.startsWith('.') && dirName !== '.appwrite');
61
+ };