@njdamstra/appwrite-utils-cli 1.8.9 → 1.10.1

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 (285) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CONFIG_TODO.md +1189 -0
  3. package/SELECTION_DIALOGS.md +146 -0
  4. package/SERVICE_IMPLEMENTATION_REPORT.md +462 -0
  5. package/dist/adapters/index.d.ts +7 -8
  6. package/dist/adapters/index.js +7 -9
  7. package/dist/backups/operations/bucketBackup.js +2 -2
  8. package/dist/backups/operations/collectionBackup.d.ts +1 -1
  9. package/dist/backups/operations/collectionBackup.js +3 -3
  10. package/dist/backups/operations/comprehensiveBackup.d.ts +1 -1
  11. package/dist/backups/operations/comprehensiveBackup.js +2 -2
  12. package/dist/backups/tracking/centralizedTracking.d.ts +1 -1
  13. package/dist/backups/tracking/centralizedTracking.js +2 -2
  14. package/dist/cli/commands/configCommands.js +51 -7
  15. package/dist/cli/commands/databaseCommands.d.ts +1 -0
  16. package/dist/cli/commands/databaseCommands.js +119 -9
  17. package/dist/cli/commands/functionCommands.js +3 -3
  18. package/dist/cli/commands/importFileCommands.d.ts +7 -0
  19. package/dist/cli/commands/importFileCommands.js +674 -0
  20. package/dist/cli/commands/schemaCommands.js +3 -3
  21. package/dist/cli/commands/storageCommands.js +2 -3
  22. package/dist/cli/commands/transferCommands.js +3 -5
  23. package/dist/collections/attributes.d.ts +1 -1
  24. package/dist/collections/attributes.js +85 -35
  25. package/dist/collections/indexes.js +2 -4
  26. package/dist/collections/methods.d.ts +1 -1
  27. package/dist/collections/methods.js +111 -192
  28. package/dist/collections/tableOperations.d.ts +1 -0
  29. package/dist/collections/tableOperations.js +90 -23
  30. package/dist/collections/transferOperations.d.ts +1 -1
  31. package/dist/collections/transferOperations.js +3 -4
  32. package/dist/collections/wipeOperations.d.ts +4 -3
  33. package/dist/collections/wipeOperations.js +112 -39
  34. package/dist/databases/methods.js +2 -2
  35. package/dist/databases/setup.js +2 -2
  36. package/dist/examples/yamlTerminologyExample.js +2 -2
  37. package/dist/functions/deployments.d.ts +1 -1
  38. package/dist/functions/deployments.js +5 -5
  39. package/dist/functions/fnConfigDiscovery.js +2 -2
  40. package/dist/functions/methods.js +16 -4
  41. package/dist/init.js +1 -1
  42. package/dist/interactiveCLI.d.ts +6 -1
  43. package/dist/interactiveCLI.js +64 -10
  44. package/dist/main.js +130 -177
  45. package/dist/migrations/afterImportActions.js +2 -3
  46. package/dist/migrations/appwriteToX.d.ts +97 -1
  47. package/dist/migrations/appwriteToX.js +9 -7
  48. package/dist/migrations/comprehensiveTransfer.js +3 -5
  49. package/dist/migrations/dataLoader.d.ts +194 -2
  50. package/dist/migrations/dataLoader.js +2 -5
  51. package/dist/migrations/importController.js +3 -4
  52. package/dist/migrations/importDataActions.js +3 -3
  53. package/dist/migrations/relationships.js +1 -2
  54. package/dist/migrations/services/DataTransformationService.js +2 -2
  55. package/dist/migrations/services/FileHandlerService.js +1 -1
  56. package/dist/migrations/services/ImportOrchestrator.js +4 -4
  57. package/dist/migrations/services/RateLimitManager.js +1 -1
  58. package/dist/migrations/services/RelationshipResolver.js +1 -1
  59. package/dist/migrations/services/UserMappingService.js +1 -1
  60. package/dist/migrations/services/ValidationService.js +1 -1
  61. package/dist/migrations/transfer.d.ts +8 -4
  62. package/dist/migrations/transfer.js +106 -55
  63. package/dist/migrations/yaml/YamlImportConfigLoader.js +1 -1
  64. package/dist/migrations/yaml/YamlImportIntegration.js +2 -2
  65. package/dist/migrations/yaml/generateImportSchemas.js +1 -1
  66. package/dist/setupCommands.d.ts +1 -1
  67. package/dist/setupCommands.js +5 -6
  68. package/dist/setupController.js +1 -1
  69. package/dist/shared/backupTracking.d.ts +1 -1
  70. package/dist/shared/backupTracking.js +2 -2
  71. package/dist/shared/confirmationDialogs.js +1 -1
  72. package/dist/shared/migrationHelpers.d.ts +1 -1
  73. package/dist/shared/migrationHelpers.js +3 -3
  74. package/dist/shared/operationQueue.d.ts +1 -1
  75. package/dist/shared/operationQueue.js +2 -3
  76. package/dist/shared/operationsTable.d.ts +1 -1
  77. package/dist/shared/operationsTable.js +2 -2
  78. package/dist/shared/progressManager.js +1 -1
  79. package/dist/shared/selectionDialogs.js +9 -8
  80. package/dist/storage/methods.js +4 -4
  81. package/dist/storage/schemas.d.ts +386 -2
  82. package/dist/tables/indexManager.d.ts +65 -0
  83. package/dist/tables/indexManager.js +294 -0
  84. package/dist/types.d.ts +2 -2
  85. package/dist/types.js +1 -1
  86. package/dist/users/methods.js +2 -3
  87. package/dist/utils/configMigration.js +1 -1
  88. package/dist/utils/index.d.ts +1 -1
  89. package/dist/utils/index.js +1 -1
  90. package/dist/utils/loadConfigs.d.ts +2 -2
  91. package/dist/utils/loadConfigs.js +6 -7
  92. package/dist/utils/setupFiles.js +5 -7
  93. package/dist/utilsController.d.ts +15 -8
  94. package/dist/utilsController.js +57 -28
  95. package/package.json +8 -4
  96. package/src/adapters/index.ts +8 -34
  97. package/src/backups/operations/bucketBackup.ts +2 -2
  98. package/src/backups/operations/collectionBackup.ts +4 -4
  99. package/src/backups/operations/comprehensiveBackup.ts +3 -3
  100. package/src/backups/tracking/centralizedTracking.ts +3 -3
  101. package/src/cli/commands/configCommands.ts +72 -8
  102. package/src/cli/commands/databaseCommands.ts +161 -9
  103. package/src/cli/commands/functionCommands.ts +4 -3
  104. package/src/cli/commands/importFileCommands.ts +815 -0
  105. package/src/cli/commands/schemaCommands.ts +3 -3
  106. package/src/cli/commands/storageCommands.ts +2 -3
  107. package/src/cli/commands/transferCommands.ts +3 -6
  108. package/src/collections/attributes.ts +155 -39
  109. package/src/collections/indexes.ts +5 -7
  110. package/src/collections/methods.ts +115 -150
  111. package/src/collections/tableOperations.ts +92 -21
  112. package/src/collections/transferOperations.ts +4 -5
  113. package/src/collections/wipeOperations.ts +154 -51
  114. package/src/databases/methods.ts +2 -2
  115. package/src/databases/setup.ts +2 -2
  116. package/src/examples/yamlTerminologyExample.ts +2 -2
  117. package/src/functions/deployments.ts +6 -5
  118. package/src/functions/fnConfigDiscovery.ts +2 -2
  119. package/src/functions/methods.ts +19 -6
  120. package/src/init.ts +1 -1
  121. package/src/interactiveCLI.ts +78 -13
  122. package/src/main.ts +143 -287
  123. package/src/migrations/afterImportActions.ts +2 -3
  124. package/src/migrations/appwriteToX.ts +12 -8
  125. package/src/migrations/comprehensiveTransfer.ts +6 -6
  126. package/src/migrations/dataLoader.ts +2 -5
  127. package/src/migrations/importController.ts +3 -4
  128. package/src/migrations/importDataActions.ts +3 -3
  129. package/src/migrations/relationships.ts +1 -2
  130. package/src/migrations/services/DataTransformationService.ts +2 -2
  131. package/src/migrations/services/FileHandlerService.ts +1 -1
  132. package/src/migrations/services/ImportOrchestrator.ts +4 -4
  133. package/src/migrations/services/RateLimitManager.ts +1 -1
  134. package/src/migrations/services/RelationshipResolver.ts +1 -1
  135. package/src/migrations/services/UserMappingService.ts +1 -1
  136. package/src/migrations/services/ValidationService.ts +1 -1
  137. package/src/migrations/transfer.ts +126 -83
  138. package/src/migrations/yaml/YamlImportConfigLoader.ts +1 -1
  139. package/src/migrations/yaml/YamlImportIntegration.ts +2 -2
  140. package/src/migrations/yaml/generateImportSchemas.ts +1 -1
  141. package/src/setupCommands.ts +5 -6
  142. package/src/setupController.ts +1 -1
  143. package/src/shared/backupTracking.ts +3 -3
  144. package/src/shared/confirmationDialogs.ts +1 -1
  145. package/src/shared/migrationHelpers.ts +4 -4
  146. package/src/shared/operationQueue.ts +3 -4
  147. package/src/shared/operationsTable.ts +3 -3
  148. package/src/shared/progressManager.ts +1 -1
  149. package/src/shared/selectionDialogs.ts +9 -8
  150. package/src/storage/methods.ts +4 -4
  151. package/src/tables/indexManager.ts +409 -0
  152. package/src/types.ts +2 -2
  153. package/src/users/methods.ts +2 -3
  154. package/src/utils/configMigration.ts +1 -1
  155. package/src/utils/index.ts +1 -1
  156. package/src/utils/loadConfigs.ts +15 -7
  157. package/src/utils/setupFiles.ts +5 -7
  158. package/src/utilsController.ts +86 -32
  159. package/dist/adapters/AdapterFactory.d.ts +0 -94
  160. package/dist/adapters/AdapterFactory.js +0 -405
  161. package/dist/adapters/DatabaseAdapter.d.ts +0 -233
  162. package/dist/adapters/DatabaseAdapter.js +0 -50
  163. package/dist/adapters/LegacyAdapter.d.ts +0 -50
  164. package/dist/adapters/LegacyAdapter.js +0 -612
  165. package/dist/adapters/TablesDBAdapter.d.ts +0 -45
  166. package/dist/adapters/TablesDBAdapter.js +0 -571
  167. package/dist/config/ConfigManager.d.ts +0 -445
  168. package/dist/config/ConfigManager.js +0 -625
  169. package/dist/config/configMigration.d.ts +0 -87
  170. package/dist/config/configMigration.js +0 -390
  171. package/dist/config/configValidation.d.ts +0 -66
  172. package/dist/config/configValidation.js +0 -358
  173. package/dist/config/index.d.ts +0 -8
  174. package/dist/config/index.js +0 -7
  175. package/dist/config/services/ConfigDiscoveryService.d.ts +0 -126
  176. package/dist/config/services/ConfigDiscoveryService.js +0 -374
  177. package/dist/config/services/ConfigLoaderService.d.ts +0 -129
  178. package/dist/config/services/ConfigLoaderService.js +0 -540
  179. package/dist/config/services/ConfigMergeService.d.ts +0 -208
  180. package/dist/config/services/ConfigMergeService.js +0 -308
  181. package/dist/config/services/ConfigValidationService.d.ts +0 -214
  182. package/dist/config/services/ConfigValidationService.js +0 -310
  183. package/dist/config/services/SessionAuthService.d.ts +0 -225
  184. package/dist/config/services/SessionAuthService.js +0 -456
  185. package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +0 -1
  186. package/dist/config/services/__tests__/ConfigMergeService.test.js +0 -271
  187. package/dist/config/services/index.d.ts +0 -13
  188. package/dist/config/services/index.js +0 -10
  189. package/dist/config/yamlConfig.d.ts +0 -722
  190. package/dist/config/yamlConfig.js +0 -702
  191. package/dist/functions/pathResolution.d.ts +0 -37
  192. package/dist/functions/pathResolution.js +0 -185
  193. package/dist/shared/attributeMapper.d.ts +0 -20
  194. package/dist/shared/attributeMapper.js +0 -203
  195. package/dist/shared/errorUtils.d.ts +0 -54
  196. package/dist/shared/errorUtils.js +0 -95
  197. package/dist/shared/functionManager.d.ts +0 -48
  198. package/dist/shared/functionManager.js +0 -336
  199. package/dist/shared/indexManager.d.ts +0 -24
  200. package/dist/shared/indexManager.js +0 -151
  201. package/dist/shared/jsonSchemaGenerator.d.ts +0 -50
  202. package/dist/shared/jsonSchemaGenerator.js +0 -290
  203. package/dist/shared/logging.d.ts +0 -61
  204. package/dist/shared/logging.js +0 -116
  205. package/dist/shared/messageFormatter.d.ts +0 -39
  206. package/dist/shared/messageFormatter.js +0 -162
  207. package/dist/shared/pydanticModelGenerator.d.ts +0 -17
  208. package/dist/shared/pydanticModelGenerator.js +0 -615
  209. package/dist/shared/schemaGenerator.d.ts +0 -40
  210. package/dist/shared/schemaGenerator.js +0 -556
  211. package/dist/utils/ClientFactory.d.ts +0 -87
  212. package/dist/utils/ClientFactory.js +0 -212
  213. package/dist/utils/configDiscovery.d.ts +0 -78
  214. package/dist/utils/configDiscovery.js +0 -472
  215. package/dist/utils/constantsGenerator.d.ts +0 -31
  216. package/dist/utils/constantsGenerator.js +0 -321
  217. package/dist/utils/dataConverters.d.ts +0 -46
  218. package/dist/utils/dataConverters.js +0 -139
  219. package/dist/utils/directoryUtils.d.ts +0 -22
  220. package/dist/utils/directoryUtils.js +0 -59
  221. package/dist/utils/getClientFromConfig.d.ts +0 -39
  222. package/dist/utils/getClientFromConfig.js +0 -199
  223. package/dist/utils/helperFunctions.d.ts +0 -63
  224. package/dist/utils/helperFunctions.js +0 -156
  225. package/dist/utils/pathResolvers.d.ts +0 -53
  226. package/dist/utils/pathResolvers.js +0 -72
  227. package/dist/utils/projectConfig.d.ts +0 -119
  228. package/dist/utils/projectConfig.js +0 -171
  229. package/dist/utils/retryFailedPromises.d.ts +0 -2
  230. package/dist/utils/retryFailedPromises.js +0 -23
  231. package/dist/utils/sessionAuth.d.ts +0 -48
  232. package/dist/utils/sessionAuth.js +0 -164
  233. package/dist/utils/typeGuards.d.ts +0 -35
  234. package/dist/utils/typeGuards.js +0 -57
  235. package/dist/utils/validationRules.d.ts +0 -43
  236. package/dist/utils/validationRules.js +0 -42
  237. package/dist/utils/versionDetection.d.ts +0 -58
  238. package/dist/utils/versionDetection.js +0 -251
  239. package/dist/utils/yamlConverter.d.ts +0 -100
  240. package/dist/utils/yamlConverter.js +0 -428
  241. package/dist/utils/yamlLoader.d.ts +0 -70
  242. package/dist/utils/yamlLoader.js +0 -267
  243. package/src/adapters/AdapterFactory.ts +0 -510
  244. package/src/adapters/DatabaseAdapter.ts +0 -306
  245. package/src/adapters/LegacyAdapter.ts +0 -841
  246. package/src/adapters/TablesDBAdapter.ts +0 -773
  247. package/src/config/ConfigManager.ts +0 -808
  248. package/src/config/README.md +0 -274
  249. package/src/config/configMigration.ts +0 -575
  250. package/src/config/configValidation.ts +0 -445
  251. package/src/config/index.ts +0 -10
  252. package/src/config/services/ConfigDiscoveryService.ts +0 -463
  253. package/src/config/services/ConfigLoaderService.ts +0 -740
  254. package/src/config/services/ConfigMergeService.ts +0 -388
  255. package/src/config/services/ConfigValidationService.ts +0 -394
  256. package/src/config/services/SessionAuthService.ts +0 -565
  257. package/src/config/services/__tests__/ConfigMergeService.test.ts +0 -351
  258. package/src/config/services/index.ts +0 -29
  259. package/src/config/yamlConfig.ts +0 -761
  260. package/src/functions/pathResolution.ts +0 -227
  261. package/src/shared/attributeMapper.ts +0 -229
  262. package/src/shared/errorUtils.ts +0 -110
  263. package/src/shared/functionManager.ts +0 -525
  264. package/src/shared/indexManager.ts +0 -254
  265. package/src/shared/jsonSchemaGenerator.ts +0 -383
  266. package/src/shared/logging.ts +0 -149
  267. package/src/shared/messageFormatter.ts +0 -208
  268. package/src/shared/pydanticModelGenerator.ts +0 -618
  269. package/src/shared/schemaGenerator.ts +0 -644
  270. package/src/utils/ClientFactory.ts +0 -240
  271. package/src/utils/configDiscovery.ts +0 -557
  272. package/src/utils/constantsGenerator.ts +0 -369
  273. package/src/utils/dataConverters.ts +0 -159
  274. package/src/utils/directoryUtils.ts +0 -61
  275. package/src/utils/getClientFromConfig.ts +0 -257
  276. package/src/utils/helperFunctions.ts +0 -228
  277. package/src/utils/pathResolvers.ts +0 -81
  278. package/src/utils/projectConfig.ts +0 -299
  279. package/src/utils/retryFailedPromises.ts +0 -29
  280. package/src/utils/sessionAuth.ts +0 -230
  281. package/src/utils/typeGuards.ts +0 -65
  282. package/src/utils/validationRules.ts +0 -88
  283. package/src/utils/versionDetection.ts +0 -292
  284. package/src/utils/yamlConverter.ts +0 -542
  285. package/src/utils/yamlLoader.ts +0 -371
