@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,86 @@
|
|
|
1
|
+
import type { Attribute } from "@njdamstra/appwrite-utils";
|
|
2
|
+
interface ColumnPropertyChange {
|
|
3
|
+
property: string;
|
|
4
|
+
oldValue: any;
|
|
5
|
+
newValue: any;
|
|
6
|
+
requiresRecreate: boolean;
|
|
7
|
+
}
|
|
8
|
+
interface ColumnOperationPlan {
|
|
9
|
+
toCreate: Attribute[];
|
|
10
|
+
toUpdate: Array<{
|
|
11
|
+
attribute: Attribute;
|
|
12
|
+
changes: ColumnPropertyChange[];
|
|
13
|
+
}>;
|
|
14
|
+
toRecreate: Array<{
|
|
15
|
+
oldAttribute: any;
|
|
16
|
+
newAttribute: Attribute;
|
|
17
|
+
}>;
|
|
18
|
+
toDelete: Array<{
|
|
19
|
+
attribute: any;
|
|
20
|
+
}>;
|
|
21
|
+
unchanged: string[];
|
|
22
|
+
}
|
|
23
|
+
type ComparableColumn = {
|
|
24
|
+
key: string;
|
|
25
|
+
type: string;
|
|
26
|
+
required?: boolean;
|
|
27
|
+
array?: boolean;
|
|
28
|
+
default?: any;
|
|
29
|
+
size?: number;
|
|
30
|
+
min?: number;
|
|
31
|
+
max?: number;
|
|
32
|
+
elements?: string[];
|
|
33
|
+
encrypt?: boolean;
|
|
34
|
+
relatedCollection?: string;
|
|
35
|
+
relationType?: string;
|
|
36
|
+
twoWay?: boolean;
|
|
37
|
+
twoWayKey?: string;
|
|
38
|
+
onDelete?: string;
|
|
39
|
+
side?: string;
|
|
40
|
+
};
|
|
41
|
+
export declare function normalizeAttributeToComparable(attr: Attribute): ComparableColumn;
|
|
42
|
+
export declare function normalizeColumnToComparable(col: any): ComparableColumn;
|
|
43
|
+
export declare function isColumnEqualToColumn(a: any, b: any): boolean;
|
|
44
|
+
export declare function isIndexEqualToIndex(a: any, b: any): boolean;
|
|
45
|
+
/**
|
|
46
|
+
* Enhanced version of columns diff with detailed change analysis
|
|
47
|
+
* Order: desired first, then existing (matches internal usage here)
|
|
48
|
+
*/
|
|
49
|
+
export declare function diffColumnsDetailed(desiredAttributes: Attribute[], existingColumns: any[]): ColumnOperationPlan;
|
|
50
|
+
/**
|
|
51
|
+
* Returns true if there is any difference between existing columns and desired attributes
|
|
52
|
+
*/
|
|
53
|
+
export declare function areTableColumnsDiff(existingColumns: any[], desired: Attribute[]): boolean;
|
|
54
|
+
export declare function diffTableColumns(existingColumns: any[], desired: Attribute[]): {
|
|
55
|
+
toCreate: Attribute[];
|
|
56
|
+
toUpdate: Attribute[];
|
|
57
|
+
unchanged: string[];
|
|
58
|
+
};
|
|
59
|
+
/**
|
|
60
|
+
* Execute the column operation plan using the adapter
|
|
61
|
+
*/
|
|
62
|
+
export declare function executeColumnOperations(adapter: any, databaseId: string, tableId: string, plan: ColumnOperationPlan): Promise<{
|
|
63
|
+
success: string[];
|
|
64
|
+
errors: Array<{
|
|
65
|
+
column: string;
|
|
66
|
+
error: string;
|
|
67
|
+
}>;
|
|
68
|
+
}>;
|
|
69
|
+
/**
|
|
70
|
+
* Integration function for methods.ts - processes columns using enhanced logic
|
|
71
|
+
*/
|
|
72
|
+
export declare function processTableColumns(adapter: any, databaseId: string, tableId: string, desiredAttributes: Attribute[], existingColumns?: any[]): Promise<{
|
|
73
|
+
totalProcessed: number;
|
|
74
|
+
success: string[];
|
|
75
|
+
errors: Array<{
|
|
76
|
+
column: string;
|
|
77
|
+
error: string;
|
|
78
|
+
}>;
|
|
79
|
+
summary: {
|
|
80
|
+
created: number;
|
|
81
|
+
updated: number;
|
|
82
|
+
recreated: number;
|
|
83
|
+
unchanged: number;
|
|
84
|
+
};
|
|
85
|
+
}>;
|
|
86
|
+
export {};
|
|
@@ -0,0 +1,434 @@
|
|
|
1
|
+
import { mapToCreateAttributeParams, mapToUpdateAttributeParams } from "../shared/attributeMapper.js";
|
|
2
|
+
import { Decimal } from "decimal.js";
|
|
3
|
+
const EXTREME_BOUND = new Decimal('1e12');
|
|
4
|
+
// Property configuration for different column types
|
|
5
|
+
const MUTABLE_PROPERTIES = {
|
|
6
|
+
string: ["required", "default", "size", "array"],
|
|
7
|
+
integer: ["required", "default", "min", "max", "array"],
|
|
8
|
+
float: ["required", "default", "min", "max", "array"],
|
|
9
|
+
double: ["required", "default", "min", "max", "array"],
|
|
10
|
+
boolean: ["required", "default", "array"],
|
|
11
|
+
datetime: ["required", "default", "array"],
|
|
12
|
+
email: ["required", "default", "array"],
|
|
13
|
+
ip: ["required", "default", "array"],
|
|
14
|
+
url: ["required", "default", "array"],
|
|
15
|
+
enum: ["required", "default", "elements", "array"],
|
|
16
|
+
relationship: ["required", "default"],
|
|
17
|
+
};
|
|
18
|
+
const IMMUTABLE_PROPERTIES = {
|
|
19
|
+
string: ["encrypt", "key"],
|
|
20
|
+
integer: ["encrypt", "key"],
|
|
21
|
+
float: ["encrypt", "key"],
|
|
22
|
+
double: ["encrypt", "key"],
|
|
23
|
+
boolean: ["key"],
|
|
24
|
+
datetime: ["key"],
|
|
25
|
+
email: ["key"],
|
|
26
|
+
ip: ["key"],
|
|
27
|
+
url: ["key"],
|
|
28
|
+
enum: ["key"],
|
|
29
|
+
relationship: ["key", "relatedCollection", "relationType", "twoWay", "twoWayKey", "onDelete"],
|
|
30
|
+
};
|
|
31
|
+
const TYPE_CHANGE_REQUIRES_RECREATE = [
|
|
32
|
+
"string",
|
|
33
|
+
"integer",
|
|
34
|
+
"float",
|
|
35
|
+
"double",
|
|
36
|
+
"boolean",
|
|
37
|
+
"datetime",
|
|
38
|
+
"email",
|
|
39
|
+
"ip",
|
|
40
|
+
"url",
|
|
41
|
+
"enum",
|
|
42
|
+
"relationship",
|
|
43
|
+
];
|
|
44
|
+
function normDefault(val) {
|
|
45
|
+
// Treat undefined and null as equal unset default
|
|
46
|
+
return val === undefined ? null : val;
|
|
47
|
+
}
|
|
48
|
+
function toNumber(n) {
|
|
49
|
+
if (n === null || n === undefined)
|
|
50
|
+
return undefined;
|
|
51
|
+
const num = Number(n);
|
|
52
|
+
return Number.isFinite(num) ? num : undefined;
|
|
53
|
+
}
|
|
54
|
+
export function normalizeAttributeToComparable(attr) {
|
|
55
|
+
const t = String(attr.type || '').toLowerCase();
|
|
56
|
+
const base = {
|
|
57
|
+
key: attr.key,
|
|
58
|
+
type: t,
|
|
59
|
+
required: !!attr.required,
|
|
60
|
+
array: !!attr.array,
|
|
61
|
+
default: normDefault(attr.xdefault),
|
|
62
|
+
};
|
|
63
|
+
if (t === 'string') {
|
|
64
|
+
base.size = attr.size ?? 255;
|
|
65
|
+
base.encrypt = !!(attr.encrypt);
|
|
66
|
+
}
|
|
67
|
+
if (t === 'integer' || t === 'float' || t === 'double') {
|
|
68
|
+
const min = toNumber(attr.min);
|
|
69
|
+
const max = toNumber(attr.max);
|
|
70
|
+
if (min !== undefined && max !== undefined) {
|
|
71
|
+
base.min = Math.min(min, max);
|
|
72
|
+
base.max = Math.max(min, max);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
base.min = min;
|
|
76
|
+
base.max = max;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
if (t === 'enum') {
|
|
80
|
+
base.elements = Array.isArray(attr.elements) ? attr.elements.slice().sort() : [];
|
|
81
|
+
}
|
|
82
|
+
if (t === 'relationship') {
|
|
83
|
+
base.relatedCollection = attr.relatedCollection;
|
|
84
|
+
base.relationType = attr.relationType;
|
|
85
|
+
base.twoWay = !!attr.twoWay;
|
|
86
|
+
base.twoWayKey = attr.twoWayKey;
|
|
87
|
+
base.onDelete = attr.onDelete;
|
|
88
|
+
base.side = attr.side;
|
|
89
|
+
}
|
|
90
|
+
return base;
|
|
91
|
+
}
|
|
92
|
+
export function normalizeColumnToComparable(col) {
|
|
93
|
+
// Detect enum surfaced as string+elements from server and normalize to enum for comparison
|
|
94
|
+
let t = String((col?.type ?? col?.columnType ?? '')).toLowerCase();
|
|
95
|
+
const hasElements = Array.isArray(col?.elements) && col.elements.length > 0;
|
|
96
|
+
if (t === 'string' && hasElements)
|
|
97
|
+
t = 'enum';
|
|
98
|
+
const base = {
|
|
99
|
+
key: col?.key,
|
|
100
|
+
type: t,
|
|
101
|
+
required: !!col?.required,
|
|
102
|
+
array: !!col?.array,
|
|
103
|
+
default: normDefault(col?.default ?? col?.xdefault),
|
|
104
|
+
};
|
|
105
|
+
if (t === 'string') {
|
|
106
|
+
base.size = typeof col?.size === 'number' ? col.size : undefined;
|
|
107
|
+
base.encrypt = !!col?.encrypt;
|
|
108
|
+
}
|
|
109
|
+
if (t === 'integer' || t === 'float' || t === 'double') {
|
|
110
|
+
// Preserve raw min/max without forcing extremes; compare with Decimal in shallowEqual
|
|
111
|
+
const rawMin = col?.min;
|
|
112
|
+
const rawMax = col?.max;
|
|
113
|
+
base.min = rawMin;
|
|
114
|
+
base.max = rawMax;
|
|
115
|
+
}
|
|
116
|
+
if (t === 'enum') {
|
|
117
|
+
base.elements = Array.isArray(col?.elements) ? col.elements.slice().sort() : [];
|
|
118
|
+
}
|
|
119
|
+
if (t === 'relationship') {
|
|
120
|
+
base.relatedCollection = col?.relatedTableId || col?.relatedCollection;
|
|
121
|
+
base.relationType = col?.relationType || col?.typeName;
|
|
122
|
+
base.twoWay = !!col?.twoWay;
|
|
123
|
+
base.twoWayKey = col?.twoWayKey;
|
|
124
|
+
base.onDelete = col?.onDelete;
|
|
125
|
+
base.side = col?.side;
|
|
126
|
+
}
|
|
127
|
+
return base;
|
|
128
|
+
}
|
|
129
|
+
function shallowEqual(a, b) {
|
|
130
|
+
const keys = new Set([...Object.keys(a), ...Object.keys(b)]);
|
|
131
|
+
for (const k of keys) {
|
|
132
|
+
const va = a[k];
|
|
133
|
+
const vb = b[k];
|
|
134
|
+
if (Array.isArray(va) && Array.isArray(vb)) {
|
|
135
|
+
if (va.length !== vb.length)
|
|
136
|
+
return false;
|
|
137
|
+
for (let i = 0; i < va.length; i++)
|
|
138
|
+
if (va[i] !== vb[i])
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
else if (k === 'min' || k === 'max') {
|
|
142
|
+
// Compare numeric bounds with Decimal to avoid precision issues
|
|
143
|
+
if (va == null && vb == null)
|
|
144
|
+
continue;
|
|
145
|
+
if (va == null || vb == null) {
|
|
146
|
+
// Treat extreme bounds on one side as equivalent to undefined (unbounded)
|
|
147
|
+
const present = va == null ? vb : va;
|
|
148
|
+
try {
|
|
149
|
+
const dp = new Decimal(String(present));
|
|
150
|
+
if (dp.abs().greaterThanOrEqualTo(EXTREME_BOUND))
|
|
151
|
+
continue; // equal
|
|
152
|
+
}
|
|
153
|
+
catch { }
|
|
154
|
+
return false;
|
|
155
|
+
}
|
|
156
|
+
try {
|
|
157
|
+
const da = new Decimal(String(va));
|
|
158
|
+
const db = new Decimal(String(vb));
|
|
159
|
+
if (!da.equals(db))
|
|
160
|
+
return false;
|
|
161
|
+
}
|
|
162
|
+
catch {
|
|
163
|
+
if (va !== vb)
|
|
164
|
+
return false;
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
else if (va !== vb) {
|
|
168
|
+
// Treat null and undefined as equal for defaults
|
|
169
|
+
if (!(va == null && vb == null))
|
|
170
|
+
return false;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
return true;
|
|
174
|
+
}
|
|
175
|
+
export function isColumnEqualToColumn(a, b) {
|
|
176
|
+
const na = normalizeColumnToComparable(a);
|
|
177
|
+
const nb = normalizeColumnToComparable(b);
|
|
178
|
+
return shallowEqual(na, nb);
|
|
179
|
+
}
|
|
180
|
+
export function isIndexEqualToIndex(a, b) {
|
|
181
|
+
if (!a || !b)
|
|
182
|
+
return false;
|
|
183
|
+
if (a.key !== b.key)
|
|
184
|
+
return false;
|
|
185
|
+
if (String(a.type).toLowerCase() !== String(b.type).toLowerCase())
|
|
186
|
+
return false;
|
|
187
|
+
// Compare attributes as sets (order-insensitive)
|
|
188
|
+
const attrsA = Array.isArray(a.attributes) ? [...a.attributes].sort() : [];
|
|
189
|
+
const attrsB = Array.isArray(b.attributes) ? [...b.attributes].sort() : [];
|
|
190
|
+
if (attrsA.length !== attrsB.length)
|
|
191
|
+
return false;
|
|
192
|
+
for (let i = 0; i < attrsA.length; i++)
|
|
193
|
+
if (attrsA[i] !== attrsB[i])
|
|
194
|
+
return false;
|
|
195
|
+
// Orders are only considered if BOTH have orders defined
|
|
196
|
+
const hasOrdersA = Array.isArray(a.orders) && a.orders.length > 0;
|
|
197
|
+
const hasOrdersB = Array.isArray(b.orders) && b.orders.length > 0;
|
|
198
|
+
if (hasOrdersA && hasOrdersB) {
|
|
199
|
+
const ordersA = [...a.orders].sort();
|
|
200
|
+
const ordersB = [...b.orders].sort();
|
|
201
|
+
if (ordersA.length !== ordersB.length)
|
|
202
|
+
return false;
|
|
203
|
+
for (let i = 0; i < ordersA.length; i++)
|
|
204
|
+
if (ordersA[i] !== ordersB[i])
|
|
205
|
+
return false;
|
|
206
|
+
}
|
|
207
|
+
// If only one side has orders, treat as equal (orders unspecified by user)
|
|
208
|
+
return true;
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Compare individual properties between old and new columns
|
|
212
|
+
*/
|
|
213
|
+
function compareColumnProperties(oldColumn, newAttribute, columnType) {
|
|
214
|
+
const changes = [];
|
|
215
|
+
const t = String(columnType || newAttribute.type || '').toLowerCase();
|
|
216
|
+
const mutableProps = MUTABLE_PROPERTIES[t] || [];
|
|
217
|
+
const immutableProps = IMMUTABLE_PROPERTIES[t] || [];
|
|
218
|
+
const getNewVal = (prop) => {
|
|
219
|
+
const na = newAttribute;
|
|
220
|
+
if (prop === 'default')
|
|
221
|
+
return na.xdefault;
|
|
222
|
+
if (prop === 'encrypt')
|
|
223
|
+
return na.encrypt;
|
|
224
|
+
return na[prop];
|
|
225
|
+
};
|
|
226
|
+
const getOldVal = (prop) => {
|
|
227
|
+
if (prop === 'default')
|
|
228
|
+
return oldColumn?.default ?? oldColumn?.xdefault;
|
|
229
|
+
return oldColumn?.[prop];
|
|
230
|
+
};
|
|
231
|
+
for (const prop of mutableProps) {
|
|
232
|
+
const oldValue = getOldVal(prop);
|
|
233
|
+
let newValue = getNewVal(prop);
|
|
234
|
+
// Special-case: enum elements empty/missing should not trigger updates
|
|
235
|
+
if (t === 'enum' && prop === 'elements') {
|
|
236
|
+
if (!Array.isArray(newValue) || newValue.length === 0)
|
|
237
|
+
newValue = oldValue;
|
|
238
|
+
}
|
|
239
|
+
if (Array.isArray(oldValue) && Array.isArray(newValue)) {
|
|
240
|
+
if (oldValue.length !== newValue.length || oldValue.some((v, i) => v !== newValue[i])) {
|
|
241
|
+
changes.push({ property: prop, oldValue, newValue, requiresRecreate: false });
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
else if (oldValue !== newValue) {
|
|
245
|
+
changes.push({ property: prop, oldValue, newValue, requiresRecreate: false });
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
for (const prop of immutableProps) {
|
|
249
|
+
const oldValue = getOldVal(prop);
|
|
250
|
+
const newValue = getNewVal(prop);
|
|
251
|
+
if (Array.isArray(oldValue) && Array.isArray(newValue)) {
|
|
252
|
+
if (oldValue.length !== newValue.length || oldValue.some((v, i) => v !== newValue[i])) {
|
|
253
|
+
changes.push({ property: prop, oldValue, newValue, requiresRecreate: true });
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
else if (oldValue !== newValue) {
|
|
257
|
+
changes.push({ property: prop, oldValue, newValue, requiresRecreate: true });
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
// Type change requires recreate (normalize string+elements to enum on old side)
|
|
261
|
+
const oldTypeRaw = String(oldColumn?.type || oldColumn?.columnType || '').toLowerCase();
|
|
262
|
+
const oldHasElements = Array.isArray(oldColumn?.elements) && oldColumn.elements.length > 0;
|
|
263
|
+
const oldType = oldTypeRaw === 'string' && oldHasElements ? 'enum' : oldTypeRaw;
|
|
264
|
+
if (oldType && t && oldType !== t && TYPE_CHANGE_REQUIRES_RECREATE.includes(oldType)) {
|
|
265
|
+
changes.push({ property: 'type', oldValue: oldType, newValue: t, requiresRecreate: true });
|
|
266
|
+
}
|
|
267
|
+
return changes;
|
|
268
|
+
}
|
|
269
|
+
/**
|
|
270
|
+
* Analyze what changes are needed for a specific column
|
|
271
|
+
*/
|
|
272
|
+
function analyzeColumnChanges(oldColumn, newAttribute) {
|
|
273
|
+
const columnType = String(newAttribute.type || 'string').toLowerCase();
|
|
274
|
+
const columnKey = newAttribute.key;
|
|
275
|
+
// Use normalized comparison to reduce false positives then property-wise details
|
|
276
|
+
const normalizedOld = normalizeColumnToComparable(oldColumn);
|
|
277
|
+
const normalizedNew = normalizeAttributeToComparable(newAttribute);
|
|
278
|
+
const hasAnyDiff = !shallowEqual(normalizedOld, normalizedNew);
|
|
279
|
+
const changes = hasAnyDiff ? compareColumnProperties(oldColumn, newAttribute, columnType) : [];
|
|
280
|
+
const requiresRecreate = changes.some((c) => c.requiresRecreate);
|
|
281
|
+
const mutableChanges = {};
|
|
282
|
+
const immutableChanges = {};
|
|
283
|
+
for (const c of changes) {
|
|
284
|
+
if (c.requiresRecreate)
|
|
285
|
+
immutableChanges[c.property] = { old: c.oldValue, new: c.newValue };
|
|
286
|
+
else
|
|
287
|
+
mutableChanges[c.property] = { old: c.oldValue, new: c.newValue };
|
|
288
|
+
}
|
|
289
|
+
return {
|
|
290
|
+
columnKey,
|
|
291
|
+
columnType,
|
|
292
|
+
hasChanges: changes.length > 0,
|
|
293
|
+
requiresRecreate,
|
|
294
|
+
changes,
|
|
295
|
+
mutableChanges,
|
|
296
|
+
immutableChanges,
|
|
297
|
+
};
|
|
298
|
+
}
|
|
299
|
+
/**
|
|
300
|
+
* Enhanced version of columns diff with detailed change analysis
|
|
301
|
+
* Order: desired first, then existing (matches internal usage here)
|
|
302
|
+
*/
|
|
303
|
+
export function diffColumnsDetailed(desiredAttributes, existingColumns) {
|
|
304
|
+
const byKey = new Map((existingColumns || []).map((col) => [col?.key, col]));
|
|
305
|
+
const toCreate = [];
|
|
306
|
+
const toUpdate = [];
|
|
307
|
+
const toRecreate = [];
|
|
308
|
+
const unchanged = [];
|
|
309
|
+
for (const attr of desiredAttributes || []) {
|
|
310
|
+
const key = attr?.key;
|
|
311
|
+
const existing = key ? byKey.get(key) : undefined;
|
|
312
|
+
if (!existing) {
|
|
313
|
+
toCreate.push(attr);
|
|
314
|
+
continue;
|
|
315
|
+
}
|
|
316
|
+
const analysis = analyzeColumnChanges(existing, attr);
|
|
317
|
+
if (!analysis.hasChanges)
|
|
318
|
+
unchanged.push(analysis.columnKey);
|
|
319
|
+
else if (analysis.requiresRecreate)
|
|
320
|
+
toRecreate.push({ oldAttribute: existing, newAttribute: attr });
|
|
321
|
+
else
|
|
322
|
+
toUpdate.push({ attribute: attr, changes: analysis.changes });
|
|
323
|
+
}
|
|
324
|
+
// Note: we keep toDelete empty for now (conservative behavior)
|
|
325
|
+
return { toCreate, toUpdate, toRecreate, toDelete: [], unchanged };
|
|
326
|
+
}
|
|
327
|
+
/**
|
|
328
|
+
* Returns true if there is any difference between existing columns and desired attributes
|
|
329
|
+
*/
|
|
330
|
+
export function areTableColumnsDiff(existingColumns, desired) {
|
|
331
|
+
const byKey = new Map();
|
|
332
|
+
for (const c of existingColumns || []) {
|
|
333
|
+
if (c?.key)
|
|
334
|
+
byKey.set(c.key, c);
|
|
335
|
+
}
|
|
336
|
+
for (const attr of desired || []) {
|
|
337
|
+
const desiredNorm = normalizeAttributeToComparable(attr);
|
|
338
|
+
const existing = byKey.get(desiredNorm.key);
|
|
339
|
+
if (!existing)
|
|
340
|
+
return true;
|
|
341
|
+
const existingNorm = normalizeColumnToComparable(existing);
|
|
342
|
+
if (!shallowEqual(desiredNorm, existingNorm))
|
|
343
|
+
return true;
|
|
344
|
+
}
|
|
345
|
+
// Extra columns on remote also constitute a diff
|
|
346
|
+
const desiredKeys = new Set((desired || []).map((a) => a.key));
|
|
347
|
+
for (const k of byKey.keys())
|
|
348
|
+
if (!desiredKeys.has(k))
|
|
349
|
+
return true;
|
|
350
|
+
return false;
|
|
351
|
+
}
|
|
352
|
+
export function diffTableColumns(existingColumns, desired) {
|
|
353
|
+
// Use detailed plan but return legacy structure for compatibility
|
|
354
|
+
const plan = diffColumnsDetailed(desired, existingColumns);
|
|
355
|
+
const toUpdate = [
|
|
356
|
+
...plan.toUpdate.map((u) => u.attribute),
|
|
357
|
+
...plan.toRecreate.map((r) => r.newAttribute),
|
|
358
|
+
];
|
|
359
|
+
return { toCreate: plan.toCreate, toUpdate, unchanged: plan.unchanged };
|
|
360
|
+
}
|
|
361
|
+
/**
|
|
362
|
+
* Execute the column operation plan using the adapter
|
|
363
|
+
*/
|
|
364
|
+
export async function executeColumnOperations(adapter, databaseId, tableId, plan) {
|
|
365
|
+
if (!databaseId || !tableId)
|
|
366
|
+
throw new Error('Database ID and Table ID are required for column operations');
|
|
367
|
+
if (!adapter || typeof adapter.createAttribute !== 'function')
|
|
368
|
+
throw new Error('Valid adapter is required for column operations');
|
|
369
|
+
const results = { success: [], errors: [] };
|
|
370
|
+
const exec = async (fn, key, op) => {
|
|
371
|
+
try {
|
|
372
|
+
await fn();
|
|
373
|
+
results.success.push(`${op}: ${key}`);
|
|
374
|
+
}
|
|
375
|
+
catch (e) {
|
|
376
|
+
results.errors.push({ column: key, error: `${op} failed: ${e?.message || String(e)}` });
|
|
377
|
+
}
|
|
378
|
+
};
|
|
379
|
+
for (const attr of plan.toCreate) {
|
|
380
|
+
const params = mapToCreateAttributeParams(attr, { databaseId, tableId });
|
|
381
|
+
await exec(() => adapter.createAttribute(params), attr.key, 'CREATE');
|
|
382
|
+
}
|
|
383
|
+
for (const { attribute } of plan.toUpdate) {
|
|
384
|
+
const params = mapToUpdateAttributeParams(attribute, { databaseId, tableId });
|
|
385
|
+
await exec(() => adapter.updateAttribute(params), attribute.key, 'UPDATE');
|
|
386
|
+
}
|
|
387
|
+
for (const { oldAttribute, newAttribute } of plan.toRecreate) {
|
|
388
|
+
await exec(() => adapter.deleteAttribute({ databaseId, tableId, key: oldAttribute.key }), oldAttribute.key, 'DELETE (for recreate)');
|
|
389
|
+
// Wait until the attribute is actually removed (or no longer 'deleting') before recreating
|
|
390
|
+
try {
|
|
391
|
+
const start = Date.now();
|
|
392
|
+
const maxWaitMs = 60000; // 60s
|
|
393
|
+
while (Date.now() - start < maxWaitMs) {
|
|
394
|
+
try {
|
|
395
|
+
const tableRes = await adapter.getTable({ databaseId, tableId });
|
|
396
|
+
const cols = (tableRes?.data?.columns || tableRes?.data?.attributes || []);
|
|
397
|
+
const found = cols.find((c) => c.key === oldAttribute.key);
|
|
398
|
+
if (!found)
|
|
399
|
+
break; // fully removed
|
|
400
|
+
if (found.status && found.status !== 'deleting')
|
|
401
|
+
break; // no longer deleting (failed/stuck) -> stop waiting
|
|
402
|
+
}
|
|
403
|
+
catch { }
|
|
404
|
+
await new Promise((r) => setTimeout(r, 1500));
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
catch { }
|
|
408
|
+
const params = mapToCreateAttributeParams(newAttribute, { databaseId, tableId });
|
|
409
|
+
await exec(() => adapter.createAttribute(params), newAttribute.key, 'CREATE (after recreate)');
|
|
410
|
+
}
|
|
411
|
+
return results;
|
|
412
|
+
}
|
|
413
|
+
/**
|
|
414
|
+
* Integration function for methods.ts - processes columns using enhanced logic
|
|
415
|
+
*/
|
|
416
|
+
export async function processTableColumns(adapter, databaseId, tableId, desiredAttributes, existingColumns = []) {
|
|
417
|
+
if (!existingColumns || existingColumns.length === 0) {
|
|
418
|
+
const tableInfo = await adapter.getTable({ databaseId, tableId });
|
|
419
|
+
existingColumns = (tableInfo?.data?.columns || tableInfo?.data?.attributes || []);
|
|
420
|
+
}
|
|
421
|
+
const plan = diffColumnsDetailed(desiredAttributes, existingColumns);
|
|
422
|
+
const results = await executeColumnOperations(adapter, databaseId, tableId, plan);
|
|
423
|
+
return {
|
|
424
|
+
totalProcessed: plan.toCreate.length + plan.toUpdate.length + plan.toRecreate.length,
|
|
425
|
+
success: results.success,
|
|
426
|
+
errors: results.errors,
|
|
427
|
+
summary: {
|
|
428
|
+
created: plan.toCreate.length,
|
|
429
|
+
updated: plan.toUpdate.length,
|
|
430
|
+
recreated: plan.toRecreate.length,
|
|
431
|
+
unchanged: plan.unchanged.length,
|
|
432
|
+
},
|
|
433
|
+
};
|
|
434
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Databases } from "node-appwrite";
|
|
2
|
+
import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
|
|
3
|
+
/**
|
|
4
|
+
* Transfers all documents from one collection to another in a different database
|
|
5
|
+
* within the same Appwrite Project
|
|
6
|
+
*/
|
|
7
|
+
export declare const transferDocumentsBetweenDbsLocalToLocal: (db: Databases | DatabaseAdapter, fromDbId: string, toDbId: string, fromCollId: string, toCollId: string) => Promise<void>;
|
|
8
|
+
export declare const transferDocumentsBetweenDbsLocalToRemote: (localDb: Databases | DatabaseAdapter, endpoint: string, projectId: string, apiKey: string, fromDbId: string, toDbId: string, fromCollId: string, toCollId: string) => Promise<void>;
|