@njdamstra/appwrite-utils-cli 1.8.9 → 1.10.0

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 (284) 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 +2 -35
  25. package/dist/collections/indexes.js +1 -3
  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 +55 -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 +63 -9
  44. package/dist/main.js +130 -177
  45. package/dist/migrations/afterImportActions.js +2 -3
  46. package/dist/migrations/appwriteToX.d.ts +1 -1
  47. package/dist/migrations/appwriteToX.js +9 -7
  48. package/dist/migrations/comprehensiveTransfer.js +3 -5
  49. package/dist/migrations/dataLoader.js +2 -5
  50. package/dist/migrations/importController.js +3 -4
  51. package/dist/migrations/importDataActions.js +3 -3
  52. package/dist/migrations/relationships.js +1 -2
  53. package/dist/migrations/services/DataTransformationService.js +2 -2
  54. package/dist/migrations/services/FileHandlerService.js +1 -1
  55. package/dist/migrations/services/ImportOrchestrator.js +4 -4
  56. package/dist/migrations/services/RateLimitManager.js +1 -1
  57. package/dist/migrations/services/RelationshipResolver.js +1 -1
  58. package/dist/migrations/services/UserMappingService.js +1 -1
  59. package/dist/migrations/services/ValidationService.js +1 -1
  60. package/dist/migrations/transfer.d.ts +8 -4
  61. package/dist/migrations/transfer.js +106 -55
  62. package/dist/migrations/yaml/YamlImportConfigLoader.js +1 -1
  63. package/dist/migrations/yaml/YamlImportIntegration.js +2 -2
  64. package/dist/migrations/yaml/generateImportSchemas.js +1 -1
  65. package/dist/setupCommands.d.ts +1 -1
  66. package/dist/setupCommands.js +5 -6
  67. package/dist/setupController.js +1 -1
  68. package/dist/shared/backupTracking.d.ts +1 -1
  69. package/dist/shared/backupTracking.js +2 -2
  70. package/dist/shared/confirmationDialogs.js +1 -1
  71. package/dist/shared/migrationHelpers.d.ts +1 -1
  72. package/dist/shared/migrationHelpers.js +3 -3
  73. package/dist/shared/operationQueue.d.ts +1 -1
  74. package/dist/shared/operationQueue.js +2 -3
  75. package/dist/shared/operationsTable.d.ts +1 -1
  76. package/dist/shared/operationsTable.js +2 -2
  77. package/dist/shared/progressManager.js +1 -1
  78. package/dist/shared/selectionDialogs.js +9 -8
  79. package/dist/storage/methods.js +4 -4
  80. package/dist/storage/schemas.d.ts +2 -2
  81. package/dist/tables/indexManager.d.ts +65 -0
  82. package/dist/tables/indexManager.js +294 -0
  83. package/dist/types.d.ts +2 -2
  84. package/dist/types.js +1 -1
  85. package/dist/users/methods.js +2 -3
  86. package/dist/utils/configMigration.js +1 -1
  87. package/dist/utils/index.d.ts +1 -1
  88. package/dist/utils/index.js +1 -1
  89. package/dist/utils/loadConfigs.d.ts +2 -2
  90. package/dist/utils/loadConfigs.js +6 -7
  91. package/dist/utils/setupFiles.js +5 -7
  92. package/dist/utilsController.d.ts +15 -8
  93. package/dist/utilsController.js +57 -28
  94. package/package.json +7 -3
  95. package/src/adapters/index.ts +8 -34
  96. package/src/backups/operations/bucketBackup.ts +2 -2
  97. package/src/backups/operations/collectionBackup.ts +4 -4
  98. package/src/backups/operations/comprehensiveBackup.ts +3 -3
  99. package/src/backups/tracking/centralizedTracking.ts +3 -3
  100. package/src/cli/commands/configCommands.ts +72 -8
  101. package/src/cli/commands/databaseCommands.ts +161 -9
  102. package/src/cli/commands/functionCommands.ts +4 -3
  103. package/src/cli/commands/importFileCommands.ts +815 -0
  104. package/src/cli/commands/schemaCommands.ts +3 -3
  105. package/src/cli/commands/storageCommands.ts +2 -3
  106. package/src/cli/commands/transferCommands.ts +3 -6
  107. package/src/collections/attributes.ts +3 -39
  108. package/src/collections/indexes.ts +2 -4
  109. package/src/collections/methods.ts +115 -150
  110. package/src/collections/tableOperations.ts +57 -21
  111. package/src/collections/transferOperations.ts +4 -5
  112. package/src/collections/wipeOperations.ts +154 -51
  113. package/src/databases/methods.ts +2 -2
  114. package/src/databases/setup.ts +2 -2
  115. package/src/examples/yamlTerminologyExample.ts +2 -2
  116. package/src/functions/deployments.ts +6 -5
  117. package/src/functions/fnConfigDiscovery.ts +2 -2
  118. package/src/functions/methods.ts +17 -4
  119. package/src/init.ts +1 -1
  120. package/src/interactiveCLI.ts +75 -10
  121. package/src/main.ts +143 -287
  122. package/src/migrations/afterImportActions.ts +2 -3
  123. package/src/migrations/appwriteToX.ts +12 -8
  124. package/src/migrations/comprehensiveTransfer.ts +6 -6
  125. package/src/migrations/dataLoader.ts +2 -5
  126. package/src/migrations/importController.ts +3 -4
  127. package/src/migrations/importDataActions.ts +3 -3
  128. package/src/migrations/relationships.ts +1 -2
  129. package/src/migrations/services/DataTransformationService.ts +2 -2
  130. package/src/migrations/services/FileHandlerService.ts +1 -1
  131. package/src/migrations/services/ImportOrchestrator.ts +4 -4
  132. package/src/migrations/services/RateLimitManager.ts +1 -1
  133. package/src/migrations/services/RelationshipResolver.ts +1 -1
  134. package/src/migrations/services/UserMappingService.ts +1 -1
  135. package/src/migrations/services/ValidationService.ts +1 -1
  136. package/src/migrations/transfer.ts +126 -83
  137. package/src/migrations/yaml/YamlImportConfigLoader.ts +1 -1
  138. package/src/migrations/yaml/YamlImportIntegration.ts +2 -2
  139. package/src/migrations/yaml/generateImportSchemas.ts +1 -1
  140. package/src/setupCommands.ts +5 -6
  141. package/src/setupController.ts +1 -1
  142. package/src/shared/backupTracking.ts +3 -3
  143. package/src/shared/confirmationDialogs.ts +1 -1
  144. package/src/shared/migrationHelpers.ts +4 -4
  145. package/src/shared/operationQueue.ts +3 -4
  146. package/src/shared/operationsTable.ts +3 -3
  147. package/src/shared/progressManager.ts +1 -1
  148. package/src/shared/selectionDialogs.ts +9 -8
  149. package/src/storage/methods.ts +4 -4
  150. package/src/tables/indexManager.ts +409 -0
  151. package/src/types.ts +2 -2
  152. package/src/users/methods.ts +2 -3
  153. package/src/utils/configMigration.ts +1 -1
  154. package/src/utils/index.ts +1 -1
  155. package/src/utils/loadConfigs.ts +15 -7
  156. package/src/utils/setupFiles.ts +5 -7
  157. package/src/utilsController.ts +86 -32
  158. package/dist/adapters/AdapterFactory.d.ts +0 -94
  159. package/dist/adapters/AdapterFactory.js +0 -405
  160. package/dist/adapters/DatabaseAdapter.d.ts +0 -233
  161. package/dist/adapters/DatabaseAdapter.js +0 -50
  162. package/dist/adapters/LegacyAdapter.d.ts +0 -50
  163. package/dist/adapters/LegacyAdapter.js +0 -612
  164. package/dist/adapters/TablesDBAdapter.d.ts +0 -45
  165. package/dist/adapters/TablesDBAdapter.js +0 -571
  166. package/dist/config/ConfigManager.d.ts +0 -445
  167. package/dist/config/ConfigManager.js +0 -625
  168. package/dist/config/configMigration.d.ts +0 -87
  169. package/dist/config/configMigration.js +0 -390
  170. package/dist/config/configValidation.d.ts +0 -66
  171. package/dist/config/configValidation.js +0 -358
  172. package/dist/config/index.d.ts +0 -8
  173. package/dist/config/index.js +0 -7
  174. package/dist/config/services/ConfigDiscoveryService.d.ts +0 -126
  175. package/dist/config/services/ConfigDiscoveryService.js +0 -374
  176. package/dist/config/services/ConfigLoaderService.d.ts +0 -129
  177. package/dist/config/services/ConfigLoaderService.js +0 -540
  178. package/dist/config/services/ConfigMergeService.d.ts +0 -208
  179. package/dist/config/services/ConfigMergeService.js +0 -308
  180. package/dist/config/services/ConfigValidationService.d.ts +0 -214
  181. package/dist/config/services/ConfigValidationService.js +0 -310
  182. package/dist/config/services/SessionAuthService.d.ts +0 -225
  183. package/dist/config/services/SessionAuthService.js +0 -456
  184. package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +0 -1
  185. package/dist/config/services/__tests__/ConfigMergeService.test.js +0 -271
  186. package/dist/config/services/index.d.ts +0 -13
  187. package/dist/config/services/index.js +0 -10
  188. package/dist/config/yamlConfig.d.ts +0 -722
  189. package/dist/config/yamlConfig.js +0 -702
  190. package/dist/functions/pathResolution.d.ts +0 -37
  191. package/dist/functions/pathResolution.js +0 -185
  192. package/dist/shared/attributeMapper.d.ts +0 -20
  193. package/dist/shared/attributeMapper.js +0 -203
  194. package/dist/shared/errorUtils.d.ts +0 -54
  195. package/dist/shared/errorUtils.js +0 -95
  196. package/dist/shared/functionManager.d.ts +0 -48
  197. package/dist/shared/functionManager.js +0 -336
  198. package/dist/shared/indexManager.d.ts +0 -24
  199. package/dist/shared/indexManager.js +0 -151
  200. package/dist/shared/jsonSchemaGenerator.d.ts +0 -50
  201. package/dist/shared/jsonSchemaGenerator.js +0 -290
  202. package/dist/shared/logging.d.ts +0 -61
  203. package/dist/shared/logging.js +0 -116
  204. package/dist/shared/messageFormatter.d.ts +0 -39
  205. package/dist/shared/messageFormatter.js +0 -162
  206. package/dist/shared/pydanticModelGenerator.d.ts +0 -17
  207. package/dist/shared/pydanticModelGenerator.js +0 -615
  208. package/dist/shared/schemaGenerator.d.ts +0 -40
  209. package/dist/shared/schemaGenerator.js +0 -556
  210. package/dist/utils/ClientFactory.d.ts +0 -87
  211. package/dist/utils/ClientFactory.js +0 -212
  212. package/dist/utils/configDiscovery.d.ts +0 -78
  213. package/dist/utils/configDiscovery.js +0 -472
  214. package/dist/utils/constantsGenerator.d.ts +0 -31
  215. package/dist/utils/constantsGenerator.js +0 -321
  216. package/dist/utils/dataConverters.d.ts +0 -46
  217. package/dist/utils/dataConverters.js +0 -139
  218. package/dist/utils/directoryUtils.d.ts +0 -22
  219. package/dist/utils/directoryUtils.js +0 -59
  220. package/dist/utils/getClientFromConfig.d.ts +0 -39
  221. package/dist/utils/getClientFromConfig.js +0 -199
  222. package/dist/utils/helperFunctions.d.ts +0 -63
  223. package/dist/utils/helperFunctions.js +0 -156
  224. package/dist/utils/pathResolvers.d.ts +0 -53
  225. package/dist/utils/pathResolvers.js +0 -72
  226. package/dist/utils/projectConfig.d.ts +0 -119
  227. package/dist/utils/projectConfig.js +0 -171
  228. package/dist/utils/retryFailedPromises.d.ts +0 -2
  229. package/dist/utils/retryFailedPromises.js +0 -23
  230. package/dist/utils/sessionAuth.d.ts +0 -48
  231. package/dist/utils/sessionAuth.js +0 -164
  232. package/dist/utils/typeGuards.d.ts +0 -35
  233. package/dist/utils/typeGuards.js +0 -57
  234. package/dist/utils/validationRules.d.ts +0 -43
  235. package/dist/utils/validationRules.js +0 -42
  236. package/dist/utils/versionDetection.d.ts +0 -58
  237. package/dist/utils/versionDetection.js +0 -251
  238. package/dist/utils/yamlConverter.d.ts +0 -100
  239. package/dist/utils/yamlConverter.js +0 -428
  240. package/dist/utils/yamlLoader.d.ts +0 -70
  241. package/dist/utils/yamlLoader.js +0 -267
  242. package/src/adapters/AdapterFactory.ts +0 -510
  243. package/src/adapters/DatabaseAdapter.ts +0 -306
  244. package/src/adapters/LegacyAdapter.ts +0 -841
  245. package/src/adapters/TablesDBAdapter.ts +0 -773
  246. package/src/config/ConfigManager.ts +0 -808
  247. package/src/config/README.md +0 -274
  248. package/src/config/configMigration.ts +0 -575
  249. package/src/config/configValidation.ts +0 -445
  250. package/src/config/index.ts +0 -10
  251. package/src/config/services/ConfigDiscoveryService.ts +0 -463
  252. package/src/config/services/ConfigLoaderService.ts +0 -740
  253. package/src/config/services/ConfigMergeService.ts +0 -388
  254. package/src/config/services/ConfigValidationService.ts +0 -394
  255. package/src/config/services/SessionAuthService.ts +0 -565
  256. package/src/config/services/__tests__/ConfigMergeService.test.ts +0 -351
  257. package/src/config/services/index.ts +0 -29
  258. package/src/config/yamlConfig.ts +0 -761
  259. package/src/functions/pathResolution.ts +0 -227
  260. package/src/shared/attributeMapper.ts +0 -229
  261. package/src/shared/errorUtils.ts +0 -110
  262. package/src/shared/functionManager.ts +0 -525
  263. package/src/shared/indexManager.ts +0 -254
  264. package/src/shared/jsonSchemaGenerator.ts +0 -383
  265. package/src/shared/logging.ts +0 -149
  266. package/src/shared/messageFormatter.ts +0 -208
  267. package/src/shared/pydanticModelGenerator.ts +0 -618
  268. package/src/shared/schemaGenerator.ts +0 -644
  269. package/src/utils/ClientFactory.ts +0 -240
  270. package/src/utils/configDiscovery.ts +0 -557
  271. package/src/utils/constantsGenerator.ts +0 -369
  272. package/src/utils/dataConverters.ts +0 -159
  273. package/src/utils/directoryUtils.ts +0 -61
  274. package/src/utils/getClientFromConfig.ts +0 -257
  275. package/src/utils/helperFunctions.ts +0 -228
  276. package/src/utils/pathResolvers.ts +0 -81
  277. package/src/utils/projectConfig.ts +0 -299
  278. package/src/utils/retryFailedPromises.ts +0 -29
  279. package/src/utils/sessionAuth.ts +0 -230
  280. package/src/utils/typeGuards.ts +0 -65
  281. package/src/utils/validationRules.ts +0 -88
  282. package/src/utils/versionDetection.ts +0 -292
  283. package/src/utils/yamlConverter.ts +0 -542
  284. 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;