@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,149 @@
|
|
|
1
|
+
import winston from "winston";
|
|
2
|
+
import fs from "fs";
|
|
3
|
+
import path from "path";
|
|
4
|
+
|
|
5
|
+
export interface LoggingConfig {
|
|
6
|
+
enabled: boolean;
|
|
7
|
+
level: string;
|
|
8
|
+
logDirectory?: string;
|
|
9
|
+
console: boolean;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Predefined logging configurations for common debugging scenarios
|
|
14
|
+
*/
|
|
15
|
+
export const LOGGING_PRESETS = {
|
|
16
|
+
/** Minimal logging - errors only to console */
|
|
17
|
+
minimal: {
|
|
18
|
+
enabled: false,
|
|
19
|
+
level: 'error',
|
|
20
|
+
console: true
|
|
21
|
+
},
|
|
22
|
+
/** Standard logging - info level to file and console */
|
|
23
|
+
standard: {
|
|
24
|
+
enabled: true,
|
|
25
|
+
level: 'info',
|
|
26
|
+
console: true
|
|
27
|
+
},
|
|
28
|
+
/** Debug logging - verbose debug output for troubleshooting */
|
|
29
|
+
debug: {
|
|
30
|
+
enabled: true,
|
|
31
|
+
level: 'debug',
|
|
32
|
+
console: true
|
|
33
|
+
},
|
|
34
|
+
/** Silent - no logging output */
|
|
35
|
+
silent: {
|
|
36
|
+
enabled: false,
|
|
37
|
+
level: 'error',
|
|
38
|
+
console: false
|
|
39
|
+
}
|
|
40
|
+
} as const;
|
|
41
|
+
|
|
42
|
+
const DEFAULT_LOGGING_CONFIG: LoggingConfig = {
|
|
43
|
+
enabled: false,
|
|
44
|
+
level: "info",
|
|
45
|
+
console: false,
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
let loggingConfig: LoggingConfig = DEFAULT_LOGGING_CONFIG;
|
|
49
|
+
|
|
50
|
+
export const configureLogging = (config: Partial<LoggingConfig> = {}) => {
|
|
51
|
+
loggingConfig = { ...DEFAULT_LOGGING_CONFIG, ...config };
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Configure logging using a preset
|
|
56
|
+
*/
|
|
57
|
+
export const configureLoggingPreset = (preset: keyof typeof LOGGING_PRESETS, logDirectory?: string) => {
|
|
58
|
+
const presetConfig = LOGGING_PRESETS[preset];
|
|
59
|
+
configureLogging({
|
|
60
|
+
...presetConfig,
|
|
61
|
+
...(logDirectory && { logDirectory })
|
|
62
|
+
});
|
|
63
|
+
updateLogger();
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const createLogger = () => {
|
|
67
|
+
const transports: winston.transport[] = [];
|
|
68
|
+
|
|
69
|
+
// Add console transport if enabled
|
|
70
|
+
if (loggingConfig.console) {
|
|
71
|
+
transports.push(new winston.transports.Console({
|
|
72
|
+
format: winston.format.combine(
|
|
73
|
+
winston.format.colorize(),
|
|
74
|
+
winston.format.simple()
|
|
75
|
+
)
|
|
76
|
+
}));
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Add file transports if logging is enabled
|
|
80
|
+
if (loggingConfig.enabled) {
|
|
81
|
+
const logDir = loggingConfig.logDirectory || path.join(process.cwd(), "zlogs");
|
|
82
|
+
|
|
83
|
+
if (!fs.existsSync(logDir)) {
|
|
84
|
+
fs.mkdirSync(logDir, { recursive: true });
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
transports.push(
|
|
88
|
+
new winston.transports.File({
|
|
89
|
+
filename: path.join(logDir, "error.log"),
|
|
90
|
+
level: "error",
|
|
91
|
+
}),
|
|
92
|
+
new winston.transports.File({
|
|
93
|
+
filename: path.join(logDir, "combined.log"),
|
|
94
|
+
})
|
|
95
|
+
);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
return winston.createLogger({
|
|
99
|
+
level: loggingConfig.level,
|
|
100
|
+
format: winston.format.combine(
|
|
101
|
+
winston.format.timestamp(),
|
|
102
|
+
winston.format.errors({ stack: true }),
|
|
103
|
+
winston.format.json()
|
|
104
|
+
),
|
|
105
|
+
defaultMeta: { service: "@njdamstra/appwrite-utils-cli" },
|
|
106
|
+
transports,
|
|
107
|
+
silent: !loggingConfig.enabled && !loggingConfig.console,
|
|
108
|
+
});
|
|
109
|
+
};
|
|
110
|
+
|
|
111
|
+
export let logger = createLogger();
|
|
112
|
+
|
|
113
|
+
// Recreate logger when config changes
|
|
114
|
+
export const updateLogger = () => {
|
|
115
|
+
logger = createLogger();
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Enable debug logging for troubleshooting push process issues
|
|
120
|
+
* This is a convenience function for quickly enabling comprehensive logging
|
|
121
|
+
*/
|
|
122
|
+
export const enableDebugLogging = (logDirectory?: string) => {
|
|
123
|
+
configureLogging({
|
|
124
|
+
enabled: true,
|
|
125
|
+
level: 'debug',
|
|
126
|
+
console: true,
|
|
127
|
+
logDirectory
|
|
128
|
+
});
|
|
129
|
+
updateLogger();
|
|
130
|
+
logger.info('Debug logging enabled for push process troubleshooting', {
|
|
131
|
+
level: 'debug',
|
|
132
|
+
console: true,
|
|
133
|
+
logDirectory: logDirectory || 'zlogs',
|
|
134
|
+
operation: 'enableDebugLogging'
|
|
135
|
+
});
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
/**
|
|
139
|
+
* Disable logging (reset to default)
|
|
140
|
+
*/
|
|
141
|
+
export const disableLogging = () => {
|
|
142
|
+
configureLogging(DEFAULT_LOGGING_CONFIG);
|
|
143
|
+
updateLogger();
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Get current logging configuration
|
|
148
|
+
*/
|
|
149
|
+
export const getLoggingConfig = () => ({ ...loggingConfig });
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
import chalk from "chalk";
|
|
2
|
+
import { logger } from "./logging.js";
|
|
3
|
+
|
|
4
|
+
export interface MessageOptions {
|
|
5
|
+
prefix?: string;
|
|
6
|
+
skipLogging?: boolean;
|
|
7
|
+
logLevel?: "info" | "warn" | "error" | "debug";
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
export class MessageFormatter {
|
|
11
|
+
static success(message: string, options: MessageOptions = {}) {
|
|
12
|
+
const formatted = `${chalk.green("✅")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
13
|
+
console.log(formatted);
|
|
14
|
+
|
|
15
|
+
if (!options.skipLogging) {
|
|
16
|
+
logger.info(`SUCCESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
static error(message: string, error?: Error | string, options: MessageOptions = {}) {
|
|
21
|
+
const errorDetails = error instanceof Error ? error.message : error;
|
|
22
|
+
const formatted = `${chalk.red("❌")} ${options.prefix ? `${options.prefix}: ` : ""}${message}${errorDetails ? `\n ${chalk.gray(errorDetails)}` : ""}`;
|
|
23
|
+
console.error(formatted);
|
|
24
|
+
|
|
25
|
+
if (!options.skipLogging) {
|
|
26
|
+
logger.error(`ERROR: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, {
|
|
27
|
+
error: errorDetails,
|
|
28
|
+
stack: error instanceof Error ? error.stack : undefined,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
static warning(message: string, options: MessageOptions = {}) {
|
|
34
|
+
const formatted = `${chalk.yellow("⚠️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
35
|
+
console.log(formatted);
|
|
36
|
+
|
|
37
|
+
if (!options.skipLogging) {
|
|
38
|
+
logger.warn(`WARNING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
static info(message: string, options: MessageOptions = {}) {
|
|
43
|
+
const formatted = `${chalk.blue("ℹ️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
44
|
+
console.log(formatted);
|
|
45
|
+
|
|
46
|
+
if (!options.skipLogging) {
|
|
47
|
+
logger.info(`INFO: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
static step(step: number, total: number, message: string, options: MessageOptions = {}) {
|
|
52
|
+
const formatted = `${chalk.cyan(`[${step}/${total}]`)} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
53
|
+
console.log(formatted);
|
|
54
|
+
|
|
55
|
+
if (!options.skipLogging) {
|
|
56
|
+
logger.info(`STEP ${step}/${total}: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
static progress(message: string, options: MessageOptions = {}) {
|
|
61
|
+
const formatted = `${chalk.gray("⏳")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
62
|
+
console.log(formatted);
|
|
63
|
+
|
|
64
|
+
if (!options.skipLogging) {
|
|
65
|
+
logger.debug(`PROGRESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
static debug(message: string, data?: any, options: MessageOptions = {}) {
|
|
70
|
+
if (process.env.NODE_ENV === "development" || process.env.DEBUG) {
|
|
71
|
+
const formatted = `${chalk.magenta("🔍")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
72
|
+
console.log(formatted);
|
|
73
|
+
if (data) {
|
|
74
|
+
console.log(chalk.gray(JSON.stringify(data, null, 2)));
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (!options.skipLogging) {
|
|
79
|
+
logger.debug(`DEBUG: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, data);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
static processing(message: string, options: MessageOptions = {}) {
|
|
84
|
+
const formatted = `${chalk.cyan("⚙️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
|
|
85
|
+
console.log(formatted);
|
|
86
|
+
|
|
87
|
+
if (!options.skipLogging) {
|
|
88
|
+
logger.info(`PROCESSING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
static divider() {
|
|
93
|
+
console.log(chalk.gray("─".repeat(60)));
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
static banner(title: string, subtitle?: string) {
|
|
97
|
+
const divider = chalk.cyan("═".repeat(60));
|
|
98
|
+
console.log(`\n${divider}`);
|
|
99
|
+
console.log(chalk.cyan.bold(` ${title}`));
|
|
100
|
+
if (subtitle) {
|
|
101
|
+
console.log(chalk.gray(` ${subtitle}`));
|
|
102
|
+
}
|
|
103
|
+
console.log(`${divider}\n`);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
static section(title: string) {
|
|
107
|
+
console.log(`\n${chalk.bold.underline(title)}`);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
static list(items: string[], title?: string) {
|
|
111
|
+
if (title) {
|
|
112
|
+
console.log(chalk.bold(title));
|
|
113
|
+
}
|
|
114
|
+
items.forEach((item, index) => {
|
|
115
|
+
console.log(`${chalk.gray(` ${index + 1}.`)} ${item}`);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
static table(data: Record<string, string | number>[], headers?: string[]) {
|
|
120
|
+
if (data.length === 0) return;
|
|
121
|
+
|
|
122
|
+
const keys = headers || Object.keys(data[0]);
|
|
123
|
+
const maxWidths = keys.map(key =>
|
|
124
|
+
Math.max(
|
|
125
|
+
key.length,
|
|
126
|
+
...data.map(row => String(row[key]).length)
|
|
127
|
+
)
|
|
128
|
+
);
|
|
129
|
+
|
|
130
|
+
// Header
|
|
131
|
+
const headerRow = keys.map((key, i) =>
|
|
132
|
+
chalk.bold(key.padEnd(maxWidths[i]))
|
|
133
|
+
).join(" │ ");
|
|
134
|
+
console.log(`┌─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┐`);
|
|
135
|
+
console.log(`│ ${headerRow} │`);
|
|
136
|
+
console.log(`├─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┤`);
|
|
137
|
+
|
|
138
|
+
// Rows
|
|
139
|
+
data.forEach(row => {
|
|
140
|
+
const dataRow = keys.map((key, i) =>
|
|
141
|
+
String(row[key]).padEnd(maxWidths[i])
|
|
142
|
+
).join(" │ ");
|
|
143
|
+
console.log(`│ ${dataRow} │`);
|
|
144
|
+
});
|
|
145
|
+
console.log(`└─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┴─")}─┘`);
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
static operationSummary(title: string, stats: Record<string, string | number>, duration?: number) {
|
|
149
|
+
this.section(`${title} Summary`);
|
|
150
|
+
|
|
151
|
+
Object.entries(stats).forEach(([key, value]) => {
|
|
152
|
+
const formattedKey = key.replace(/([A-Z])/g, ' $1').replace(/^./, str => str.toUpperCase());
|
|
153
|
+
console.log(`${chalk.gray("●")} ${formattedKey}: ${chalk.cyan(String(value))}`);
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
if (duration) {
|
|
157
|
+
console.log(`${chalk.gray("●")} Duration: ${chalk.cyan(this.formatDuration(duration))}`);
|
|
158
|
+
}
|
|
159
|
+
console.log();
|
|
160
|
+
}
|
|
161
|
+
|
|
162
|
+
static formatBytes(bytes: number): string {
|
|
163
|
+
const units = ['B', 'KB', 'MB', 'GB', 'TB'];
|
|
164
|
+
let size = bytes;
|
|
165
|
+
let unitIndex = 0;
|
|
166
|
+
|
|
167
|
+
while (size >= 1024 && unitIndex < units.length - 1) {
|
|
168
|
+
size /= 1024;
|
|
169
|
+
unitIndex++;
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
return `${size.toFixed(1)} ${units[unitIndex]}`;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
static formatDuration(ms: number): string {
|
|
176
|
+
const seconds = Math.floor(ms / 1000);
|
|
177
|
+
const minutes = Math.floor(seconds / 60);
|
|
178
|
+
const hours = Math.floor(minutes / 60);
|
|
179
|
+
|
|
180
|
+
if (hours > 0) {
|
|
181
|
+
return `${hours}h ${minutes % 60}m ${seconds % 60}s`;
|
|
182
|
+
} else if (minutes > 0) {
|
|
183
|
+
return `${minutes}m ${seconds % 60}s`;
|
|
184
|
+
} else {
|
|
185
|
+
return `${seconds}s`;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
static formatNumber(num: number): string {
|
|
190
|
+
return num.toLocaleString();
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
export const Messages = {
|
|
195
|
+
CONFIG_NOT_FOUND: "Appwrite configuration not found. Run 'appwrite-migrate setup' first.",
|
|
196
|
+
CONFIG_LOADED: (type: string, path: string) => `Loaded ${type} configuration from ${path}`,
|
|
197
|
+
DATABASE_CONNECTION_FAILED: "Failed to connect to Appwrite. Check your endpoint and API key.",
|
|
198
|
+
OPERATION_CANCELLED: "Operation cancelled by user.",
|
|
199
|
+
OPERATION_COMPLETED: (operation: string) => `${operation} completed successfully`,
|
|
200
|
+
BACKUP_STARTED: (database: string) => `Starting backup for database: ${database}`,
|
|
201
|
+
BACKUP_COMPLETED: (database: string, size: number) => `Backup completed for ${database} (${MessageFormatter.formatBytes(size)})`,
|
|
202
|
+
IMPORT_STARTED: (collections: number) => `Starting import process for ${collections} collection(s)`,
|
|
203
|
+
IMPORT_COMPLETED: (documents: number) => `Import completed. Processed ${MessageFormatter.formatNumber(documents)} documents`,
|
|
204
|
+
FUNCTION_DEPLOYED: (name: string) => `Function '${name}' deployed successfully`,
|
|
205
|
+
FUNCTION_DEPLOYMENT_FAILED: (name: string, error: string) => `Function '${name}' deployment failed: ${error}`,
|
|
206
|
+
TRANSFER_STARTED: (source: string, target: string) => `Starting transfer from ${source} to ${target}`,
|
|
207
|
+
TRANSFER_COMPLETED: (items: number) => `Transfer completed. Moved ${MessageFormatter.formatNumber(items)} items`,
|
|
208
|
+
} as const;
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { ID, Query, type Databases } from "node-appwrite";
|
|
2
|
+
import { BatchSchema, OperationSchema, type Operation } from "../storage/schemas.js";
|
|
3
|
+
import { AttributeMappingsSchema } from "@njdamstra/appwrite-utils";
|
|
4
|
+
import { z } from "zod";
|
|
5
|
+
import { logger } from "./logging.js";
|
|
6
|
+
import { tryAwaitWithRetry } from "../utils/helperFunctions.js";
|
|
7
|
+
import {
|
|
8
|
+
findOrCreateOperation as findOrCreateOp,
|
|
9
|
+
updateOperation as updateOp,
|
|
10
|
+
getOperation as getOp
|
|
11
|
+
} from "./operationsTable.js";
|
|
12
|
+
import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
|
|
13
|
+
import { MessageFormatter } from "./messageFormatter.js";
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Object that contains the context for an action that needs to be executed after import
|
|
17
|
+
* Used in the afterImportActionsDefinitions
|
|
18
|
+
* @type {ContextObject}
|
|
19
|
+
* @typedef {Object} ContextObject
|
|
20
|
+
* @property {string} collectionId - The ID of the collection
|
|
21
|
+
* @property {any} finalItem - The final item that was imported
|
|
22
|
+
* @property {string} action - The name of the action
|
|
23
|
+
* @property {string[]} params - The parameters for the action
|
|
24
|
+
* @property {Object} context - The context object for the action (all the data of this specific item)
|
|
25
|
+
*/
|
|
26
|
+
export const ContextObject = z.object({
|
|
27
|
+
dbId: z.string(),
|
|
28
|
+
collectionId: z.string(),
|
|
29
|
+
finalItem: z.any(),
|
|
30
|
+
attributeMappings: AttributeMappingsSchema,
|
|
31
|
+
context: z.any(),
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
export type ContextObject = z.infer<typeof ContextObject>;
|
|
35
|
+
|
|
36
|
+
export const createOrFindAfterImportOperation = async (
|
|
37
|
+
database: Databases,
|
|
38
|
+
collectionId: string,
|
|
39
|
+
context: ContextObject
|
|
40
|
+
) => {
|
|
41
|
+
let operation = await findOrCreateOperationLegacy(
|
|
42
|
+
database,
|
|
43
|
+
collectionId,
|
|
44
|
+
"afterImportAction"
|
|
45
|
+
);
|
|
46
|
+
if (!operation.batches) {
|
|
47
|
+
operation.batches = [];
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Directly create a new batch for the context without checking for an existing batch
|
|
51
|
+
const contextData = JSON.stringify(context);
|
|
52
|
+
// Create a new batch with the contextData
|
|
53
|
+
const newBatchId = await addBatch(database, contextData);
|
|
54
|
+
// Update the operation with the new batch's $id
|
|
55
|
+
operation.batches = [...operation.batches, newBatchId];
|
|
56
|
+
await database.updateDocument(
|
|
57
|
+
"migrations",
|
|
58
|
+
"currentOperations",
|
|
59
|
+
operation.$id,
|
|
60
|
+
{ batches: operation.batches }
|
|
61
|
+
);
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export const addBatch = async (database: Databases, data: string) => {
|
|
65
|
+
const batch = await database.createDocument(
|
|
66
|
+
"migrations",
|
|
67
|
+
"batches",
|
|
68
|
+
ID.unique(),
|
|
69
|
+
{
|
|
70
|
+
data,
|
|
71
|
+
processed: false,
|
|
72
|
+
}
|
|
73
|
+
);
|
|
74
|
+
return batch.$id;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
export const getAfterImportOperations = async (
|
|
78
|
+
database: Databases,
|
|
79
|
+
collectionId: string
|
|
80
|
+
) => {
|
|
81
|
+
let lastDocumentId: string | undefined;
|
|
82
|
+
const allOperations = [];
|
|
83
|
+
let total = 0;
|
|
84
|
+
|
|
85
|
+
do {
|
|
86
|
+
const query = [
|
|
87
|
+
Query.equal("collectionId", collectionId),
|
|
88
|
+
Query.equal("operationType", "afterImportAction"),
|
|
89
|
+
Query.limit(100),
|
|
90
|
+
];
|
|
91
|
+
|
|
92
|
+
if (lastDocumentId) {
|
|
93
|
+
query.push(Query.cursorAfter(lastDocumentId));
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const operations = await database.listDocuments(
|
|
97
|
+
"migrations",
|
|
98
|
+
"currentOperations",
|
|
99
|
+
query
|
|
100
|
+
);
|
|
101
|
+
total = operations.total; // Update total with the latest fetch
|
|
102
|
+
allOperations.push(...operations.documents);
|
|
103
|
+
|
|
104
|
+
if (operations.documents.length > 0 && operations.documents.length >= 100) {
|
|
105
|
+
lastDocumentId =
|
|
106
|
+
operations.documents[operations.documents.length - 1].$id;
|
|
107
|
+
}
|
|
108
|
+
} while (allOperations.length < total);
|
|
109
|
+
|
|
110
|
+
const allOps = allOperations.map((op) => OperationSchema.parse(op));
|
|
111
|
+
return allOps;
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
// Legacy function for backward compatibility with old migrations database
|
|
115
|
+
const findOrCreateOperationLegacy = async (
|
|
116
|
+
database: Databases,
|
|
117
|
+
collectionId: string,
|
|
118
|
+
operationType: string,
|
|
119
|
+
additionalQueries?: string[]
|
|
120
|
+
) => {
|
|
121
|
+
const operations = await tryAwaitWithRetry(
|
|
122
|
+
async () =>
|
|
123
|
+
await database.listDocuments("migrations", "currentOperations", [
|
|
124
|
+
Query.equal("collectionId", collectionId),
|
|
125
|
+
Query.equal("operationType", operationType),
|
|
126
|
+
Query.equal("status", "pending"),
|
|
127
|
+
...(additionalQueries || []),
|
|
128
|
+
])
|
|
129
|
+
);
|
|
130
|
+
|
|
131
|
+
if (operations.documents.length > 0) {
|
|
132
|
+
return OperationSchema.parse(operations.documents[0]);
|
|
133
|
+
} else {
|
|
134
|
+
const op = await tryAwaitWithRetry(
|
|
135
|
+
async () =>
|
|
136
|
+
await database.createDocument(
|
|
137
|
+
"migrations",
|
|
138
|
+
"currentOperations",
|
|
139
|
+
ID.unique(),
|
|
140
|
+
{
|
|
141
|
+
operationType,
|
|
142
|
+
collectionId,
|
|
143
|
+
status: "pending",
|
|
144
|
+
batches: [],
|
|
145
|
+
progress: 0,
|
|
146
|
+
total: 0,
|
|
147
|
+
error: "",
|
|
148
|
+
}
|
|
149
|
+
)
|
|
150
|
+
);
|
|
151
|
+
|
|
152
|
+
return OperationSchema.parse(op);
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
|
|
156
|
+
export const findOrCreateOperation = async (
|
|
157
|
+
db: DatabaseAdapter,
|
|
158
|
+
databaseId: string,
|
|
159
|
+
operationType: string,
|
|
160
|
+
collectionId?: string,
|
|
161
|
+
data?: any
|
|
162
|
+
): Promise<any> => {
|
|
163
|
+
// Use new operations table system
|
|
164
|
+
return await findOrCreateOp(db, databaseId, operationType, {
|
|
165
|
+
targetCollection: collectionId,
|
|
166
|
+
data: data
|
|
167
|
+
});
|
|
168
|
+
};
|
|
169
|
+
|
|
170
|
+
export const updateOperation = async (
|
|
171
|
+
db: DatabaseAdapter,
|
|
172
|
+
databaseId: string,
|
|
173
|
+
operationId: string,
|
|
174
|
+
updates: any
|
|
175
|
+
): Promise<any> => {
|
|
176
|
+
// Use new operations table system
|
|
177
|
+
return await updateOp(db, databaseId, operationId, updates);
|
|
178
|
+
};
|
|
179
|
+
|
|
180
|
+
export const getOperation = async (
|
|
181
|
+
db: DatabaseAdapter,
|
|
182
|
+
databaseId: string,
|
|
183
|
+
operationId: string
|
|
184
|
+
): Promise<any> => {
|
|
185
|
+
// Use new operations table system
|
|
186
|
+
return await getOp(db, databaseId, operationId);
|
|
187
|
+
};
|
|
188
|
+
|
|
189
|
+
// Actual max 1073741824
|
|
190
|
+
export const maxDataLength = 1073741820;
|
|
191
|
+
export const maxBatchItems = 25;
|
|
192
|
+
|
|
193
|
+
export const splitIntoBatches = (data: any[]): any[][] => {
|
|
194
|
+
let batches = [];
|
|
195
|
+
let currentBatch: any[] = [];
|
|
196
|
+
let currentBatchLength = 0;
|
|
197
|
+
let currentBatchItemCount = 0;
|
|
198
|
+
|
|
199
|
+
data.forEach((item, index) => {
|
|
200
|
+
const itemLength = JSON.stringify(item).length;
|
|
201
|
+
if (itemLength > maxDataLength) {
|
|
202
|
+
MessageFormatter.warning(
|
|
203
|
+
`Large item found at index ${index} with length ${itemLength}`,
|
|
204
|
+
{ prefix: "Batch Splitter" }
|
|
205
|
+
);
|
|
206
|
+
logger.debug("Large item data:", item);
|
|
207
|
+
}
|
|
208
|
+
// Check if adding the current item would exceed the max length or max items per batch
|
|
209
|
+
if (
|
|
210
|
+
currentBatchLength + itemLength >= maxDataLength ||
|
|
211
|
+
currentBatchItemCount >= maxBatchItems
|
|
212
|
+
) {
|
|
213
|
+
// If so, start a new batch
|
|
214
|
+
batches.push(currentBatch);
|
|
215
|
+
currentBatch = [item];
|
|
216
|
+
currentBatchLength = itemLength;
|
|
217
|
+
currentBatchItemCount = 1; // Reset item count for the new batch
|
|
218
|
+
} else {
|
|
219
|
+
// Otherwise, add the item to the current batch
|
|
220
|
+
currentBatch.push(item);
|
|
221
|
+
currentBatchLength += itemLength;
|
|
222
|
+
currentBatchItemCount++;
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
|
|
226
|
+
// Don't forget to add the last batch if it's not empty
|
|
227
|
+
if (currentBatch.length > 0) {
|
|
228
|
+
batches.push(currentBatch);
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
return batches;
|
|
232
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { Databases, Models } from "node-appwrite";
|
|
2
|
+
import type { OperationCreate } from "../storage/schemas.js";
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Legacy operation logger - deprecated
|
|
6
|
+
* This function is maintained for backward compatibility but no longer performs any logging.
|
|
7
|
+
* The operations table system has been refactored to use the dynamic adapter pattern.
|
|
8
|
+
*
|
|
9
|
+
* @deprecated This function will be removed in a future version
|
|
10
|
+
*/
|
|
11
|
+
export const logOperation = async (
|
|
12
|
+
db: Databases,
|
|
13
|
+
dbId: string,
|
|
14
|
+
operationDetails: OperationCreate,
|
|
15
|
+
operationId?: string
|
|
16
|
+
): Promise<Models.Document | null> => {
|
|
17
|
+
// No-op: Operations logging has been moved to the new operations table system
|
|
18
|
+
// Callers should migrate to using operationsTable.ts functions directly
|
|
19
|
+
return null;
|
|
20
|
+
};
|