@@ -1,321 +0,0 @@
1
- import fs from "fs/promises";
2
- import path from "path";
3
- import {} from "@njdamstra/appwrite-utils";
4
- import { MessageFormatter } from "../shared/messageFormatter.js";
5
- export class ConstantsGenerator {
6
- config;
7
- constants;
8
- constructor(config) {
9
- this.config = config;
10
- this.constants = this.extractConstants();
11
- }
12
- extractConstants() {
13
- const constants = {
14
- databases: {},
15
- collections: {},
16
- buckets: {},
17
- functions: {}
18
- };
19
- // Extract database IDs
20
- this.config.databases?.forEach(db => {
21
- if (db.$id) {
22
- const key = this.toConstantName(db.name || db.$id);
23
- constants.databases[key] = db.$id;
24
- }
25
- });
26
- // Extract collection IDs
27
- this.config.collections?.forEach(collection => {
28
- if (collection.$id) {
29
- const key = this.toConstantName(collection.name || collection.$id);
30
- constants.collections[key] = collection.$id;
31
- }
32
- });
33
- // Extract bucket IDs
34
- this.config.buckets?.forEach(bucket => {
35
- if (bucket.$id) {
36
- const key = this.toConstantName(bucket.name || bucket.$id);
37
- constants.buckets[key] = bucket.$id;
38
- }
39
- });
40
- // Extract function IDs
41
- this.config.functions?.forEach(func => {
42
- if (func.$id) {
43
- const key = this.toConstantName(func.name || func.$id);
44
- constants.functions[key] = func.$id;
45
- }
46
- });
47
- return constants;
48
- }
49
- toConstantName(name) {
50
- return name
51
- .replace(/[^a-zA-Z0-9]/g, '_')
52
- .replace(/_+/g, '_')
53
- .replace(/^_|_$/g, '')
54
- .toUpperCase();
55
- }
56
- toCamelCase(name) {
57
- return name
58
- .toLowerCase()
59
- .replace(/_([a-z])/g, (_, letter) => letter.toUpperCase());
60
- }
61
- toSnakeCase(name) {
62
- return name.toLowerCase();
63
- }
64
- generateTypeScript(constantsOverride) {
65
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
66
- return `// Auto-generated Appwrite constants
67
- // Generated on ${new Date().toISOString()}
68
-
69
- export const DATABASE_IDS = {
70
- ${Object.entries(databases).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
71
- } as const;
72
-
73
- export const COLLECTION_IDS = {
74
- ${Object.entries(collections).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
75
- } as const;
76
-
77
- export const BUCKET_IDS = {
78
- ${Object.entries(buckets).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
79
- } as const;
80
-
81
- export const FUNCTION_IDS = {
82
- ${Object.entries(functions).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
83
- } as const;
84
-
85
- // Type helpers
86
- export type DatabaseId = typeof DATABASE_IDS[keyof typeof DATABASE_IDS];
87
- export type CollectionId = typeof COLLECTION_IDS[keyof typeof COLLECTION_IDS];
88
- export type BucketId = typeof BUCKET_IDS[keyof typeof BUCKET_IDS];
89
- export type FunctionId = typeof FUNCTION_IDS[keyof typeof FUNCTION_IDS];
90
-
91
- // Helper objects for runtime use
92
- export const ALL_DATABASE_IDS = Object.values(DATABASE_IDS);
93
- export const ALL_COLLECTION_IDS = Object.values(COLLECTION_IDS);
94
- export const ALL_BUCKET_IDS = Object.values(BUCKET_IDS);
95
- export const ALL_FUNCTION_IDS = Object.values(FUNCTION_IDS);
96
- `;
97
- }
98
- generateJavaScript(constantsOverride) {
99
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
100
- return `// Auto-generated Appwrite constants
101
- // Generated on ${new Date().toISOString()}
102
-
103
- export const DATABASE_IDS = {
104
- ${Object.entries(databases).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
105
- };
106
-
107
- export const COLLECTION_IDS = {
108
- ${Object.entries(collections).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
109
- };
110
-
111
- export const BUCKET_IDS = {
112
- ${Object.entries(buckets).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
113
- };
114
-
115
- export const FUNCTION_IDS = {
116
- ${Object.entries(functions).map(([key, value]) => ` ${key}: "${value}"`).join(',\n')}
117
- };
118
-
119
- // Helper arrays for runtime use
120
- export const ALL_DATABASE_IDS = Object.values(DATABASE_IDS);
121
- export const ALL_COLLECTION_IDS = Object.values(COLLECTION_IDS);
122
- export const ALL_BUCKET_IDS = Object.values(BUCKET_IDS);
123
- export const ALL_FUNCTION_IDS = Object.values(FUNCTION_IDS);
124
- `;
125
- }
126
- generatePython(constantsOverride) {
127
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
128
- return `# Auto-generated Appwrite constants
129
- # Generated on ${new Date().toISOString()}
130
-
131
- class DatabaseIds:
132
- """Database ID constants"""
133
- ${Object.entries(databases).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
134
-
135
- class CollectionIds:
136
- """Collection ID constants"""
137
- ${Object.entries(collections).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
138
-
139
- class BucketIds:
140
- """Bucket ID constants"""
141
- ${Object.entries(buckets).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
142
-
143
- class FunctionIds:
144
- """Function ID constants"""
145
- ${Object.entries(functions).map(([key, value]) => ` ${key} = "${value}"`).join('\n')}
146
-
147
- # Helper dictionaries for runtime use
148
- DATABASE_ID_MAP = {
149
- ${Object.entries(databases).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
150
- }
151
-
152
- COLLECTION_ID_MAP = {
153
- ${Object.entries(collections).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
154
- }
155
-
156
- BUCKET_ID_MAP = {
157
- ${Object.entries(buckets).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
158
- }
159
-
160
- FUNCTION_ID_MAP = {
161
- ${Object.entries(functions).map(([key, value]) => ` "${this.toSnakeCase(key)}": "${value}"`).join(',\n')}
162
- }
163
- `;
164
- }
165
- generatePHP(constantsOverride) {
166
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
167
- return `<?php
168
- // Auto-generated Appwrite constants
169
- // Generated on ${new Date().toISOString()}
170
-
171
- class AppwriteConstants {
172
-
173
- const DATABASE_IDS = [
174
- ${Object.entries(databases).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
175
- ];
176
-
177
- const COLLECTION_IDS = [
178
- ${Object.entries(collections).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
179
- ];
180
-
181
- const BUCKET_IDS = [
182
- ${Object.entries(buckets).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
183
- ];
184
-
185
- const FUNCTION_IDS = [
186
- ${Object.entries(functions).map(([key, value]) => ` '${key}' => '${value}'`).join(',\n')}
187
- ];
188
-
189
- /**
190
- * Get all database IDs as array
191
- */
192
- public static function getAllDatabaseIds(): array {
193
- return array_values(self::DATABASE_IDS);
194
- }
195
-
196
- /**
197
- * Get all collection IDs as array
198
- */
199
- public static function getAllCollectionIds(): array {
200
- return array_values(self::COLLECTION_IDS);
201
- }
202
-
203
- /**
204
- * Get all bucket IDs as array
205
- */
206
- public static function getAllBucketIds(): array {
207
- return array_values(self::BUCKET_IDS);
208
- }
209
-
210
- /**
211
- * Get all function IDs as array
212
- */
213
- public static function getAllFunctionIds(): array {
214
- return array_values(self::FUNCTION_IDS);
215
- }
216
- }
217
- `;
218
- }
219
- generateDart(constantsOverride) {
220
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
221
- return `// Auto-generated Appwrite constants
222
- // Generated on ${new Date().toISOString()}
223
-
224
- class AppwriteConstants {
225
-
226
- static const Map<String, String> databaseIds = {
227
- ${Object.entries(databases).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
228
- };
229
-
230
- static const Map<String, String> collectionIds = {
231
- ${Object.entries(collections).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
232
- };
233
-
234
- static const Map<String, String> bucketIds = {
235
- ${Object.entries(buckets).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
236
- };
237
-
238
- static const Map<String, String> functionIds = {
239
- ${Object.entries(functions).map(([key, value]) => ` '${this.toCamelCase(key)}': '${value}'`).join(',\n')}
240
- };
241
-
242
- // Helper getters for individual IDs
243
- ${Object.entries(databases).map(([key, value]) => ` static String get ${this.toCamelCase(key)}DatabaseId => '${value}';`).join('\n')}
244
-
245
- ${Object.entries(collections).map(([key, value]) => ` static String get ${this.toCamelCase(key)}CollectionId => '${value}';`).join('\n')}
246
-
247
- ${Object.entries(buckets).map(([key, value]) => ` static String get ${this.toCamelCase(key)}BucketId => '${value}';`).join('\n')}
248
-
249
- ${Object.entries(functions).map(([key, value]) => ` static String get ${this.toCamelCase(key)}FunctionId => '${value}';`).join('\n')}
250
- }
251
- `;
252
- }
253
- generateJSON(constantsOverride) {
254
- const c = constantsOverride || this.constants;
255
- return JSON.stringify({
256
- meta: {
257
- generated: new Date().toISOString(),
258
- generator: "@njdamstra/appwrite-utils-cli"
259
- },
260
- databases: c.databases,
261
- collections: c.collections,
262
- buckets: c.buckets,
263
- functions: c.functions
264
- }, null, 2);
265
- }
266
- generateEnv(constantsOverride) {
267
- const { databases, collections, buckets, functions } = constantsOverride || this.constants;
268
- const lines = [
269
- "# Auto-generated Appwrite constants",
270
- `# Generated on ${new Date().toISOString()}`,
271
- "",
272
- "# Database IDs",
273
- ...Object.entries(databases).map(([key, value]) => `DATABASE_${key}=${value}`),
274
- "",
275
- "# Collection IDs",
276
- ...Object.entries(collections).map(([key, value]) => `COLLECTION_${key}=${value}`),
277
- "",
278
- "# Bucket IDs",
279
- ...Object.entries(buckets).map(([key, value]) => `BUCKET_${key}=${value}`),
280
- "",
281
- "# Function IDs",
282
- ...Object.entries(functions).map(([key, value]) => `FUNCTION_${key}=${value}`)
283
- ];
284
- return lines.join('\n');
285
- }
286
- async generateFiles(languages, outputDir, include) {
287
- await fs.mkdir(outputDir, { recursive: true });
288
- const filterConstants = () => {
289
- if (!include)
290
- return this.constants;
291
- return {
292
- databases: include.databases === false ? {} : this.constants.databases,
293
- collections: include.collections === false ? {} : this.constants.collections,
294
- buckets: include.buckets === false ? {} : this.constants.buckets,
295
- functions: include.functions === false ? {} : this.constants.functions,
296
- };
297
- };
298
- const subset = filterConstants();
299
- const generators = {
300
- typescript: () => ({ content: this.generateTypeScript(subset), filename: "appwrite-constants.ts" }),
301
- javascript: () => ({ content: this.generateJavaScript(subset), filename: "appwrite-constants.js" }),
302
- python: () => ({ content: this.generatePython(subset), filename: "appwrite_constants.py" }),
303
- php: () => ({ content: this.generatePHP(subset), filename: "AppwriteConstants.php" }),
304
- dart: () => ({ content: this.generateDart(subset), filename: "appwrite_constants.dart" }),
305
- json: () => ({ content: this.generateJSON(subset), filename: "appwrite-constants.json" }),
306
- env: () => ({ content: this.generateEnv(subset), filename: ".env.appwrite" })
307
- };
308
- for (const language of languages) {
309
- const generator = generators[language];
310
- if (generator) {
311
- const { content, filename } = generator();
312
- const filePath = path.join(outputDir, filename);
313
- await fs.writeFile(filePath, content, 'utf-8');
314
- MessageFormatter.success(`Generated ${language} constants: ${filePath}`, { prefix: "Constants" });
315
- }
316
- else {
317
- MessageFormatter.error(`Unsupported language: ${language}`, undefined, { prefix: "Constants" });
318
- }
319
- }
320
- }
321
- }
@@ -1,46 +0,0 @@
1
- import { type AttributeMappings } from "@njdamstra/appwrite-utils";
2
- /**
3
- * Deeply converts all properties of an object (or array) to strings.
4
- * @param data The input data to convert.
5
- * @returns The data with all its properties converted to strings.
6
- */
7
- export declare const deepAnyToString: (data: any) => any;
8
- /**
9
- * Performs a deep conversion of all values in a nested structure to the specified type.
10
- * Uses a conversion function like anyToString, anyToNumber, etc.
11
- * @param data The data to convert.
12
- * @param convertFn The conversion function to apply.
13
- * @returns The converted data.
14
- */
15
- export declare const deepConvert: <T>(data: any, convertFn: (value: any) => T) => any;
16
- /**
17
- * Converts an entire object's properties to different types based on a provided schema.
18
- * @param obj The object to convert.
19
- * @param schema A mapping of object keys to conversion functions.
20
- * @returns The converted object.
21
- */
22
- export declare const convertObjectBySchema: (obj: Record<string, any>, schema: Record<string, (value: any) => any>) => Record<string, any>;
23
- /**
24
- * Converts the keys of an object based on a provided attributeMappings.
25
- * Each key in the object is checked against attributeMappings; if a matching entry is found,
26
- * the key is renamed to the targetKey specified in attributeMappings.
27
- *
28
- * @param obj The object to convert.
29
- * @param attributeMappings The attributeMappings defining how keys in the object should be converted.
30
- * @returns The converted object with keys renamed according to attributeMappings.
31
- */
32
- export declare const convertObjectByAttributeMappings: (obj: Record<string, any>, attributeMappings: AttributeMappings) => Record<string, any>;
33
- /**
34
- * Ensures data conversion without mutating the original input.
35
- * @param data The data to convert.
36
- * @param convertFn The conversion function to apply.
37
- * @returns The converted data.
38
- */
39
- export declare const immutableConvert: <T>(data: any, convertFn: (value: any) => T) => T;
40
- /**
41
- * Validates a string against a regular expression and returns the string if valid, or null.
42
- * @param value The string to validate.
43
- * @param pattern The regex pattern to validate against.
44
- * @returns The original string if valid, otherwise null.
45
- */
46
- export declare const validateString: (value: string, pattern: RegExp) => string | null;
@@ -1,139 +0,0 @@
1
- import { converterFunctions } from "@njdamstra/appwrite-utils";
2
- import { cloneDeep, isPlainObject } from "es-toolkit";
3
- /**
4
- * Deeply converts all properties of an object (or array) to strings.
5
- * @param data The input data to convert.
6
- * @returns The data with all its properties converted to strings.
7
- */
8
- export const deepAnyToString = (data) => {
9
- if (Array.isArray(data)) {
10
- return data.map((item) => deepAnyToString(item));
11
- }
12
- else if (isPlainObject(data)) {
13
- return Object.keys(data).reduce((acc, key) => {
14
- acc[key] = deepAnyToString(data[key]);
15
- return acc;
16
- }, {});
17
- }
18
- else {
19
- return converterFunctions.anyToString(data);
20
- }
21
- };
22
- /**
23
- * Performs a deep conversion of all values in a nested structure to the specified type.
24
- * Uses a conversion function like anyToString, anyToNumber, etc.
25
- * @param data The data to convert.
26
- * @param convertFn The conversion function to apply.
27
- * @returns The converted data.
28
- */
29
- export const deepConvert = (data, convertFn) => {
30
- if (Array.isArray(data)) {
31
- return data.map((item) => deepConvert(item, convertFn));
32
- }
33
- else if (isPlainObject(data)) {
34
- return Object.keys(data).reduce((acc, key) => {
35
- acc[key] = deepConvert(data[key], convertFn);
36
- return acc;
37
- }, {});
38
- }
39
- else {
40
- return convertFn(data);
41
- }
42
- };
43
- /**
44
- * Converts an entire object's properties to different types based on a provided schema.
45
- * @param obj The object to convert.
46
- * @param schema A mapping of object keys to conversion functions.
47
- * @returns The converted object.
48
- */
49
- export const convertObjectBySchema = (obj, schema) => {
50
- return Object.keys(obj).reduce((acc, key) => {
51
- const convertFn = schema[key];
52
- acc[key] = convertFn ? convertFn(obj[key]) : obj[key];
53
- return acc;
54
- }, {});
55
- };
56
- /**
57
- * Converts the keys of an object based on a provided attributeMappings.
58
- * Each key in the object is checked against attributeMappings; if a matching entry is found,
59
- * the key is renamed to the targetKey specified in attributeMappings.
60
- *
61
- * @param obj The object to convert.
62
- * @param attributeMappings The attributeMappings defining how keys in the object should be converted.
63
- * @returns The converted object with keys renamed according to attributeMappings.
64
- */
65
- export const convertObjectByAttributeMappings = (obj, attributeMappings) => {
66
- const result = {};
67
- // Correctly handle [any] notation by mapping or aggregating over all elements or keys
68
- const resolveValue = (obj, path) => {
69
- const parts = path.split(".");
70
- let current = obj;
71
- for (let i = 0; i < parts.length; i++) {
72
- if (parts[i] === "[any]") {
73
- if (Array.isArray(current)) {
74
- // If current is an array, apply resolution to each item
75
- return current.map((item) => resolveValue(item, parts.slice(i + 1).join(".")));
76
- }
77
- else if (typeof current === "object" && current !== null) {
78
- // If current is an object, aggregate values from all keys
79
- return Object.values(current).map((value) => resolveValue(value, parts.slice(i + 1).join(".")));
80
- }
81
- }
82
- else {
83
- current = current[parts[i]];
84
- if (current === undefined)
85
- return undefined;
86
- }
87
- }
88
- return current;
89
- };
90
- for (const mapping of attributeMappings) {
91
- if (mapping.valueToSet !== undefined) {
92
- result[mapping.targetKey] = mapping.valueToSet;
93
- }
94
- else if (Array.isArray(mapping.oldKeys)) {
95
- // Collect and flatten values from multiple oldKeys
96
- const values = mapping.oldKeys
97
- .map((oldKey) => resolveValue(obj, oldKey))
98
- .flat(Infinity);
99
- if (values.length > 0) {
100
- result[mapping.targetKey] = values.filter((value) => value !== undefined);
101
- }
102
- else {
103
- result[mapping.targetKey] = null;
104
- }
105
- }
106
- else if (mapping.oldKey) {
107
- // Resolve single oldKey
108
- const value = resolveValue(obj, mapping.oldKey);
109
- if (value !== undefined) {
110
- result[mapping.targetKey] = Array.isArray(value)
111
- ? value.flat(Infinity)
112
- : value;
113
- }
114
- else {
115
- result[mapping.targetKey] = value ? value : null;
116
- }
117
- }
118
- }
119
- return result;
120
- };
121
- /**
122
- * Ensures data conversion without mutating the original input.
123
- * @param data The data to convert.
124
- * @param convertFn The conversion function to apply.
125
- * @returns The converted data.
126
- */
127
- export const immutableConvert = (data, convertFn) => {
128
- const clonedData = cloneDeep(data);
129
- return convertFn(clonedData);
130
- };
131
- /**
132
- * Validates a string against a regular expression and returns the string if valid, or null.
133
- * @param value The string to validate.
134
- * @param pattern The regex pattern to validate against.
135
- * @returns The original string if valid, otherwise null.
136
- */
137
- export const validateString = (value, pattern) => {
138
- return pattern.test(value) ? value : null;
139
- };
@@ -1,22 +0,0 @@
1
- /**
2
- * Directory utility functions for filtering and managing directory traversal
3
- */
4
- /**
5
- * List of directories that should be ignored during recursive searches
6
- * Includes common build outputs, dependencies, caches, and system folders
7
- */
8
- export declare const IGNORED_DIRECTORIES: string[];
9
- /**
10
- * Determines if a directory should be ignored during recursive file operations
11
- *
12
- * @param dirName - The name of the directory to check
13
- * @returns true if the directory should be ignored, false otherwise
14
- *
15
- * @remarks
16
- * A directory is ignored if:
17
- * - It matches one of the entries in IGNORED_DIRECTORIES
18
- * - It starts with '.git' prefix
19
- * - It starts with 'node_modules' prefix
20
- * - It starts with '.' (hidden directory) except for '.appwrite'
21
- */
22
- export declare const shouldIgnoreDirectory: (dirName: string) => boolean;
@@ -1,59 +0,0 @@
1
- /**
2
- * Directory utility functions for filtering and managing directory traversal
3
- */
4
- /**
5
- * List of directories that should be ignored during recursive searches
6
- * Includes common build outputs, dependencies, caches, and system folders
7
- */
8
- export const IGNORED_DIRECTORIES = [
9
- 'node_modules',
10
- 'dist',
11
- 'build',
12
- 'coverage',
13
- '.next',
14
- '.nuxt',
15
- '.cache',
16
- '.git',
17
- '.svn',
18
- '.hg',
19
- '__pycache__',
20
- '.pytest_cache',
21
- '.mypy_cache',
22
- 'venv',
23
- '.venv',
24
- 'env',
25
- '.env',
26
- 'target',
27
- 'out',
28
- 'bin',
29
- 'obj',
30
- '.vs',
31
- '.vscode',
32
- '.idea',
33
- 'temp',
34
- 'tmp',
35
- '.tmp',
36
- 'logs',
37
- 'log',
38
- '.DS_Store',
39
- 'Thumbs.db'
40
- ];
41
- /**
42
- * Determines if a directory should be ignored during recursive file operations
43
- *
44
- * @param dirName - The name of the directory to check
45
- * @returns true if the directory should be ignored, false otherwise
46
- *
47
- * @remarks
48
- * A directory is ignored if:
49
- * - It matches one of the entries in IGNORED_DIRECTORIES
50
- * - It starts with '.git' prefix
51
- * - It starts with 'node_modules' prefix
52
- * - It starts with '.' (hidden directory) except for '.appwrite'
53
- */
54
- export const shouldIgnoreDirectory = (dirName) => {
55
- return IGNORED_DIRECTORIES.includes(dirName) ||
56
- dirName.startsWith('.git') ||
57
- dirName.startsWith('node_modules') ||
58
- (dirName.startsWith('.') && dirName !== '.appwrite');
59
- };
@@ -1,39 +0,0 @@
1
- import { type AppwriteConfig } from "@njdamstra/appwrite-utils";
2
- import { Client } from "node-appwrite";
3
- import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
4
- /**
5
- * Enhanced client creation from config with session authentication support
6
- * @deprecated Use getAdapterFromConfig for dual API support with session auth
7
- */
8
- export declare const getClientFromConfig: (config: AppwriteConfig, sessionCookie?: string) => Client | undefined;
9
- /**
10
- * Enhanced client creation with session authentication support
11
- * Priority: explicit session > session from prefs > API key
12
- */
13
- export declare const getClientWithAuth: (endpoint: string, project: string, key?: string, sessionCookie?: string) => Client;
14
- /**
15
- * Legacy function - returns basic Client
16
- * @deprecated Use getClientWithAuth for session support or createDatabaseAdapter for dual API support
17
- */
18
- export declare const getClient: (endpoint: string, project: string, key: string) => Client;
19
- /**
20
- * Modern adapter-based client creation with dual API support and session authentication
21
- * Returns both adapter and legacy client for compatibility
22
- */
23
- export declare const getAdapterFromConfig: (config: AppwriteConfig, forceRefresh?: boolean, sessionCookie?: string) => Promise<{
24
- adapter: DatabaseAdapter;
25
- client: Client;
26
- apiMode: "legacy" | "tablesdb";
27
- }>;
28
- /**
29
- * Create adapter from individual parameters with session authentication support
30
- */
31
- export declare const getAdapter: (endpoint: string, project: string, key?: string, apiMode?: "auto" | "legacy" | "tablesdb", sessionCookie?: string) => Promise<{
32
- adapter: DatabaseAdapter;
33
- client: Client;
34
- apiMode: "legacy" | "tablesdb";
35
- }>;
36
- /**
37
- * Check if session authentication is available for a project
38
- */
39
- export declare const checkSessionAuth: (endpoint: string, project: string) => boolean;