@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,267 @@
1
+ import yaml from "js-yaml";
2
+ import fs from "fs";
3
+ import path from "path";
4
+ import { logger } from "../shared/logging.js";
5
+ import { normalizeYamlData, usesTableTerminology, convertTerminology } from "./yamlConverter.js";
6
+ import { CollectionCreateSchema, } from "@njdamstra/appwrite-utils";
7
+ /**
8
+ * Enhanced YAML loader with dual terminology support
9
+ */
10
+ export class YamlLoader {
11
+ baseDirectory;
12
+ constructor(baseDirectory) {
13
+ this.baseDirectory = baseDirectory;
14
+ }
15
+ /**
16
+ * Loads a YAML file with automatic terminology detection and normalization
17
+ */
18
+ async loadCollectionYaml(filePath) {
19
+ const fullPath = path.resolve(this.baseDirectory, filePath);
20
+ if (!fs.existsSync(fullPath)) {
21
+ throw new Error(`YAML file not found: ${fullPath}`);
22
+ }
23
+ try {
24
+ const yamlContent = fs.readFileSync(fullPath, "utf8");
25
+ const rawData = yaml.load(yamlContent);
26
+ // Detect original terminology
27
+ const originalTerminology = usesTableTerminology(rawData) ? 'table' : 'collection';
28
+ // Normalize to collection terminology for internal processing
29
+ const normalized = normalizeYamlData(rawData);
30
+ logger.info(`Loaded YAML file: ${filePath} (${originalTerminology} terminology)`);
31
+ return {
32
+ data: rawData,
33
+ originalTerminology,
34
+ normalized
35
+ };
36
+ }
37
+ catch (error) {
38
+ throw new Error(`Failed to load YAML file ${filePath}: ${error instanceof Error ? error.message : 'Unknown error'}`);
39
+ }
40
+ }
41
+ /**
42
+ * Loads multiple YAML files from a directory with terminology support
43
+ */
44
+ async loadDirectoryYamls(directoryPath, targetTerminology) {
45
+ const fullDirectoryPath = path.resolve(this.baseDirectory, directoryPath);
46
+ if (!fs.existsSync(fullDirectoryPath)) {
47
+ logger.warn(`Directory not found: ${fullDirectoryPath}`);
48
+ return {
49
+ collections: [],
50
+ summary: { total: 0, collectionFormat: 0, tableFormat: 0, converted: 0 }
51
+ };
52
+ }
53
+ const collections = [];
54
+ const files = fs.readdirSync(fullDirectoryPath, { withFileTypes: true });
55
+ let collectionFormatCount = 0;
56
+ let tableFormatCount = 0;
57
+ let convertedCount = 0;
58
+ for (const file of files) {
59
+ if (file.isFile() && file.name.endsWith('.yaml')) {
60
+ try {
61
+ const filePath = path.join(directoryPath, file.name);
62
+ const result = await this.loadCollectionYaml(filePath);
63
+ let converted;
64
+ // Convert terminology if requested and different from original
65
+ if (targetTerminology && targetTerminology !== result.originalTerminology) {
66
+ converted = convertTerminology(result.data, targetTerminology === 'table');
67
+ convertedCount++;
68
+ }
69
+ collections.push({
70
+ filePath,
71
+ data: result.data,
72
+ originalTerminology: result.originalTerminology,
73
+ converted
74
+ });
75
+ if (result.originalTerminology === 'collection') {
76
+ collectionFormatCount++;
77
+ }
78
+ else {
79
+ tableFormatCount++;
80
+ }
81
+ }
82
+ catch (error) {
83
+ logger.error(`Failed to load ${file.name}:`, error);
84
+ }
85
+ }
86
+ }
87
+ return {
88
+ collections,
89
+ summary: {
90
+ total: collections.length,
91
+ collectionFormat: collectionFormatCount,
92
+ tableFormat: tableFormatCount,
93
+ converted: convertedCount
94
+ }
95
+ };
96
+ }
97
+ /**
98
+ * Converts YAML data to CollectionCreate format for internal use
99
+ */
100
+ yamlToCollectionCreate(yamlData) {
101
+ // Always normalize to ensure consistent attribute terminology
102
+ const normalized = normalizeYamlData(yamlData);
103
+ const collectionInput = {
104
+ name: normalized.name,
105
+ $id: normalized.id || normalized.name.toLowerCase().replace(/\s+/g, '_'),
106
+ enabled: normalized.enabled !== false,
107
+ documentSecurity: normalized.documentSecurity || false,
108
+ $permissions: normalized.permissions?.map(p => ({
109
+ permission: p.permission,
110
+ target: p.target
111
+ })) || [],
112
+ attributes: normalized.attributes?.map(attr => ({
113
+ key: attr.key,
114
+ type: attr.type,
115
+ size: attr.size,
116
+ required: attr.required || false,
117
+ array: attr.array || false,
118
+ xdefault: attr.default,
119
+ min: attr.min,
120
+ max: attr.max,
121
+ elements: attr.elements,
122
+ relatedCollection: attr.relatedCollection,
123
+ relationType: attr.relationType,
124
+ twoWay: attr.twoWay,
125
+ twoWayKey: attr.twoWayKey,
126
+ onDelete: attr.onDelete,
127
+ side: attr.side,
128
+ encrypt: attr.encrypt,
129
+ format: attr.format
130
+ })) || [],
131
+ indexes: normalized.indexes?.map(idx => ({
132
+ key: idx.key,
133
+ type: idx.type,
134
+ attributes: idx.attributes,
135
+ orders: idx.orders
136
+ })) || [],
137
+ importDefs: normalized.importDefs || []
138
+ };
139
+ return CollectionCreateSchema.parse(collectionInput);
140
+ }
141
+ /**
142
+ * Saves YAML data with specified terminology
143
+ */
144
+ async saveCollectionYaml(filePath, data, config) {
145
+ const fullPath = path.resolve(this.baseDirectory, filePath);
146
+ const directory = path.dirname(fullPath);
147
+ // Ensure directory exists
148
+ if (!fs.existsSync(directory)) {
149
+ fs.mkdirSync(directory, { recursive: true });
150
+ }
151
+ // Convert to target terminology if needed
152
+ const targetData = config.useTableTerminology
153
+ ? convertTerminology(data, true)
154
+ : normalizeYamlData(data);
155
+ // Generate YAML content
156
+ const yamlContent = yaml.dump(targetData, {
157
+ indent: 2,
158
+ lineWidth: 120,
159
+ sortKeys: false,
160
+ quotingType: '"',
161
+ forceQuotes: false,
162
+ });
163
+ // Add schema reference and header
164
+ const schemaPath = config.schemaPath ||
165
+ (config.useTableTerminology ? "../.yaml_schemas/table.schema.json" : "../.yaml_schemas/collection.schema.json");
166
+ const entityType = config.useTableTerminology ? 'Table' : 'Collection';
167
+ const header = `# yaml-language-server: $schema=${schemaPath}
168
+ # ${entityType} Definition: ${data.name}
169
+ `;
170
+ const finalContent = header + yamlContent;
171
+ fs.writeFileSync(fullPath, finalContent, "utf8");
172
+ logger.info(`Saved ${entityType.toLowerCase()} YAML: ${fullPath}`);
173
+ }
174
+ /**
175
+ * Migrates YAML files from one terminology to another
176
+ */
177
+ async migrateTerminology(sourceDirectory, targetDirectory, toTableTerminology) {
178
+ const result = await this.loadDirectoryYamls(sourceDirectory);
179
+ const errors = [];
180
+ let migrated = 0;
181
+ let skipped = 0;
182
+ // Ensure target directory exists
183
+ const fullTargetPath = path.resolve(this.baseDirectory, targetDirectory);
184
+ if (!fs.existsSync(fullTargetPath)) {
185
+ fs.mkdirSync(fullTargetPath, { recursive: true });
186
+ }
187
+ for (const collection of result.collections) {
188
+ try {
189
+ const needsMigration = toTableTerminology
190
+ ? collection.originalTerminology === 'collection'
191
+ : collection.originalTerminology === 'table';
192
+ if (!needsMigration) {
193
+ skipped++;
194
+ continue;
195
+ }
196
+ const targetFileName = path.basename(collection.filePath);
197
+ const targetFilePath = path.join(targetDirectory, targetFileName);
198
+ await this.saveCollectionYaml(targetFilePath, collection.data, {
199
+ useTableTerminology: toTableTerminology,
200
+ entityType: toTableTerminology ? 'table' : 'collection'
201
+ });
202
+ migrated++;
203
+ }
204
+ catch (error) {
205
+ const errorMessage = `Failed to migrate ${collection.filePath}: ${error instanceof Error ? error.message : 'Unknown error'}`;
206
+ errors.push(errorMessage);
207
+ logger.error(errorMessage);
208
+ }
209
+ }
210
+ logger.info(`Migration complete: ${migrated} migrated, ${skipped} skipped, ${errors.length} errors`);
211
+ return { migrated, skipped, errors };
212
+ }
213
+ /**
214
+ * Validates YAML files for terminology consistency
215
+ */
216
+ async validateTerminologyConsistency(directoryPath) {
217
+ const result = await this.loadDirectoryYamls(directoryPath);
218
+ const issues = [];
219
+ let mixedFiles = 0;
220
+ for (const collection of result.collections) {
221
+ // Check for mixed terminology within a single file
222
+ const data = collection.data;
223
+ const hasAttributes = !!data.attributes && data.attributes.length > 0;
224
+ const hasColumns = !!data.columns && data.columns.length > 0;
225
+ const hasAttributeIndexes = data.indexes?.some(idx => !!idx.attributes);
226
+ const hasColumnIndexes = data.indexes?.some(idx => !!idx.columns);
227
+ if (hasAttributes && hasColumns) {
228
+ issues.push({
229
+ file: collection.filePath,
230
+ issue: "File contains both 'attributes' and 'columns' - use only one terminology",
231
+ severity: 'error'
232
+ });
233
+ mixedFiles++;
234
+ }
235
+ if (hasAttributeIndexes && hasColumnIndexes) {
236
+ issues.push({
237
+ file: collection.filePath,
238
+ issue: "Indexes contain both 'attributes' and 'columns' references - use consistent terminology",
239
+ severity: 'error'
240
+ });
241
+ }
242
+ // Check for missing required fields
243
+ if (!hasAttributes && !hasColumns) {
244
+ issues.push({
245
+ file: collection.filePath,
246
+ issue: "File missing both 'attributes' and 'columns' - at least one is required",
247
+ severity: 'warning'
248
+ });
249
+ }
250
+ }
251
+ return {
252
+ isConsistent: issues.filter(i => i.severity === 'error').length === 0,
253
+ issues,
254
+ summary: {
255
+ collectionFiles: result.summary.collectionFormat,
256
+ tableFiles: result.summary.tableFormat,
257
+ mixedFiles
258
+ }
259
+ };
260
+ }
261
+ }
262
+ /**
263
+ * Creates a YAML loader instance for the given base directory
264
+ */
265
+ export function createYamlLoader(baseDirectory) {
266
+ return new YamlLoader(baseDirectory);
267
+ }
@@ -0,0 +1,106 @@
1
+ import { Client, Databases, Storage, type Models } from "node-appwrite";
2
+ import { type AppwriteConfig, type AppwriteFunction, type Specification } from "@njdamstra/appwrite-utils";
3
+ import { type AfterImportActions, type ConverterFunctions, type ValidationRules } from "@njdamstra/appwrite-utils";
4
+ import { type TransferOptions } from "./migrations/transfer.js";
5
+ import type { DatabaseAdapter } from './adapters/DatabaseAdapter.js';
6
+ import { type ValidationResult } from "./config/configValidation.js";
7
+ import type { DatabaseSelection, BucketSelection } from "./shared/selectionDialogs.js";
8
+ export interface SetupOptions {
9
+ databases?: Models.Database[];
10
+ collections?: string[];
11
+ doBackup?: boolean;
12
+ wipeDatabase?: boolean;
13
+ wipeCollections?: boolean;
14
+ wipeDocumentStorage?: boolean;
15
+ wipeUsers?: boolean;
16
+ transferUsers?: boolean;
17
+ generateSchemas?: boolean;
18
+ importData?: boolean;
19
+ checkDuplicates?: boolean;
20
+ shouldWriteFile?: boolean;
21
+ }
22
+ export declare class UtilsController {
23
+ private static instance;
24
+ private isInitialized;
25
+ /**
26
+ * Get the UtilsController singleton instance
27
+ */
28
+ static getInstance(currentUserDir: string, directConfig?: {
29
+ appwriteEndpoint?: string;
30
+ appwriteProject?: string;
31
+ appwriteKey?: string;
32
+ }): UtilsController;
33
+ /**
34
+ * Clear the singleton instance (useful for testing)
35
+ */
36
+ static clearInstance(): void;
37
+ private appwriteFolderPath?;
38
+ private appwriteConfigPath?;
39
+ private currentUserDir;
40
+ config?: AppwriteConfig;
41
+ appwriteServer?: Client;
42
+ database?: Databases;
43
+ storage?: Storage;
44
+ adapter?: DatabaseAdapter;
45
+ converterDefinitions: ConverterFunctions;
46
+ validityRuleDefinitions: ValidationRules;
47
+ afterImportActionsDefinitions: AfterImportActions;
48
+ constructor(currentUserDir: string, directConfig?: {
49
+ appwriteEndpoint?: string;
50
+ appwriteProject?: string;
51
+ appwriteKey?: string;
52
+ });
53
+ init(options?: {
54
+ validate?: boolean;
55
+ strictMode?: boolean;
56
+ useSession?: boolean;
57
+ sessionCookie?: string;
58
+ }): Promise<void>;
59
+ reloadConfig(): Promise<void>;
60
+ ensureDatabaseConfigBucketsExist(databases?: Models.Database[]): Promise<void>;
61
+ ensureDatabasesExist(databases?: Models.Database[]): Promise<void>;
62
+ ensureCollectionsExist(database: Models.Database, collections?: Models.Collection[]): Promise<void>;
63
+ getDatabasesByIds(ids: string[]): Promise<Models.Database[] | undefined>;
64
+ fetchAllBuckets(): Promise<{
65
+ buckets: Models.Bucket[];
66
+ }>;
67
+ wipeOtherDatabases(databasesToKeep: Models.Database[]): Promise<void>;
68
+ wipeUsers(): Promise<void>;
69
+ backupDatabase(database: Models.Database, format?: 'json' | 'zip'): Promise<void>;
70
+ listAllFunctions(): Promise<Models.Function[]>;
71
+ findFunctionDirectories(): Promise<Map<any, any>>;
72
+ deployFunction(functionName: string, functionPath?: string, functionConfig?: AppwriteFunction): Promise<void>;
73
+ syncFunctions(): Promise<void>;
74
+ wipeDatabase(database: Models.Database, wipeBucket?: boolean): Promise<void>;
75
+ wipeBucketFromDatabase(database: Models.Database): Promise<void>;
76
+ wipeCollection(database: Models.Database, collection: Models.Collection): Promise<void>;
77
+ wipeDocumentStorage(bucketId: string): Promise<void>;
78
+ createOrUpdateCollectionsForDatabases(databases: Models.Database[], collections?: Models.Collection[]): Promise<void>;
79
+ createOrUpdateCollections(database: Models.Database, deletedCollections?: {
80
+ collectionId: string;
81
+ collectionName: string;
82
+ }[], collections?: Models.Collection[]): Promise<void>;
83
+ generateSchemas(): Promise<void>;
84
+ importData(options?: SetupOptions): Promise<void>;
85
+ synchronizeConfigurations(databases?: Models.Database[], config?: AppwriteConfig, databaseSelections?: DatabaseSelection[], bucketSelections?: BucketSelection[]): Promise<void>;
86
+ selectivePull(databaseSelections: DatabaseSelection[], bucketSelections: BucketSelection[]): Promise<void>;
87
+ selectivePush(databaseSelections: DatabaseSelection[], bucketSelections: BucketSelection[]): Promise<void>;
88
+ syncDb(databases?: Models.Database[], collections?: Models.Collection[]): Promise<void>;
89
+ getAppwriteFolderPath(): string | undefined;
90
+ transferData(options: TransferOptions): Promise<void>;
91
+ updateFunctionSpecifications(functionId: string, specification: Specification): Promise<void>;
92
+ /**
93
+ * Validates the current configuration for collections/tables conflicts
94
+ */
95
+ validateConfiguration(strictMode?: boolean): Promise<ValidationResult>;
96
+ /**
97
+ * Get current session information for debugging/logging purposes
98
+ * Delegates to ConfigManager for session info
99
+ */
100
+ getSessionInfo(): Promise<{
101
+ hasSession: boolean;
102
+ authMethod?: string;
103
+ email?: string;
104
+ expiresAt?: string;
105
+ }>;
106
+ }