@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,35 @@
1
+ import type { Databases } from "node-appwrite";
2
+ import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
3
+ /**
4
+ * Type guard and validation utilities
5
+ */
6
+ /**
7
+ * Type guard to check if object is a DatabaseAdapter
8
+ * @param db - Object to check
9
+ * @returns True if object is DatabaseAdapter
10
+ */
11
+ export declare function isDatabaseAdapter(db: Databases | DatabaseAdapter): db is DatabaseAdapter;
12
+ /**
13
+ * Type guard to check if object is legacy Databases instance
14
+ * @param db - Object to check
15
+ * @returns True if object is Databases (not DatabaseAdapter)
16
+ */
17
+ export declare function isLegacyDatabases(db: Databases | DatabaseAdapter): db is Databases;
18
+ /**
19
+ * Checks if object has metadata property
20
+ * @param obj - Object to check
21
+ * @returns True if object has metadata
22
+ */
23
+ export declare function hasMetadata(obj: any): boolean;
24
+ /**
25
+ * Type guard for collection create objects
26
+ * @param obj - Object to check
27
+ * @returns True if object looks like CollectionCreate
28
+ */
29
+ export declare function isCollectionCreate(obj: any): boolean;
30
+ /**
31
+ * Type guard for table create objects
32
+ * @param obj - Object to check
33
+ * @returns True if object looks like TableCreate
34
+ */
35
+ export declare function isTableCreate(obj: any): boolean;
@@ -0,0 +1,57 @@
1
+ import { logger } from "../shared/logging.js";
2
+ /**
3
+ * Type guard and validation utilities
4
+ */
5
+ /**
6
+ * Type guard to check if object is a DatabaseAdapter
7
+ * @param db - Object to check
8
+ * @returns True if object is DatabaseAdapter
9
+ */
10
+ export function isDatabaseAdapter(db) {
11
+ const isAdapter = 'getMetadata' in db && typeof db.getMetadata === 'function';
12
+ logger.debug('Adapter type detection', {
13
+ isAdapter,
14
+ hasGetMetadata: 'getMetadata' in db,
15
+ getMetadataType: typeof db.getMetadata,
16
+ operation: 'isDatabaseAdapter'
17
+ });
18
+ return isAdapter;
19
+ }
20
+ /**
21
+ * Type guard to check if object is legacy Databases instance
22
+ * @param db - Object to check
23
+ * @returns True if object is Databases (not DatabaseAdapter)
24
+ */
25
+ export function isLegacyDatabases(db) {
26
+ return !isDatabaseAdapter(db);
27
+ }
28
+ /**
29
+ * Checks if object has metadata property
30
+ * @param obj - Object to check
31
+ * @returns True if object has metadata
32
+ */
33
+ export function hasMetadata(obj) {
34
+ return obj && typeof obj === 'object' && 'metadata' in obj;
35
+ }
36
+ /**
37
+ * Type guard for collection create objects
38
+ * @param obj - Object to check
39
+ * @returns True if object looks like CollectionCreate
40
+ */
41
+ export function isCollectionCreate(obj) {
42
+ return obj &&
43
+ typeof obj === 'object' &&
44
+ 'name' in obj &&
45
+ ('$id' in obj || 'collectionId' in obj);
46
+ }
47
+ /**
48
+ * Type guard for table create objects
49
+ * @param obj - Object to check
50
+ * @returns True if object looks like TableCreate
51
+ */
52
+ export function isTableCreate(obj) {
53
+ return obj &&
54
+ typeof obj === 'object' &&
55
+ 'name' in obj &&
56
+ ('tableId' in obj || '$id' in obj);
57
+ }
@@ -0,0 +1,43 @@
1
+ export interface ValidationRules {
2
+ [key: string]: (value: any, ...args: any[]) => boolean;
3
+ }
4
+ export declare const validationRules: {
5
+ isNumber: (value: any) => boolean;
6
+ isString: (value: any) => boolean;
7
+ isBoolean: (value: any) => boolean;
8
+ isArray: (value: any) => boolean;
9
+ isObject: (value: any) => boolean;
10
+ isNull: (value: any) => boolean;
11
+ isValidEmail: (value: string) => boolean;
12
+ isValidPhone: (value: string) => boolean;
13
+ isValidPassword: (value: string) => boolean;
14
+ isValidUrl: (value: string) => boolean;
15
+ isValidHex: (value: string) => boolean;
16
+ isValidHexColor: (value: string) => boolean;
17
+ isValidHexAlpha: (value: string) => boolean;
18
+ isValidDate: (value: string) => boolean;
19
+ isValidTime: (value: string) => boolean;
20
+ isNullish: (value: any) => boolean;
21
+ isUndefined: (value: any) => boolean;
22
+ isDefined: (value: any) => boolean;
23
+ isDate: (value: any) => boolean;
24
+ isEmpty: (value: any) => boolean;
25
+ isInteger: (value: any) => boolean;
26
+ isFloat: (value: any) => boolean;
27
+ isArrayLike: (value: any) => boolean;
28
+ isArrayLikeObject: (value: any) => boolean;
29
+ isFunction: (value: any) => boolean;
30
+ isLength: (value: any) => boolean;
31
+ isMap: (value: any) => boolean;
32
+ isSet: (value: any) => boolean;
33
+ isRegExp: (value: any) => boolean;
34
+ isSymbol: (value: any) => boolean;
35
+ isObjectLike: (value: any) => boolean;
36
+ isPlainObject: (value: any) => boolean;
37
+ isSafeInteger: (value: any) => boolean;
38
+ isTypedArray: (value: any) => boolean;
39
+ isEqual: (value: any, other: any) => boolean;
40
+ isMatch: (object: any, source: any) => boolean;
41
+ has: (object: any, path: string) => boolean;
42
+ get: (object: any, path: string, defaultValue: any) => any;
43
+ };
@@ -0,0 +1,42 @@
1
+ import { isNumber, isString, isBoolean, isArray, isPlainObject, isNull, isUndefined, isDate, isEmpty, isInteger, isArrayLike, isArrayLikeObject, isFunction, isLength, isMap, isSet, isRegExp, isSymbol, isObjectLike, isSafeInteger, isTypedArray, isEqual, isMatch, has, get, } from "es-toolkit/compat";
2
+ export const validationRules = {
3
+ isNumber: (value) => isNumber(value),
4
+ isString: (value) => isString(value),
5
+ isBoolean: (value) => isBoolean(value),
6
+ isArray: (value) => isArray(value),
7
+ isObject: (value) => isPlainObject(value) && !isArray(value) && !isFunction(value),
8
+ isNull: (value) => isNull(value),
9
+ isValidEmail: (value) => value.match(/^[\w\-\.]+@([\w-]+\.)+[\w-]{2,}$/) !== null,
10
+ isValidPhone: (value) => value.match(/^[+]?[(]?[0-9]{3}[)]?[-\s.]?[0-9]{3}[-\s.]?[0-9]{4,6}$/im) !==
11
+ null,
12
+ isValidPassword: (value) => value.match(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*#?&])[A-Za-z\d@$!%*#?&]{8,}$/) !== null,
13
+ isValidUrl: (value) => value.match(/^(https?:\/\/)?([\da-z\.-]+)\.([a-z\.]{2,6})([\/\w \.-]*)*\/?$/) !== null,
14
+ isValidHex: (value) => value.match(/^#([a-f0-9]{6}|[a-f0-9]{3})$/i) !== null,
15
+ isValidHexColor: (value) => value.match(/^#([a-f0-9]{6}|[a-f0-9]{3})$/i) !== null,
16
+ isValidHexAlpha: (value) => value.match(/^#([a-f0-9]{8}|[a-f0-9]{4})$/i) !== null,
17
+ isValidDate: (value) => value.match(/^\d{4}-\d{2}-\d{2}$/) !== null,
18
+ isValidTime: (value) => value.match(/^\d{2}:\d{2}(:\d{2})?$/) !== null,
19
+ isNullish: (value) => isNull(value) || isUndefined(value),
20
+ isUndefined: (value) => isUndefined(value),
21
+ isDefined: (value) => !isUndefined(value) && !isNull(value) && !isEmpty(value),
22
+ isDate: (value) => isDate(value),
23
+ isEmpty: (value) => isEmpty(value),
24
+ isInteger: (value) => isInteger(value),
25
+ isFloat: (value) => isNumber(value) && !isInteger(value), // Note: Works for double precision numbers
26
+ isArrayLike: (value) => isArrayLike(value),
27
+ isArrayLikeObject: (value) => isArrayLikeObject(value),
28
+ isFunction: (value) => isFunction(value),
29
+ isLength: (value) => isLength(value),
30
+ isMap: (value) => isMap(value),
31
+ isSet: (value) => isSet(value),
32
+ isRegExp: (value) => isRegExp(value),
33
+ isSymbol: (value) => isSymbol(value),
34
+ isObjectLike: (value) => isObjectLike(value),
35
+ isPlainObject: (value) => isPlainObject(value),
36
+ isSafeInteger: (value) => isSafeInteger(value),
37
+ isTypedArray: (value) => isTypedArray(value),
38
+ isEqual: (value, other) => isEqual(value, other),
39
+ isMatch: (object, source) => isMatch(object, source),
40
+ has: (object, path) => has(object, path),
41
+ get: (object, path, defaultValue) => get(object, path, defaultValue),
42
+ };
@@ -0,0 +1,58 @@
1
+ /**
2
+ * Version Detection Utility for Appwrite API Compatibility
3
+ *
4
+ * This module provides functions to detect whether an Appwrite instance
5
+ * supports the new TablesDB API or uses the legacy Databases API.
6
+ *
7
+ * Detection Strategy:
8
+ * 1. Primary: Test TablesDB-specific endpoint availability
9
+ * 2. Secondary: Health endpoint version check
10
+ * 3. Fallback: Default to legacy mode for safety
11
+ */
12
+ export type ApiMode = 'legacy' | 'tablesdb';
13
+ export interface VersionDetectionResult {
14
+ apiMode: ApiMode;
15
+ detectionMethod: 'endpoint_probe' | 'health_check' | 'fallback';
16
+ serverVersion?: string;
17
+ confidence: 'high' | 'medium' | 'low';
18
+ }
19
+ /**
20
+ * Detects Appwrite API version and TablesDB support
21
+ *
22
+ * @param endpoint - Appwrite server endpoint URL
23
+ * @param project - Project ID
24
+ * @param apiKey - API key for authentication
25
+ * @returns Promise resolving to version detection result
26
+ */
27
+ export declare function detectAppwriteVersion(endpoint: string, project: string, apiKey: string): Promise<VersionDetectionResult>;
28
+ /**
29
+ * Cached version detection with automatic cache management
30
+ *
31
+ * @param endpoint - Appwrite server endpoint URL
32
+ * @param project - Project ID
33
+ * @param apiKey - API key for authentication
34
+ * @param forceRefresh - Skip cache and force fresh detection
35
+ * @returns Promise resolving to version detection result
36
+ */
37
+ export declare function detectAppwriteVersionCached(endpoint: string, project: string, apiKey: string, forceRefresh?: boolean): Promise<VersionDetectionResult>;
38
+ /**
39
+ * Quick check for cloud.appwrite.io instances (likely have TablesDB)
40
+ *
41
+ * @param endpoint - Appwrite server endpoint URL
42
+ * @returns boolean indicating if endpoint is likely cloud-hosted
43
+ */
44
+ export declare function isCloudAppwriteEndpoint(endpoint: string): boolean;
45
+ /**
46
+ * SDK feature detection as a fallback method
47
+ * Attempts to dynamically import TablesDB to check availability
48
+ */
49
+ /**
50
+ * Clear version detection cache (useful for testing)
51
+ */
52
+ export declare function clearVersionDetectionCache(): void;
53
+ /**
54
+ * Fetch server version from /health/version (no auth required)
55
+ */
56
+ export declare function fetchServerVersion(endpoint: string): Promise<string | null>;
57
+ /** Compare semantic versions (basic) */
58
+ export declare function isVersionAtLeast(current: string | undefined, target: string): boolean;
@@ -0,0 +1,251 @@
1
+ /**
2
+ * Version Detection Utility for Appwrite API Compatibility
3
+ *
4
+ * This module provides functions to detect whether an Appwrite instance
5
+ * supports the new TablesDB API or uses the legacy Databases API.
6
+ *
7
+ * Detection Strategy:
8
+ * 1. Primary: Test TablesDB-specific endpoint availability
9
+ * 2. Secondary: Health endpoint version check
10
+ * 3. Fallback: Default to legacy mode for safety
11
+ */
12
+ import { logger } from '../shared/logging.js';
13
+ import { MessageFormatter } from '../shared/messageFormatter.js';
14
+ import { Client, Databases, TablesDB, Query } from 'node-appwrite';
15
+ /**
16
+ * Detects Appwrite API version and TablesDB support
17
+ *
18
+ * @param endpoint - Appwrite server endpoint URL
19
+ * @param project - Project ID
20
+ * @param apiKey - API key for authentication
21
+ * @returns Promise resolving to version detection result
22
+ */
23
+ export async function detectAppwriteVersion(endpoint, project, apiKey) {
24
+ const startTime = Date.now();
25
+ // Clean endpoint URL
26
+ const cleanEndpoint = endpoint.replace(/\/$/, '');
27
+ logger.info('Starting Appwrite version detection', {
28
+ endpoint: cleanEndpoint,
29
+ project,
30
+ operation: 'detectAppwriteVersion'
31
+ });
32
+ // STEP 1: Check server version FIRST
33
+ const serverVersion = await fetchServerVersion(cleanEndpoint);
34
+ if (serverVersion && !isVersionAtLeast(serverVersion, '1.8.0')) {
35
+ // Server < 1.8.0 doesn't support TablesDB
36
+ logger.info('Server version below 1.8.0 - using legacy adapter', {
37
+ serverVersion,
38
+ operation: 'detectAppwriteVersion'
39
+ });
40
+ return {
41
+ apiMode: 'legacy',
42
+ detectionMethod: 'health_check',
43
+ serverVersion,
44
+ confidence: 'high'
45
+ };
46
+ }
47
+ // STEP 2: If version is unknown, use SDK probe (no fake HTTP endpoints)
48
+ try {
49
+ logger.debug('Attempting SDK-based TablesDB probe', {
50
+ endpoint: cleanEndpoint,
51
+ operation: 'detectAppwriteVersion'
52
+ });
53
+ const client = new Client().setEndpoint(cleanEndpoint).setProject(project);
54
+ if (apiKey && apiKey.trim().length > 0)
55
+ client.setKey(apiKey);
56
+ const databases = new Databases(client);
57
+ // Try to get a database id to probe tables listing
58
+ let dbId;
59
+ try {
60
+ const dbList = await databases.list([Query.limit(1)]);
61
+ dbId = dbList?.databases?.[0]?.$id || dbList?.databases?.[0]?.id || dbList?.[0]?.$id;
62
+ }
63
+ catch (e) {
64
+ // Ignore, we'll still attempt a conservative probe
65
+ logger.debug('Databases.list probe failed or returned no items', { operation: 'detectAppwriteVersion' });
66
+ }
67
+ const tables = new TablesDB(client);
68
+ if (dbId) {
69
+ // Probe listTables for the first database (limit 1)
70
+ await tables.listTables({ databaseId: dbId, queries: [Query.limit(1)] });
71
+ }
72
+ else {
73
+ // No databases to probe; assume TablesDB available (cannot falsify-positively without a db)
74
+ logger.debug('No databases found to probe tables; assuming TablesDB if SDK available', { operation: 'detectAppwriteVersion' });
75
+ }
76
+ const result = {
77
+ apiMode: 'tablesdb',
78
+ detectionMethod: 'endpoint_probe', // repurpose label for SDK probe
79
+ confidence: 'medium',
80
+ serverVersion: serverVersion || undefined
81
+ };
82
+ logger.info('TablesDB detected via SDK probe', {
83
+ endpoint: cleanEndpoint,
84
+ result,
85
+ operation: 'detectAppwriteVersion'
86
+ });
87
+ return result;
88
+ }
89
+ catch (error) {
90
+ const errorMessage = error instanceof Error ? error.message : 'Unknown error';
91
+ logger.warn('SDK TablesDB probe failed; defaulting conservatively', {
92
+ endpoint: cleanEndpoint,
93
+ error: errorMessage,
94
+ operation: 'detectAppwriteVersion'
95
+ });
96
+ }
97
+ // Final fallback: default to tablesdb for modern environments when version unknown
98
+ const fallbackResult = {
99
+ apiMode: 'tablesdb',
100
+ detectionMethod: 'fallback',
101
+ confidence: 'low',
102
+ serverVersion: serverVersion || undefined
103
+ };
104
+ logger.info('Defaulting to TablesDB mode (fallback)', {
105
+ endpoint: cleanEndpoint,
106
+ result: fallbackResult,
107
+ operation: 'detectAppwriteVersion'
108
+ });
109
+ return fallbackResult;
110
+ }
111
+ /**
112
+ * Cached version detection to avoid repeated API calls
113
+ */
114
+ class VersionDetectionCache {
115
+ cache = new Map();
116
+ CACHE_DURATION = 5 * 60 * 1000; // 5 minutes
117
+ getCacheKey(endpoint, project) {
118
+ return `${endpoint}:${project}`;
119
+ }
120
+ get(endpoint, project) {
121
+ const key = this.getCacheKey(endpoint, project);
122
+ const cached = this.cache.get(key);
123
+ if (!cached) {
124
+ return null;
125
+ }
126
+ // Check if cache is expired
127
+ if (Date.now() - cached.timestamp > this.CACHE_DURATION) {
128
+ this.cache.delete(key);
129
+ return null;
130
+ }
131
+ return cached.result;
132
+ }
133
+ set(endpoint, project, result) {
134
+ const key = this.getCacheKey(endpoint, project);
135
+ this.cache.set(key, {
136
+ result,
137
+ timestamp: Date.now()
138
+ });
139
+ }
140
+ clear() {
141
+ this.cache.clear();
142
+ }
143
+ }
144
+ // Global cache instance
145
+ const detectionCache = new VersionDetectionCache();
146
+ /**
147
+ * Cached version detection with automatic cache management
148
+ *
149
+ * @param endpoint - Appwrite server endpoint URL
150
+ * @param project - Project ID
151
+ * @param apiKey - API key for authentication
152
+ * @param forceRefresh - Skip cache and force fresh detection
153
+ * @returns Promise resolving to version detection result
154
+ */
155
+ export async function detectAppwriteVersionCached(endpoint, project, apiKey, forceRefresh = false) {
156
+ const startTime = Date.now();
157
+ logger.debug('Version detection with cache requested', {
158
+ endpoint,
159
+ project,
160
+ forceRefresh,
161
+ operation: 'detectAppwriteVersionCached'
162
+ });
163
+ // Check cache first (unless force refresh)
164
+ if (!forceRefresh) {
165
+ const cached = detectionCache.get(endpoint, project);
166
+ if (cached) {
167
+ logger.info('Using cached version detection result', {
168
+ endpoint,
169
+ project,
170
+ cachedResult: cached,
171
+ operation: 'detectAppwriteVersionCached'
172
+ });
173
+ return cached;
174
+ }
175
+ logger.debug('No cached result found, performing fresh detection', {
176
+ endpoint,
177
+ project,
178
+ operation: 'detectAppwriteVersionCached'
179
+ });
180
+ }
181
+ else {
182
+ logger.debug('Force refresh requested, bypassing cache', {
183
+ endpoint,
184
+ project,
185
+ operation: 'detectAppwriteVersionCached'
186
+ });
187
+ }
188
+ // Perform fresh detection
189
+ const result = await detectAppwriteVersion(endpoint, project, apiKey);
190
+ const totalDuration = Date.now() - startTime;
191
+ // Cache the result
192
+ detectionCache.set(endpoint, project, result);
193
+ logger.info('Version detection completed and cached', {
194
+ endpoint,
195
+ project,
196
+ result,
197
+ totalDuration,
198
+ operation: 'detectAppwriteVersionCached'
199
+ });
200
+ return result;
201
+ }
202
+ /**
203
+ * Quick check for cloud.appwrite.io instances (likely have TablesDB)
204
+ *
205
+ * @param endpoint - Appwrite server endpoint URL
206
+ * @returns boolean indicating if endpoint is likely cloud-hosted
207
+ */
208
+ export function isCloudAppwriteEndpoint(endpoint) {
209
+ return endpoint.includes('cloud.appwrite.io');
210
+ }
211
+ /**
212
+ * SDK feature detection as a fallback method
213
+ * Attempts to dynamically import TablesDB to check availability
214
+ */
215
+ // Removed dynamic SDK capability checks to avoid confusion and side effects.
216
+ /**
217
+ * Clear version detection cache (useful for testing)
218
+ */
219
+ export function clearVersionDetectionCache() {
220
+ detectionCache.clear();
221
+ }
222
+ /**
223
+ * Fetch server version from /health/version (no auth required)
224
+ */
225
+ export async function fetchServerVersion(endpoint) {
226
+ try {
227
+ const clean = endpoint.replace(/\/$/, '');
228
+ const res = await fetch(`${clean}/health/version`, { method: 'GET', signal: AbortSignal.timeout(5000) });
229
+ if (!res.ok)
230
+ return null;
231
+ const data = await res.json().catch(() => null);
232
+ const version = (data && (data.version || data.build || data.release)) ?? null;
233
+ return typeof version === 'string' ? version : null;
234
+ }
235
+ catch {
236
+ return null;
237
+ }
238
+ }
239
+ /** Compare semantic versions (basic) */
240
+ export function isVersionAtLeast(current, target) {
241
+ if (!current)
242
+ return false;
243
+ const toNums = (v) => v.split('.').map(n => parseInt(n, 10));
244
+ const [a1 = 0, a2 = 0, a3 = 0] = toNums(current);
245
+ const [b1, b2, b3] = toNums(target);
246
+ if (a1 !== b1)
247
+ return a1 > b1;
248
+ if (a2 !== b2)
249
+ return a2 > b2;
250
+ return a3 >= b3;
251
+ }
@@ -0,0 +1,100 @@
1
+ import type { Collection, CollectionCreate } from "@njdamstra/appwrite-utils";
2
+ export interface YamlCollectionData {
3
+ name: string;
4
+ id?: string;
5
+ documentSecurity?: boolean;
6
+ rowSecurity?: boolean;
7
+ enabled?: boolean;
8
+ permissions?: Array<{
9
+ permission: string;
10
+ target: string;
11
+ }>;
12
+ attributes?: Array<{
13
+ key: string;
14
+ type: string;
15
+ size?: number;
16
+ required?: boolean;
17
+ array?: boolean;
18
+ encrypt?: boolean;
19
+ default?: any;
20
+ min?: number;
21
+ max?: number;
22
+ elements?: string[];
23
+ relatedCollection?: string;
24
+ relationType?: string;
25
+ twoWay?: boolean;
26
+ twoWayKey?: string;
27
+ onDelete?: string;
28
+ side?: string;
29
+ }>;
30
+ columns?: Array<{
31
+ key: string;
32
+ type: string;
33
+ size?: number;
34
+ required?: boolean;
35
+ array?: boolean;
36
+ encrypt?: boolean;
37
+ default?: any;
38
+ min?: number;
39
+ max?: number;
40
+ elements?: string[];
41
+ relatedTable?: string;
42
+ relationType?: string;
43
+ twoWay?: boolean;
44
+ twoWayKey?: string;
45
+ onDelete?: string;
46
+ side?: string;
47
+ }>;
48
+ indexes?: Array<{
49
+ key: string;
50
+ type: string;
51
+ attributes: string[];
52
+ columns?: string[];
53
+ orders?: string[];
54
+ }>;
55
+ importDefs?: any[];
56
+ }
57
+ /**
58
+ * Configuration for terminology selection
59
+ */
60
+ export interface YamlTerminologyConfig {
61
+ useTableTerminology: boolean;
62
+ entityType: 'collection' | 'table';
63
+ schemaPath?: string;
64
+ }
65
+ /**
66
+ * Converts a Collection object to YAML format with proper schema reference
67
+ * Supports both collection and table terminology based on configuration
68
+ */
69
+ export declare function collectionToYaml(collection: Collection | CollectionCreate, config?: YamlTerminologyConfig): string;
70
+ /**
71
+ * Sanitizes a collection name for use as a filename
72
+ */
73
+ export declare function sanitizeFilename(name: string): string;
74
+ /**
75
+ * Generates the filename for a collection/table YAML file
76
+ */
77
+ export declare function getCollectionYamlFilename(collection: Collection | CollectionCreate, useTableTerminology?: boolean): string;
78
+ /**
79
+ * Converts column terminology back to attribute terminology for loading
80
+ */
81
+ export declare function normalizeYamlData(yamlData: YamlCollectionData): YamlCollectionData;
82
+ /**
83
+ * Determines if YAML data uses table terminology
84
+ */
85
+ export declare function usesTableTerminology(yamlData: YamlCollectionData): boolean;
86
+ /**
87
+ * Converts between attribute and column terminology
88
+ */
89
+ export declare function convertTerminology(yamlData: YamlCollectionData, toTableTerminology: boolean): YamlCollectionData;
90
+ /**
91
+ * Generates a template YAML file for collections or tables
92
+ */
93
+ export declare function generateYamlTemplate(entityName: string, config: YamlTerminologyConfig): string;
94
+ /**
95
+ * Generates example YAML files for both collection and table formats
96
+ */
97
+ export declare function generateExampleYamls(entityName: string): {
98
+ collection: string;
99
+ table: string;
100
+ };