@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.
- package/CHANGELOG.md +19 -0
- package/README.md +1133 -0
- package/dist/adapters/AdapterFactory.d.ts +94 -0
- package/dist/adapters/AdapterFactory.js +405 -0
- package/dist/adapters/DatabaseAdapter.d.ts +233 -0
- package/dist/adapters/DatabaseAdapter.js +50 -0
- package/dist/adapters/LegacyAdapter.d.ts +50 -0
- package/dist/adapters/LegacyAdapter.js +612 -0
- package/dist/adapters/TablesDBAdapter.d.ts +45 -0
- package/dist/adapters/TablesDBAdapter.js +571 -0
- package/dist/adapters/index.d.ts +11 -0
- package/dist/adapters/index.js +12 -0
- package/dist/backups/operations/bucketBackup.d.ts +19 -0
- package/dist/backups/operations/bucketBackup.js +197 -0
- package/dist/backups/operations/collectionBackup.d.ts +30 -0
- package/dist/backups/operations/collectionBackup.js +201 -0
- package/dist/backups/operations/comprehensiveBackup.d.ts +25 -0
- package/dist/backups/operations/comprehensiveBackup.js +238 -0
- package/dist/backups/schemas/bucketManifest.d.ts +93 -0
- package/dist/backups/schemas/bucketManifest.js +33 -0
- package/dist/backups/schemas/comprehensiveManifest.d.ts +108 -0
- package/dist/backups/schemas/comprehensiveManifest.js +32 -0
- package/dist/backups/tracking/centralizedTracking.d.ts +34 -0
- package/dist/backups/tracking/centralizedTracking.js +274 -0
- package/dist/cli/commands/configCommands.d.ts +8 -0
- package/dist/cli/commands/configCommands.js +166 -0
- package/dist/cli/commands/databaseCommands.d.ts +13 -0
- package/dist/cli/commands/databaseCommands.js +554 -0
- package/dist/cli/commands/functionCommands.d.ts +7 -0
- package/dist/cli/commands/functionCommands.js +330 -0
- package/dist/cli/commands/schemaCommands.d.ts +7 -0
- package/dist/cli/commands/schemaCommands.js +169 -0
- package/dist/cli/commands/storageCommands.d.ts +5 -0
- package/dist/cli/commands/storageCommands.js +143 -0
- package/dist/cli/commands/transferCommands.d.ts +5 -0
- package/dist/cli/commands/transferCommands.js +384 -0
- package/dist/collections/attributes.d.ts +13 -0
- package/dist/collections/attributes.js +1364 -0
- package/dist/collections/indexes.d.ts +12 -0
- package/dist/collections/indexes.js +217 -0
- package/dist/collections/methods.d.ts +19 -0
- package/dist/collections/methods.js +682 -0
- package/dist/collections/tableOperations.d.ts +86 -0
- package/dist/collections/tableOperations.js +434 -0
- package/dist/collections/transferOperations.d.ts +8 -0
- package/dist/collections/transferOperations.js +412 -0
- package/dist/collections/wipeOperations.d.ts +16 -0
- package/dist/collections/wipeOperations.js +233 -0
- package/dist/config/ConfigManager.d.ts +445 -0
- package/dist/config/ConfigManager.js +625 -0
- package/dist/config/configMigration.d.ts +87 -0
- package/dist/config/configMigration.js +390 -0
- package/dist/config/configValidation.d.ts +66 -0
- package/dist/config/configValidation.js +358 -0
- package/dist/config/index.d.ts +8 -0
- package/dist/config/index.js +7 -0
- package/dist/config/services/ConfigDiscoveryService.d.ts +126 -0
- package/dist/config/services/ConfigDiscoveryService.js +374 -0
- package/dist/config/services/ConfigLoaderService.d.ts +129 -0
- package/dist/config/services/ConfigLoaderService.js +540 -0
- package/dist/config/services/ConfigMergeService.d.ts +208 -0
- package/dist/config/services/ConfigMergeService.js +308 -0
- package/dist/config/services/ConfigValidationService.d.ts +214 -0
- package/dist/config/services/ConfigValidationService.js +310 -0
- package/dist/config/services/SessionAuthService.d.ts +225 -0
- package/dist/config/services/SessionAuthService.js +456 -0
- package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +1 -0
- package/dist/config/services/__tests__/ConfigMergeService.test.js +271 -0
- package/dist/config/services/index.d.ts +13 -0
- package/dist/config/services/index.js +10 -0
- package/dist/config/yamlConfig.d.ts +722 -0
- package/dist/config/yamlConfig.js +702 -0
- package/dist/databases/methods.d.ts +6 -0
- package/dist/databases/methods.js +35 -0
- package/dist/databases/setup.d.ts +5 -0
- package/dist/databases/setup.js +45 -0
- package/dist/examples/yamlTerminologyExample.d.ts +42 -0
- package/dist/examples/yamlTerminologyExample.js +272 -0
- package/dist/functions/deployments.d.ts +4 -0
- package/dist/functions/deployments.js +146 -0
- package/dist/functions/fnConfigDiscovery.d.ts +3 -0
- package/dist/functions/fnConfigDiscovery.js +108 -0
- package/dist/functions/methods.d.ts +16 -0
- package/dist/functions/methods.js +162 -0
- package/dist/functions/pathResolution.d.ts +37 -0
- package/dist/functions/pathResolution.js +185 -0
- package/dist/functions/templates/count-docs-in-collection/README.md +54 -0
- package/dist/functions/templates/count-docs-in-collection/src/main.ts +159 -0
- package/dist/functions/templates/count-docs-in-collection/src/request.ts +9 -0
- package/dist/functions/templates/hono-typescript/README.md +286 -0
- package/dist/functions/templates/hono-typescript/src/adapters/request.ts +74 -0
- package/dist/functions/templates/hono-typescript/src/adapters/response.ts +106 -0
- package/dist/functions/templates/hono-typescript/src/app.ts +180 -0
- package/dist/functions/templates/hono-typescript/src/context.ts +103 -0
- package/dist/functions/templates/hono-typescript/src/index.ts +54 -0
- package/dist/functions/templates/hono-typescript/src/middleware/appwrite.ts +119 -0
- package/dist/functions/templates/typescript-node/README.md +32 -0
- package/dist/functions/templates/typescript-node/src/context.ts +103 -0
- package/dist/functions/templates/typescript-node/src/index.ts +29 -0
- package/dist/functions/templates/uv/README.md +31 -0
- package/dist/functions/templates/uv/pyproject.toml +30 -0
- package/dist/functions/templates/uv/src/__init__.py +0 -0
- package/dist/functions/templates/uv/src/context.py +125 -0
- package/dist/functions/templates/uv/src/index.py +46 -0
- package/dist/init.d.ts +2 -0
- package/dist/init.js +57 -0
- package/dist/interactiveCLI.d.ts +31 -0
- package/dist/interactiveCLI.js +898 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.js +1172 -0
- package/dist/migrations/afterImportActions.d.ts +17 -0
- package/dist/migrations/afterImportActions.js +306 -0
- package/dist/migrations/appwriteToX.d.ts +211 -0
- package/dist/migrations/appwriteToX.js +491 -0
- package/dist/migrations/comprehensiveTransfer.d.ts +147 -0
- package/dist/migrations/comprehensiveTransfer.js +1317 -0
- package/dist/migrations/dataLoader.d.ts +753 -0
- package/dist/migrations/dataLoader.js +1250 -0
- package/dist/migrations/importController.d.ts +23 -0
- package/dist/migrations/importController.js +268 -0
- package/dist/migrations/importDataActions.d.ts +50 -0
- package/dist/migrations/importDataActions.js +230 -0
- package/dist/migrations/relationships.d.ts +29 -0
- package/dist/migrations/relationships.js +204 -0
- package/dist/migrations/services/DataTransformationService.d.ts +55 -0
- package/dist/migrations/services/DataTransformationService.js +158 -0
- package/dist/migrations/services/FileHandlerService.d.ts +75 -0
- package/dist/migrations/services/FileHandlerService.js +236 -0
- package/dist/migrations/services/ImportOrchestrator.d.ts +97 -0
- package/dist/migrations/services/ImportOrchestrator.js +485 -0
- package/dist/migrations/services/RateLimitManager.d.ts +138 -0
- package/dist/migrations/services/RateLimitManager.js +279 -0
- package/dist/migrations/services/RelationshipResolver.d.ts +120 -0
- package/dist/migrations/services/RelationshipResolver.js +332 -0
- package/dist/migrations/services/UserMappingService.d.ts +109 -0
- package/dist/migrations/services/UserMappingService.js +277 -0
- package/dist/migrations/services/ValidationService.d.ts +74 -0
- package/dist/migrations/services/ValidationService.js +260 -0
- package/dist/migrations/transfer.d.ts +26 -0
- package/dist/migrations/transfer.js +608 -0
- package/dist/migrations/yaml/YamlImportConfigLoader.d.ts +131 -0
- package/dist/migrations/yaml/YamlImportConfigLoader.js +383 -0
- package/dist/migrations/yaml/YamlImportIntegration.d.ts +93 -0
- package/dist/migrations/yaml/YamlImportIntegration.js +341 -0
- package/dist/migrations/yaml/generateImportSchemas.d.ts +30 -0
- package/dist/migrations/yaml/generateImportSchemas.js +1327 -0
- package/dist/schemas/authUser.d.ts +24 -0
- package/dist/schemas/authUser.js +17 -0
- package/dist/setup.d.ts +2 -0
- package/dist/setup.js +5 -0
- package/dist/setupCommands.d.ts +58 -0
- package/dist/setupCommands.js +490 -0
- package/dist/setupController.d.ts +9 -0
- package/dist/setupController.js +34 -0
- package/dist/shared/attributeMapper.d.ts +20 -0
- package/dist/shared/attributeMapper.js +203 -0
- package/dist/shared/backupMetadataSchema.d.ts +94 -0
- package/dist/shared/backupMetadataSchema.js +38 -0
- package/dist/shared/backupTracking.d.ts +18 -0
- package/dist/shared/backupTracking.js +176 -0
- package/dist/shared/confirmationDialogs.d.ts +75 -0
- package/dist/shared/confirmationDialogs.js +236 -0
- package/dist/shared/errorUtils.d.ts +54 -0
- package/dist/shared/errorUtils.js +95 -0
- package/dist/shared/functionManager.d.ts +48 -0
- package/dist/shared/functionManager.js +336 -0
- package/dist/shared/indexManager.d.ts +24 -0
- package/dist/shared/indexManager.js +151 -0
- package/dist/shared/jsonSchemaGenerator.d.ts +50 -0
- package/dist/shared/jsonSchemaGenerator.js +290 -0
- package/dist/shared/logging.d.ts +61 -0
- package/dist/shared/logging.js +116 -0
- package/dist/shared/messageFormatter.d.ts +39 -0
- package/dist/shared/messageFormatter.js +162 -0
- package/dist/shared/migrationHelpers.d.ts +61 -0
- package/dist/shared/migrationHelpers.js +145 -0
- package/dist/shared/operationLogger.d.ts +10 -0
- package/dist/shared/operationLogger.js +12 -0
- package/dist/shared/operationQueue.d.ts +40 -0
- package/dist/shared/operationQueue.js +311 -0
- package/dist/shared/operationsTable.d.ts +26 -0
- package/dist/shared/operationsTable.js +286 -0
- package/dist/shared/operationsTableSchema.d.ts +48 -0
- package/dist/shared/operationsTableSchema.js +35 -0
- package/dist/shared/progressManager.d.ts +62 -0
- package/dist/shared/progressManager.js +215 -0
- package/dist/shared/pydanticModelGenerator.d.ts +17 -0
- package/dist/shared/pydanticModelGenerator.js +615 -0
- package/dist/shared/relationshipExtractor.d.ts +56 -0
- package/dist/shared/relationshipExtractor.js +138 -0
- package/dist/shared/schemaGenerator.d.ts +40 -0
- package/dist/shared/schemaGenerator.js +556 -0
- package/dist/shared/selectionDialogs.d.ts +214 -0
- package/dist/shared/selectionDialogs.js +544 -0
- package/dist/storage/backupCompression.d.ts +20 -0
- package/dist/storage/backupCompression.js +67 -0
- package/dist/storage/methods.d.ts +32 -0
- package/dist/storage/methods.js +472 -0
- package/dist/storage/schemas.d.ts +842 -0
- package/dist/storage/schemas.js +175 -0
- package/dist/types.d.ts +4 -0
- package/dist/types.js +3 -0
- package/dist/users/methods.d.ts +16 -0
- package/dist/users/methods.js +277 -0
- package/dist/utils/ClientFactory.d.ts +87 -0
- package/dist/utils/ClientFactory.js +212 -0
- package/dist/utils/configDiscovery.d.ts +78 -0
- package/dist/utils/configDiscovery.js +472 -0
- package/dist/utils/configMigration.d.ts +1 -0
- package/dist/utils/configMigration.js +261 -0
- package/dist/utils/constantsGenerator.d.ts +31 -0
- package/dist/utils/constantsGenerator.js +321 -0
- package/dist/utils/dataConverters.d.ts +46 -0
- package/dist/utils/dataConverters.js +139 -0
- package/dist/utils/directoryUtils.d.ts +22 -0
- package/dist/utils/directoryUtils.js +59 -0
- package/dist/utils/getClientFromConfig.d.ts +39 -0
- package/dist/utils/getClientFromConfig.js +199 -0
- package/dist/utils/helperFunctions.d.ts +63 -0
- package/dist/utils/helperFunctions.js +156 -0
- package/dist/utils/index.d.ts +2 -0
- package/dist/utils/index.js +2 -0
- package/dist/utils/loadConfigs.d.ts +50 -0
- package/dist/utils/loadConfigs.js +358 -0
- package/dist/utils/pathResolvers.d.ts +53 -0
- package/dist/utils/pathResolvers.js +72 -0
- package/dist/utils/projectConfig.d.ts +119 -0
- package/dist/utils/projectConfig.js +171 -0
- package/dist/utils/retryFailedPromises.d.ts +2 -0
- package/dist/utils/retryFailedPromises.js +23 -0
- package/dist/utils/sessionAuth.d.ts +48 -0
- package/dist/utils/sessionAuth.js +164 -0
- package/dist/utils/setupFiles.d.ts +4 -0
- package/dist/utils/setupFiles.js +1192 -0
- package/dist/utils/typeGuards.d.ts +35 -0
- package/dist/utils/typeGuards.js +57 -0
- package/dist/utils/validationRules.d.ts +43 -0
- package/dist/utils/validationRules.js +42 -0
- package/dist/utils/versionDetection.d.ts +58 -0
- package/dist/utils/versionDetection.js +251 -0
- package/dist/utils/yamlConverter.d.ts +100 -0
- package/dist/utils/yamlConverter.js +428 -0
- package/dist/utils/yamlLoader.d.ts +70 -0
- package/dist/utils/yamlLoader.js +267 -0
- package/dist/utilsController.d.ts +106 -0
- package/dist/utilsController.js +863 -0
- package/package.json +75 -0
- package/scripts/copy-templates.ts +23 -0
- package/src/adapters/AdapterFactory.ts +510 -0
- package/src/adapters/DatabaseAdapter.ts +306 -0
- package/src/adapters/LegacyAdapter.ts +841 -0
- package/src/adapters/TablesDBAdapter.ts +773 -0
- package/src/adapters/index.ts +37 -0
- package/src/backups/operations/bucketBackup.ts +277 -0
- package/src/backups/operations/collectionBackup.ts +310 -0
- package/src/backups/operations/comprehensiveBackup.ts +342 -0
- package/src/backups/schemas/bucketManifest.ts +78 -0
- package/src/backups/schemas/comprehensiveManifest.ts +76 -0
- package/src/backups/tracking/centralizedTracking.ts +352 -0
- package/src/cli/commands/configCommands.ts +201 -0
- package/src/cli/commands/databaseCommands.ts +749 -0
- package/src/cli/commands/functionCommands.ts +418 -0
- package/src/cli/commands/schemaCommands.ts +200 -0
- package/src/cli/commands/storageCommands.ts +152 -0
- package/src/cli/commands/transferCommands.ts +457 -0
- package/src/collections/attributes.ts +2054 -0
- package/src/collections/attributes.ts.backup +1555 -0
- package/src/collections/indexes.ts +352 -0
- package/src/collections/methods.ts +745 -0
- package/src/collections/tableOperations.ts +506 -0
- package/src/collections/transferOperations.ts +590 -0
- package/src/collections/wipeOperations.ts +346 -0
- package/src/config/ConfigManager.ts +808 -0
- package/src/config/README.md +274 -0
- package/src/config/configMigration.ts +575 -0
- package/src/config/configValidation.ts +445 -0
- package/src/config/index.ts +10 -0
- package/src/config/services/ConfigDiscoveryService.ts +463 -0
- package/src/config/services/ConfigLoaderService.ts +740 -0
- package/src/config/services/ConfigMergeService.ts +388 -0
- package/src/config/services/ConfigValidationService.ts +394 -0
- package/src/config/services/SessionAuthService.ts +565 -0
- package/src/config/services/__tests__/ConfigMergeService.test.ts +351 -0
- package/src/config/services/index.ts +29 -0
- package/src/config/yamlConfig.ts +761 -0
- package/src/databases/methods.ts +49 -0
- package/src/databases/setup.ts +77 -0
- package/src/examples/yamlTerminologyExample.ts +346 -0
- package/src/functions/deployments.ts +220 -0
- package/src/functions/fnConfigDiscovery.ts +103 -0
- package/src/functions/methods.ts +271 -0
- package/src/functions/pathResolution.ts +227 -0
- package/src/functions/templates/count-docs-in-collection/README.md +54 -0
- package/src/functions/templates/count-docs-in-collection/src/main.ts +159 -0
- package/src/functions/templates/count-docs-in-collection/src/request.ts +9 -0
- package/src/functions/templates/hono-typescript/README.md +286 -0
- package/src/functions/templates/hono-typescript/src/adapters/request.ts +74 -0
- package/src/functions/templates/hono-typescript/src/adapters/response.ts +106 -0
- package/src/functions/templates/hono-typescript/src/app.ts +180 -0
- package/src/functions/templates/hono-typescript/src/context.ts +103 -0
- package/src/functions/templates/hono-typescript/src/index.ts +54 -0
- package/src/functions/templates/hono-typescript/src/middleware/appwrite.ts +119 -0
- package/src/functions/templates/typescript-node/README.md +32 -0
- package/src/functions/templates/typescript-node/src/context.ts +103 -0
- package/src/functions/templates/typescript-node/src/index.ts +29 -0
- package/src/functions/templates/uv/README.md +31 -0
- package/src/functions/templates/uv/pyproject.toml +30 -0
- package/src/functions/templates/uv/src/__init__.py +0 -0
- package/src/functions/templates/uv/src/context.py +125 -0
- package/src/functions/templates/uv/src/index.py +46 -0
- package/src/init.ts +62 -0
- package/src/interactiveCLI.ts +1136 -0
- package/src/main.ts +1661 -0
- package/src/migrations/afterImportActions.ts +580 -0
- package/src/migrations/appwriteToX.ts +664 -0
- package/src/migrations/comprehensiveTransfer.ts +2285 -0
- package/src/migrations/dataLoader.ts +1702 -0
- package/src/migrations/importController.ts +428 -0
- package/src/migrations/importDataActions.ts +315 -0
- package/src/migrations/relationships.ts +334 -0
- package/src/migrations/services/DataTransformationService.ts +196 -0
- package/src/migrations/services/FileHandlerService.ts +311 -0
- package/src/migrations/services/ImportOrchestrator.ts +666 -0
- package/src/migrations/services/RateLimitManager.ts +363 -0
- package/src/migrations/services/RelationshipResolver.ts +461 -0
- package/src/migrations/services/UserMappingService.ts +345 -0
- package/src/migrations/services/ValidationService.ts +349 -0
- package/src/migrations/transfer.ts +1068 -0
- package/src/migrations/yaml/YamlImportConfigLoader.ts +439 -0
- package/src/migrations/yaml/YamlImportIntegration.ts +446 -0
- package/src/migrations/yaml/generateImportSchemas.ts +1354 -0
- package/src/schemas/authUser.ts +23 -0
- package/src/setup.ts +8 -0
- package/src/setupCommands.ts +603 -0
- package/src/setupController.ts +43 -0
- package/src/shared/attributeMapper.ts +229 -0
- package/src/shared/backupMetadataSchema.ts +93 -0
- package/src/shared/backupTracking.ts +211 -0
- package/src/shared/confirmationDialogs.ts +327 -0
- package/src/shared/errorUtils.ts +110 -0
- package/src/shared/functionManager.ts +525 -0
- package/src/shared/indexManager.ts +254 -0
- package/src/shared/jsonSchemaGenerator.ts +383 -0
- package/src/shared/logging.ts +149 -0
- package/src/shared/messageFormatter.ts +208 -0
- package/src/shared/migrationHelpers.ts +232 -0
- package/src/shared/operationLogger.ts +20 -0
- package/src/shared/operationQueue.ts +377 -0
- package/src/shared/operationsTable.ts +338 -0
- package/src/shared/operationsTableSchema.ts +60 -0
- package/src/shared/progressManager.ts +278 -0
- package/src/shared/pydanticModelGenerator.ts +618 -0
- package/src/shared/relationshipExtractor.ts +214 -0
- package/src/shared/schemaGenerator.ts +644 -0
- package/src/shared/selectionDialogs.ts +749 -0
- package/src/storage/backupCompression.ts +88 -0
- package/src/storage/methods.ts +698 -0
- package/src/storage/schemas.ts +205 -0
- package/src/types/node-appwrite-tablesdb.d.ts +44 -0
- package/src/types.ts +9 -0
- package/src/users/methods.ts +359 -0
- package/src/utils/ClientFactory.ts +240 -0
- package/src/utils/configDiscovery.ts +557 -0
- package/src/utils/configMigration.ts +348 -0
- package/src/utils/constantsGenerator.ts +369 -0
- package/src/utils/dataConverters.ts +159 -0
- package/src/utils/directoryUtils.ts +61 -0
- package/src/utils/getClientFromConfig.ts +257 -0
- package/src/utils/helperFunctions.ts +228 -0
- package/src/utils/index.ts +2 -0
- package/src/utils/loadConfigs.ts +449 -0
- package/src/utils/pathResolvers.ts +81 -0
- package/src/utils/projectConfig.ts +299 -0
- package/src/utils/retryFailedPromises.ts +29 -0
- package/src/utils/sessionAuth.ts +230 -0
- package/src/utils/setupFiles.ts +1238 -0
- package/src/utils/typeGuards.ts +65 -0
- package/src/utils/validationRules.ts +88 -0
- package/src/utils/versionDetection.ts +292 -0
- package/src/utils/yamlConverter.ts +542 -0
- package/src/utils/yamlLoader.ts +371 -0
- package/src/utilsController.ts +1203 -0
- package/tests/README.md +497 -0
- package/tests/adapters/AdapterFactory.test.ts +277 -0
- package/tests/integration/syncOperations.test.ts +463 -0
- package/tests/jest.config.js +25 -0
- package/tests/migration/configMigration.test.ts +546 -0
- package/tests/setup.ts +62 -0
- package/tests/testUtils.ts +340 -0
- package/tests/utils/loadConfigs.test.ts +350 -0
- package/tests/validation/configValidation.test.ts +412 -0
- package/tsconfig.json +44 -0
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
import { promises as fs } from "fs";
|
|
2
|
+
import path from "path";
|
|
3
|
+
import { existsSync } from "fs";
|
|
4
|
+
import { MessageFormatter } from "../shared/messageFormatter.js";
|
|
5
|
+
import { ConfirmationDialogs } from "../shared/confirmationDialogs.js";
|
|
6
|
+
import yaml from "js-yaml";
|
|
7
|
+
export async function migrateConfig(workingDir) {
|
|
8
|
+
try {
|
|
9
|
+
// Look for appwriteConfig.ts files in the working directory and subdirectories
|
|
10
|
+
const configFiles = await findAppwriteConfigFiles(workingDir);
|
|
11
|
+
if (configFiles.length === 0) {
|
|
12
|
+
MessageFormatter.info("No appwriteConfig.ts files found to migrate", { prefix: "Migration" });
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
MessageFormatter.info(`Found ${configFiles.length} appwriteConfig.ts file(s) to migrate`, { prefix: "Migration" });
|
|
16
|
+
for (const configFile of configFiles) {
|
|
17
|
+
await migrateConfigFile(configFile, workingDir);
|
|
18
|
+
}
|
|
19
|
+
MessageFormatter.success("Migration completed successfully", { prefix: "Migration" });
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
MessageFormatter.error("Migration failed", error instanceof Error ? error : new Error(String(error)), { prefix: "Migration" });
|
|
23
|
+
throw error;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async function findAppwriteConfigFiles(dir) {
|
|
27
|
+
const configFiles = [];
|
|
28
|
+
const checkDir = async (currentDir) => {
|
|
29
|
+
try {
|
|
30
|
+
const entries = await fs.readdir(currentDir, { withFileTypes: true });
|
|
31
|
+
for (const entry of entries) {
|
|
32
|
+
const fullPath = path.join(currentDir, entry.name);
|
|
33
|
+
if (entry.isDirectory() && !entry.name.startsWith('.') && entry.name !== 'node_modules') {
|
|
34
|
+
await checkDir(fullPath);
|
|
35
|
+
}
|
|
36
|
+
else if (entry.isFile() && entry.name === 'appwriteConfig.ts') {
|
|
37
|
+
configFiles.push(fullPath);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
catch (error) {
|
|
42
|
+
// Ignore directory access errors
|
|
43
|
+
}
|
|
44
|
+
};
|
|
45
|
+
await checkDir(dir);
|
|
46
|
+
return configFiles;
|
|
47
|
+
}
|
|
48
|
+
async function migrateConfigFile(configFilePath, workingDir) {
|
|
49
|
+
const configDir = path.dirname(configFilePath);
|
|
50
|
+
const appwriteDir = path.join(path.dirname(configDir), '.appwrite');
|
|
51
|
+
MessageFormatter.info(`Migrating ${path.relative(workingDir, configFilePath)}`, { prefix: "Migration" });
|
|
52
|
+
// Check if .appwrite directory already exists
|
|
53
|
+
if (existsSync(appwriteDir)) {
|
|
54
|
+
const shouldOverwrite = await ConfirmationDialogs.confirmOverwrite(`.appwrite directory already exists at ${path.relative(workingDir, appwriteDir)}`);
|
|
55
|
+
if (!shouldOverwrite) {
|
|
56
|
+
MessageFormatter.info("Skipping migration for this config", { prefix: "Migration" });
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
// Load and parse the TypeScript config
|
|
61
|
+
const config = await parseTypeScriptConfig(configFilePath);
|
|
62
|
+
// Create .appwrite directory
|
|
63
|
+
await fs.mkdir(appwriteDir, { recursive: true });
|
|
64
|
+
// Convert config to YAML and save
|
|
65
|
+
const yamlConfig = convertToYAMLConfig(config);
|
|
66
|
+
const yamlContent = yaml.dump(yamlConfig, {
|
|
67
|
+
indent: 2,
|
|
68
|
+
lineWidth: 120,
|
|
69
|
+
noRefs: true
|
|
70
|
+
});
|
|
71
|
+
await fs.writeFile(path.join(appwriteDir, 'config.yaml'), yamlContent);
|
|
72
|
+
// Copy all directories except collections and schemas (we handle collections separately, skip schemas entirely)
|
|
73
|
+
const entries = await fs.readdir(configDir, { withFileTypes: true });
|
|
74
|
+
for (const entry of entries) {
|
|
75
|
+
if (entry.isDirectory() && entry.name !== 'collections' && entry.name !== 'schemas') {
|
|
76
|
+
const sourcePath = path.join(configDir, entry.name);
|
|
77
|
+
const targetPath = path.join(appwriteDir, entry.name);
|
|
78
|
+
await fs.cp(sourcePath, targetPath, { recursive: true });
|
|
79
|
+
MessageFormatter.info(`Copied ${entry.name}/ to .appwrite/${entry.name}/`, { prefix: "Migration" });
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
// Convert TypeScript collections to YAML collections
|
|
83
|
+
const collectionsPath = path.join(configDir, 'collections');
|
|
84
|
+
if (existsSync(collectionsPath)) {
|
|
85
|
+
const targetCollectionsPath = path.join(appwriteDir, 'collections');
|
|
86
|
+
await fs.mkdir(targetCollectionsPath, { recursive: true });
|
|
87
|
+
const collectionFiles = await fs.readdir(collectionsPath);
|
|
88
|
+
for (const file of collectionFiles) {
|
|
89
|
+
if (file.endsWith('.ts')) {
|
|
90
|
+
await convertCollectionToYaml(path.join(collectionsPath, file), targetCollectionsPath);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
MessageFormatter.info(`Converted TypeScript collections to YAML in .appwrite/collections/`, { prefix: "Migration" });
|
|
94
|
+
}
|
|
95
|
+
// Keep original config file in place (no backup needed since we're not deleting it)
|
|
96
|
+
MessageFormatter.success(`Migration completed for ${path.relative(workingDir, configFilePath)}`, { prefix: "Migration" });
|
|
97
|
+
}
|
|
98
|
+
async function parseTypeScriptConfig(configFilePath) {
|
|
99
|
+
try {
|
|
100
|
+
// Use tsx to import the TypeScript config file directly
|
|
101
|
+
const { register } = await import("tsx/esm/api");
|
|
102
|
+
const { pathToFileURL } = await import("node:url");
|
|
103
|
+
const unregister = register();
|
|
104
|
+
try {
|
|
105
|
+
const configUrl = pathToFileURL(configFilePath).href;
|
|
106
|
+
const configModule = await import(configUrl);
|
|
107
|
+
const config = configModule.default?.default || configModule.default || configModule;
|
|
108
|
+
if (!config) {
|
|
109
|
+
throw new Error("Failed to load config from TypeScript file");
|
|
110
|
+
}
|
|
111
|
+
return config;
|
|
112
|
+
}
|
|
113
|
+
finally {
|
|
114
|
+
unregister();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
catch (error) {
|
|
118
|
+
MessageFormatter.error("Could not load TypeScript config", error instanceof Error ? error : new Error(String(error)), { prefix: "Migration" });
|
|
119
|
+
throw new Error('Failed to load TypeScript configuration file. Please ensure it exports a valid config object.');
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
function convertToYAMLConfig(config) {
|
|
123
|
+
// Convert the config to the nested YAML structure
|
|
124
|
+
const yamlConfig = {
|
|
125
|
+
appwrite: {
|
|
126
|
+
endpoint: config.appwriteEndpoint,
|
|
127
|
+
project: config.appwriteProject,
|
|
128
|
+
key: config.appwriteKey
|
|
129
|
+
},
|
|
130
|
+
logging: {
|
|
131
|
+
enabled: config.logging?.enabled ?? false,
|
|
132
|
+
level: config.logging?.level ?? "info",
|
|
133
|
+
console: config.logging?.console ?? false,
|
|
134
|
+
logDirectory: "./logs"
|
|
135
|
+
},
|
|
136
|
+
backups: {
|
|
137
|
+
enabled: config.enableBackups ?? false,
|
|
138
|
+
interval: config.backupInterval ?? 3600,
|
|
139
|
+
retention: config.backupRetention ?? 30,
|
|
140
|
+
cleanup: config.enableBackupCleanup ?? false
|
|
141
|
+
},
|
|
142
|
+
data: {
|
|
143
|
+
enableMockData: config.enableMockData ?? false,
|
|
144
|
+
documentBucketId: config.documentBucketId ?? "documents",
|
|
145
|
+
usersCollectionName: config.usersCollectionName ?? "Users",
|
|
146
|
+
importDirectory: "importData"
|
|
147
|
+
},
|
|
148
|
+
schemas: {
|
|
149
|
+
outputDirectory: "schemas",
|
|
150
|
+
yamlSchemaDirectory: ".yaml_schemas"
|
|
151
|
+
},
|
|
152
|
+
migrations: {
|
|
153
|
+
enabled: true
|
|
154
|
+
},
|
|
155
|
+
databases: (config.databases || []).map(db => ({
|
|
156
|
+
id: db.$id,
|
|
157
|
+
name: db.name,
|
|
158
|
+
collections: [] // Collections will be handled separately
|
|
159
|
+
})),
|
|
160
|
+
buckets: (config.buckets || []).map(bucket => ({
|
|
161
|
+
id: bucket.$id,
|
|
162
|
+
name: bucket.name,
|
|
163
|
+
permissions: bucket.$permissions?.map((p) => ({
|
|
164
|
+
permission: p.permission,
|
|
165
|
+
target: p.target
|
|
166
|
+
})) || [],
|
|
167
|
+
fileSecurity: bucket.fileSecurity ?? false,
|
|
168
|
+
enabled: bucket.enabled ?? true,
|
|
169
|
+
maximumFileSize: bucket.maximumFileSize ?? 30000000,
|
|
170
|
+
allowedFileExtensions: bucket.allowedFileExtensions || [],
|
|
171
|
+
compression: bucket.compression || "gzip",
|
|
172
|
+
encryption: bucket.encryption ?? false,
|
|
173
|
+
antivirus: bucket.antivirus ?? false
|
|
174
|
+
})),
|
|
175
|
+
functions: (config.functions || []).map((func) => ({
|
|
176
|
+
id: func.$id,
|
|
177
|
+
name: func.name,
|
|
178
|
+
runtime: func.runtime,
|
|
179
|
+
execute: func.execute || [],
|
|
180
|
+
events: func.events || [],
|
|
181
|
+
schedule: func.schedule || "",
|
|
182
|
+
timeout: func.timeout ?? 15,
|
|
183
|
+
enabled: func.enabled ?? true,
|
|
184
|
+
logging: func.logging ?? false,
|
|
185
|
+
entrypoint: func.entrypoint || "src/main.js",
|
|
186
|
+
commands: func.commands || "",
|
|
187
|
+
scopes: func.scopes || [],
|
|
188
|
+
specification: func.specification || "s-1vcpu-512mb"
|
|
189
|
+
}))
|
|
190
|
+
};
|
|
191
|
+
return yamlConfig;
|
|
192
|
+
}
|
|
193
|
+
async function convertCollectionToYaml(tsFilePath, targetDir) {
|
|
194
|
+
try {
|
|
195
|
+
// Load the TypeScript collection using tsx
|
|
196
|
+
const { register } = await import("tsx/esm/api");
|
|
197
|
+
const { pathToFileURL } = await import("node:url");
|
|
198
|
+
const unregister = register();
|
|
199
|
+
try {
|
|
200
|
+
const configUrl = pathToFileURL(tsFilePath).href;
|
|
201
|
+
const collectionModule = await import(configUrl);
|
|
202
|
+
const collection = collectionModule.default?.default || collectionModule.default || collectionModule;
|
|
203
|
+
if (!collection) {
|
|
204
|
+
throw new Error("Failed to load collection from TypeScript file");
|
|
205
|
+
}
|
|
206
|
+
// Convert collection to YAML format
|
|
207
|
+
const yamlCollection = {
|
|
208
|
+
name: collection.name,
|
|
209
|
+
id: collection.$id,
|
|
210
|
+
documentSecurity: collection.documentSecurity ?? false,
|
|
211
|
+
enabled: collection.enabled ?? true,
|
|
212
|
+
permissions: (collection.permissions || collection.$permissions || []).map((p) => ({
|
|
213
|
+
permission: p.permission,
|
|
214
|
+
target: p.target
|
|
215
|
+
})),
|
|
216
|
+
attributes: (collection.attributes || []).map((attr) => ({
|
|
217
|
+
key: attr.key,
|
|
218
|
+
type: attr.type,
|
|
219
|
+
size: attr.size,
|
|
220
|
+
required: attr.required ?? false,
|
|
221
|
+
array: attr.array,
|
|
222
|
+
default: attr.xdefault || attr.default,
|
|
223
|
+
min: attr.min,
|
|
224
|
+
max: attr.max,
|
|
225
|
+
elements: attr.elements,
|
|
226
|
+
relatedCollection: attr.relatedCollection,
|
|
227
|
+
relationType: attr.relationType,
|
|
228
|
+
twoWay: attr.twoWay,
|
|
229
|
+
twoWayKey: attr.twoWayKey,
|
|
230
|
+
onDelete: attr.onDelete,
|
|
231
|
+
side: attr.side
|
|
232
|
+
})),
|
|
233
|
+
indexes: (collection.indexes || []).map((idx) => ({
|
|
234
|
+
key: idx.key,
|
|
235
|
+
type: idx.type,
|
|
236
|
+
attributes: idx.attributes,
|
|
237
|
+
orders: idx.orders
|
|
238
|
+
})),
|
|
239
|
+
importDefs: collection.importDefs || []
|
|
240
|
+
};
|
|
241
|
+
// Remove undefined values
|
|
242
|
+
const cleanYamlCollection = JSON.parse(JSON.stringify(yamlCollection, (key, value) => value === undefined ? undefined : value));
|
|
243
|
+
// Write YAML file
|
|
244
|
+
const fileName = path.basename(tsFilePath, '.ts') + '.yaml';
|
|
245
|
+
const targetPath = path.join(targetDir, fileName);
|
|
246
|
+
const yamlContent = yaml.dump(cleanYamlCollection, {
|
|
247
|
+
indent: 2,
|
|
248
|
+
lineWidth: 120,
|
|
249
|
+
noRefs: true
|
|
250
|
+
});
|
|
251
|
+
await fs.writeFile(targetPath, yamlContent);
|
|
252
|
+
MessageFormatter.info(`Converted ${path.basename(tsFilePath)} to ${fileName}`, { prefix: "Migration" });
|
|
253
|
+
}
|
|
254
|
+
finally {
|
|
255
|
+
unregister();
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
catch (error) {
|
|
259
|
+
MessageFormatter.error(`Failed to convert collection ${path.basename(tsFilePath)}`, error instanceof Error ? error : new Error(String(error)), { prefix: "Migration" });
|
|
260
|
+
}
|
|
261
|
+
}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { type AppwriteConfig } from "@njdamstra/appwrite-utils";
|
|
2
|
+
export type SupportedLanguage = "typescript" | "javascript" | "python" | "php" | "dart" | "json" | "env";
|
|
3
|
+
interface Constants {
|
|
4
|
+
databases: Record<string, string>;
|
|
5
|
+
collections: Record<string, string>;
|
|
6
|
+
buckets: Record<string, string>;
|
|
7
|
+
functions: Record<string, string>;
|
|
8
|
+
}
|
|
9
|
+
export declare class ConstantsGenerator {
|
|
10
|
+
private config;
|
|
11
|
+
private constants;
|
|
12
|
+
constructor(config: AppwriteConfig);
|
|
13
|
+
private extractConstants;
|
|
14
|
+
private toConstantName;
|
|
15
|
+
private toCamelCase;
|
|
16
|
+
private toSnakeCase;
|
|
17
|
+
generateTypeScript(constantsOverride?: Constants): string;
|
|
18
|
+
generateJavaScript(constantsOverride?: Constants): string;
|
|
19
|
+
generatePython(constantsOverride?: Constants): string;
|
|
20
|
+
generatePHP(constantsOverride?: Constants): string;
|
|
21
|
+
generateDart(constantsOverride?: Constants): string;
|
|
22
|
+
generateJSON(constantsOverride?: Constants): string;
|
|
23
|
+
generateEnv(constantsOverride?: Constants): string;
|
|
24
|
+
generateFiles(languages: SupportedLanguage[], outputDir: string, include?: {
|
|
25
|
+
databases?: boolean;
|
|
26
|
+
collections?: boolean;
|
|
27
|
+
buckets?: boolean;
|
|
28
|
+
functions?: boolean;
|
|
29
|
+
}): Promise<void>;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
@@ -0,0 +1,321 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
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;
|