@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,341 @@
1
+ import { YamlImportConfigLoader } from "./YamlImportConfigLoader.js";
2
+ import { createImportSchemas, createImportExamples } from "./generateImportSchemas.js";
3
+ import { logger } from "../../shared/logging.js";
4
+ import { normalizeYamlData, usesTableTerminology, convertTerminology } from "../../utils/yamlConverter.js";
5
+ import path from "path";
6
+ import fs from "fs";
7
+ import yaml from "js-yaml";
8
+ /**
9
+ * Integration service that bridges YAML import configurations with the existing import system.
10
+ * Provides seamless integration between new YAML configs and legacy TypeScript collection definitions.
11
+ */
12
+ export class YamlImportIntegration {
13
+ configLoader;
14
+ appwriteFolderPath;
15
+ constructor(appwriteFolderPath) {
16
+ this.appwriteFolderPath = appwriteFolderPath;
17
+ this.configLoader = new YamlImportConfigLoader(appwriteFolderPath);
18
+ }
19
+ /**
20
+ * Initializes the YAML import system.
21
+ * Creates necessary directories, schemas, and example files.
22
+ */
23
+ async initialize() {
24
+ try {
25
+ // Create import directory structure
26
+ await this.configLoader.createImportStructure();
27
+ // Generate JSON schemas for IntelliSense
28
+ await createImportSchemas(this.appwriteFolderPath);
29
+ // Create example configurations
30
+ await createImportExamples(this.appwriteFolderPath);
31
+ logger.info("YAML import system initialized successfully");
32
+ }
33
+ catch (error) {
34
+ logger.error("Failed to initialize YAML import system:", error);
35
+ throw error;
36
+ }
37
+ }
38
+ /**
39
+ * Merges YAML import configurations with existing collection definitions.
40
+ * Allows collections to have both TypeScript and YAML import definitions.
41
+ *
42
+ * @param collections - Existing collection configurations
43
+ * @returns Collections with merged import definitions
44
+ */
45
+ async mergeWithCollections(collections) {
46
+ try {
47
+ // Load all YAML import configurations
48
+ const yamlConfigs = await this.configLoader.loadAllImportConfigs();
49
+ if (yamlConfigs.size === 0) {
50
+ logger.info("No YAML import configurations found, using existing collection definitions");
51
+ return collections;
52
+ }
53
+ logger.info(`Found YAML import configurations for ${yamlConfigs.size} collections`);
54
+ const mergedCollections = [...collections];
55
+ // Process each collection with YAML configs
56
+ for (const [collectionName, yamlConfigList] of yamlConfigs.entries()) {
57
+ const existingCollection = mergedCollections.find(c => c.name === collectionName);
58
+ if (existingCollection) {
59
+ // Merge with existing collection
60
+ const yamlImportDefs = yamlConfigList.map(yamlConfig => this.configLoader.convertToImportDef(yamlConfig));
61
+ // Combine existing and YAML import definitions
62
+ const existingImportDefs = existingCollection.importDefs || [];
63
+ existingCollection.importDefs = [...existingImportDefs, ...yamlImportDefs];
64
+ logger.info(`Merged ${yamlImportDefs.length} YAML import definitions with collection: ${collectionName}`);
65
+ }
66
+ else {
67
+ // Create new collection from YAML config
68
+ const yamlImportDefs = yamlConfigList.map(yamlConfig => this.configLoader.convertToImportDef(yamlConfig));
69
+ const newCollection = {
70
+ name: collectionName,
71
+ $id: collectionName.toLowerCase().replace(/\s+/g, '_'),
72
+ enabled: true,
73
+ documentSecurity: false,
74
+ $permissions: [],
75
+ attributes: [], // Will be populated from existing collection or schema
76
+ indexes: [],
77
+ importDefs: yamlImportDefs,
78
+ };
79
+ mergedCollections.push(newCollection);
80
+ logger.info(`Created new collection from YAML config: ${collectionName}`);
81
+ }
82
+ }
83
+ return mergedCollections;
84
+ }
85
+ catch (error) {
86
+ logger.error("Failed to merge YAML configurations with collections:", error);
87
+ // Return original collections on error to avoid breaking existing functionality
88
+ return collections;
89
+ }
90
+ }
91
+ /**
92
+ * Validates YAML import configurations against existing collection schemas.
93
+ * Ensures that all target fields exist in the collection definitions.
94
+ *
95
+ * @param collections - Collection definitions to validate against
96
+ * @returns Validation results with errors and warnings
97
+ */
98
+ async validateConfigurations(collections) {
99
+ const errors = [];
100
+ const warnings = [];
101
+ try {
102
+ const yamlConfigs = await this.configLoader.loadAllImportConfigs();
103
+ for (const [collectionName, yamlConfigList] of yamlConfigs.entries()) {
104
+ const collection = collections.find(c => c.name === collectionName);
105
+ if (!collection) {
106
+ warnings.push(`YAML import config references non-existent collection: ${collectionName}`);
107
+ continue;
108
+ }
109
+ for (let i = 0; i < yamlConfigList.length; i++) {
110
+ const yamlConfig = yamlConfigList[i];
111
+ const configErrors = this.configLoader.validateAgainstCollection(yamlConfig, collection.attributes || []);
112
+ errors.push(...configErrors.map(err => `${collectionName}[${i}]: ${err}`));
113
+ // Additional validation
114
+ this.validateSourceFiles(yamlConfig, errors, collectionName, i);
115
+ this.validateConverters(yamlConfig, warnings, collectionName, i);
116
+ }
117
+ }
118
+ return {
119
+ isValid: errors.length === 0,
120
+ errors,
121
+ warnings,
122
+ };
123
+ }
124
+ catch (error) {
125
+ errors.push(`Failed to validate YAML configurations: ${error}`);
126
+ return {
127
+ isValid: false,
128
+ errors,
129
+ warnings,
130
+ };
131
+ }
132
+ }
133
+ /**
134
+ * Validates that source files exist for import configurations.
135
+ */
136
+ validateSourceFiles(yamlConfig, errors, collectionName, configIndex) {
137
+ const sourceFilePath = path.resolve(this.appwriteFolderPath, yamlConfig.source.file);
138
+ if (!fs.existsSync(sourceFilePath)) {
139
+ errors.push(`${collectionName}[${configIndex}]: Source file not found: ${yamlConfig.source.file}`);
140
+ }
141
+ }
142
+ /**
143
+ * Validates that converter functions are available.
144
+ */
145
+ validateConverters(yamlConfig, warnings, collectionName, configIndex) {
146
+ const availableConverters = [
147
+ "anyToString",
148
+ "anyToNumber",
149
+ "anyToBoolean",
150
+ "anyToDate",
151
+ "stringToLowerCase",
152
+ "stringToUpperCase",
153
+ "stringTrim",
154
+ "numberToString",
155
+ "booleanToString",
156
+ "dateToString",
157
+ "dateToTimestamp",
158
+ "timestampToDate",
159
+ "arrayToString",
160
+ "stringToArray",
161
+ "removeNulls",
162
+ "removeEmpty"
163
+ ];
164
+ for (const mapping of yamlConfig.mapping.attributes) {
165
+ for (const converter of mapping.converters) {
166
+ const cleanConverter = converter.replace(/\[arr\]/gi, "").replace(/\[Arr\]/gi, "");
167
+ if (!availableConverters.includes(cleanConverter)) {
168
+ warnings.push(`${collectionName}[${configIndex}]: Unknown converter '${converter}' in mapping for '${mapping.targetKey}'`);
169
+ }
170
+ }
171
+ }
172
+ }
173
+ /**
174
+ * Generates a YAML import configuration from an existing ImportDef.
175
+ * Useful for migrating TypeScript configurations to YAML.
176
+ * Supports both collection and table terminology.
177
+ *
178
+ * @param importDef - Existing ImportDef to convert
179
+ * @param collectionName - Name of the collection
180
+ * @param useTableTerminology - Whether to use table terminology
181
+ * @returns YAML configuration string
182
+ */
183
+ convertImportDefToYaml(importDef, collectionName, useTableTerminology = false) {
184
+ const yamlConfig = {
185
+ source: {
186
+ file: importDef.filePath,
187
+ basePath: importDef.basePath,
188
+ type: "json",
189
+ },
190
+ target: {
191
+ collection: collectionName,
192
+ type: importDef.type || "create",
193
+ primaryKey: importDef.primaryKeyField,
194
+ createUsers: importDef.createUsers || false,
195
+ },
196
+ mapping: {
197
+ attributes: importDef.attributeMappings.map(attr => ({
198
+ oldKey: attr.oldKey,
199
+ oldKeys: attr.oldKeys,
200
+ targetKey: attr.targetKey,
201
+ valueToSet: attr.valueToSet,
202
+ fileData: attr.fileData,
203
+ converters: attr.converters || [],
204
+ validation: (attr.validationActions || []).map(v => ({
205
+ rule: v.action,
206
+ params: v.params,
207
+ })),
208
+ afterImport: (attr.postImportActions || []).map(a => ({
209
+ action: a.action,
210
+ params: a.params,
211
+ })),
212
+ })),
213
+ relationships: (importDef.idMappings || []).map(rel => ({
214
+ sourceField: rel.sourceField,
215
+ targetField: rel.targetField,
216
+ targetCollection: rel.targetCollection,
217
+ fieldToSet: rel.fieldToSet,
218
+ targetFieldToMatch: rel.targetFieldToMatch,
219
+ })),
220
+ },
221
+ options: {
222
+ batchSize: 50,
223
+ skipValidation: false,
224
+ dryRun: false,
225
+ continueOnError: true,
226
+ updateMapping: importDef.updateMapping,
227
+ },
228
+ };
229
+ const yamlContent = yaml.dump(yamlConfig, {
230
+ indent: 2,
231
+ lineWidth: 120,
232
+ sortKeys: false,
233
+ });
234
+ const entityType = useTableTerminology ? 'Table' : 'Collection';
235
+ return `# yaml-language-server: $schema=../.yaml_schemas/import-config.schema.json\n# Import Configuration for ${entityType}: ${collectionName}\n\n${yamlContent}`;
236
+ }
237
+ /**
238
+ * Exports existing TypeScript import configurations to YAML files.
239
+ * Helps migrate from TypeScript to YAML-based configurations.
240
+ * Supports both collection and table terminology.
241
+ *
242
+ * @param collections - Collections with existing import definitions
243
+ * @param useTableTerminology - Whether to use table terminology
244
+ */
245
+ async exportToYaml(collections, useTableTerminology = false) {
246
+ const exportDir = path.join(this.appwriteFolderPath, "import", "exported");
247
+ if (!fs.existsSync(exportDir)) {
248
+ fs.mkdirSync(exportDir, { recursive: true });
249
+ }
250
+ let exportedCount = 0;
251
+ for (const collection of collections) {
252
+ if (!collection.importDefs || collection.importDefs.length === 0) {
253
+ continue;
254
+ }
255
+ for (let i = 0; i < collection.importDefs.length; i++) {
256
+ const importDef = collection.importDefs[i];
257
+ const yamlContent = this.convertImportDefToYaml(importDef, collection.name, useTableTerminology);
258
+ const entityType = useTableTerminology ? 'table' : 'collection';
259
+ const filename = collection.importDefs.length > 1
260
+ ? `${collection.name}-${entityType}-${i + 1}.yaml`
261
+ : `${collection.name}-${entityType}.yaml`;
262
+ const filePath = path.join(exportDir, filename);
263
+ fs.writeFileSync(filePath, yamlContent);
264
+ exportedCount++;
265
+ logger.info(`Exported import configuration: ${filePath}`);
266
+ }
267
+ }
268
+ logger.info(`Exported ${exportedCount} import configurations to YAML`);
269
+ }
270
+ /**
271
+ * Gets statistics about YAML import configurations.
272
+ */
273
+ async getStatistics() {
274
+ try {
275
+ const yamlConfigs = await this.configLoader.loadAllImportConfigs();
276
+ const stats = this.configLoader.getStatistics(yamlConfigs);
277
+ return {
278
+ hasYamlConfigs: yamlConfigs.size > 0,
279
+ totalConfigurations: stats.totalConfigurations,
280
+ collectionsWithConfigs: stats.collectionsWithConfigs,
281
+ configurationsByType: stats.configsByType,
282
+ totalAttributeMappings: stats.totalAttributeMappings,
283
+ totalRelationshipMappings: stats.totalRelationshipMappings,
284
+ };
285
+ }
286
+ catch (error) {
287
+ logger.error("Failed to get YAML import statistics:", error);
288
+ return {
289
+ hasYamlConfigs: false,
290
+ totalConfigurations: 0,
291
+ collectionsWithConfigs: 0,
292
+ configurationsByType: {},
293
+ totalAttributeMappings: 0,
294
+ totalRelationshipMappings: 0,
295
+ };
296
+ }
297
+ }
298
+ /**
299
+ * Creates a new YAML import configuration from a template.
300
+ * Supports both collection and table terminology.
301
+ *
302
+ * @param collectionName - Name of the collection
303
+ * @param sourceFile - Source data file name
304
+ * @param useTableTerminology - Whether to use table terminology
305
+ * @param outputPath - Output file path (optional)
306
+ */
307
+ async createFromTemplate(collectionName, sourceFile, useTableTerminology = false, outputPath) {
308
+ const template = this.configLoader.generateTemplate(collectionName, sourceFile, useTableTerminology);
309
+ const entityType = useTableTerminology ? 'table' : 'collection';
310
+ const fileName = outputPath || `${collectionName.toLowerCase()}-${entityType}-import.yaml`;
311
+ const fullPath = path.join(this.appwriteFolderPath, "import", fileName);
312
+ // Add schema reference to template with entity type comment
313
+ const schemaHeader = "# yaml-language-server: $schema=../.yaml_schemas/import-config.schema.json\n";
314
+ const entityComment = `# Import Configuration for ${useTableTerminology ? 'Table' : 'Collection'}: ${collectionName}\n`;
315
+ const templateWithSchema = schemaHeader + entityComment + template;
316
+ fs.writeFileSync(fullPath, templateWithSchema);
317
+ logger.info(`Created YAML import configuration: ${fullPath}`);
318
+ return fullPath;
319
+ }
320
+ /**
321
+ * Checks if YAML import system is properly set up.
322
+ */
323
+ async isSetupComplete() {
324
+ const missingComponents = [];
325
+ // Check import directory
326
+ const importDir = path.join(this.appwriteFolderPath, "import");
327
+ if (!fs.existsSync(importDir)) {
328
+ missingComponents.push("import directory");
329
+ }
330
+ // Check schema files
331
+ const schemaDir = path.join(this.appwriteFolderPath, ".yaml_schemas");
332
+ const importSchemaPath = path.join(schemaDir, "import-config.schema.json");
333
+ if (!fs.existsSync(importSchemaPath)) {
334
+ missingComponents.push("import configuration schema");
335
+ }
336
+ return {
337
+ isComplete: missingComponents.length === 0,
338
+ missingComponents,
339
+ };
340
+ }
341
+ }
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Generates JSON Schema for YAML import configurations.
3
+ * Provides IntelliSense support for YAML files in IDEs.
4
+ */
5
+ export declare function generateImportConfigSchema(): any;
6
+ /**
7
+ * Generates JSON Schema for collection definitions (legacy Databases API)
8
+ */
9
+ export declare function generateCollectionSchema(): any;
10
+ /**
11
+ * Generates JSON Schema for table definitions (new TablesDB API)
12
+ */
13
+ export declare function generateTableSchema(): any;
14
+ /**
15
+ * Generates JSON Schema for main Appwrite configuration (YAML format)
16
+ * Matches the structure of YamlConfigSchema from yamlConfig.ts
17
+ */
18
+ export declare function generateAppwriteConfigSchema(): any;
19
+ /**
20
+ * Creates all necessary schema files for YAML configurations.
21
+ *
22
+ * @param appwriteFolderPath - Path to the .appwrite directory
23
+ */
24
+ export declare function createImportSchemas(appwriteFolderPath: string): Promise<void>;
25
+ /**
26
+ * Generates example YAML import configurations.
27
+ *
28
+ * @param appwriteFolderPath - Path to the .appwrite directory
29
+ */
30
+ export declare function createImportExamples(appwriteFolderPath: string): Promise<void>;