appwrite-utils-cli 1.9.7 → 1.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1004 -1004
- package/dist/adapters/index.d.ts +7 -8
- package/dist/adapters/index.js +7 -9
- package/dist/backups/operations/bucketBackup.js +2 -2
- package/dist/backups/operations/collectionBackup.d.ts +1 -1
- package/dist/backups/operations/collectionBackup.js +3 -3
- package/dist/backups/operations/comprehensiveBackup.d.ts +1 -1
- package/dist/backups/operations/comprehensiveBackup.js +2 -2
- package/dist/backups/tracking/centralizedTracking.d.ts +1 -1
- package/dist/backups/tracking/centralizedTracking.js +2 -2
- package/dist/cli/commands/configCommands.js +51 -7
- package/dist/cli/commands/databaseCommands.js +156 -104
- package/dist/cli/commands/functionCommands.js +3 -3
- package/dist/cli/commands/importFileCommands.d.ts +7 -0
- package/dist/cli/commands/importFileCommands.js +674 -0
- package/dist/cli/commands/schemaCommands.js +3 -3
- package/dist/cli/commands/storageCommands.js +2 -3
- package/dist/cli/commands/transferCommands.js +3 -5
- package/dist/collections/{attributes.d.ts → columns.d.ts} +1 -1
- package/dist/collections/{attributes.js → columns.js} +15 -9
- package/dist/collections/indexes.js +1 -3
- package/dist/collections/methods.d.ts +1 -1
- package/dist/collections/methods.js +38 -20
- package/dist/collections/tableOperations.d.ts +1 -0
- package/dist/collections/tableOperations.js +30 -11
- package/dist/collections/transferOperations.d.ts +1 -1
- package/dist/collections/transferOperations.js +3 -4
- package/dist/collections/wipeOperations.d.ts +4 -3
- package/dist/collections/wipeOperations.js +112 -39
- package/dist/databases/methods.js +2 -2
- package/dist/databases/setup.js +2 -2
- package/dist/examples/yamlTerminologyExample.js +2 -2
- package/dist/functions/deployments.d.ts +1 -1
- package/dist/functions/deployments.js +6 -6
- package/dist/functions/fnConfigDiscovery.js +2 -2
- package/dist/functions/methods.js +2 -2
- package/dist/functions/templates/count-docs-in-collection/README.md +53 -53
- package/dist/functions/templates/count-docs-in-collection/src/main.ts +159 -159
- package/dist/functions/templates/count-docs-in-collection/src/request.ts +8 -8
- package/dist/functions/templates/hono-typescript/README.md +285 -285
- package/dist/functions/templates/hono-typescript/src/adapters/request.ts +73 -73
- package/dist/functions/templates/hono-typescript/src/adapters/response.ts +105 -105
- package/dist/functions/templates/hono-typescript/src/app.ts +179 -179
- package/dist/functions/templates/hono-typescript/src/context.ts +102 -102
- package/{src/functions/templates/hono-typescript/src/index.ts → dist/functions/templates/hono-typescript/src/main.ts} +53 -53
- package/dist/functions/templates/hono-typescript/src/middleware/appwrite.ts +118 -118
- package/dist/functions/templates/typescript-node/README.md +31 -31
- package/dist/functions/templates/typescript-node/src/context.ts +102 -102
- package/dist/functions/templates/typescript-node/src/{index.ts → main.ts} +29 -29
- package/dist/functions/templates/uv/README.md +30 -30
- package/dist/functions/templates/uv/pyproject.toml +29 -29
- package/dist/functions/templates/uv/src/context.py +124 -124
- package/dist/functions/templates/uv/src/{index.py → main.py} +45 -45
- package/dist/init.js +1 -1
- package/dist/interactiveCLI.d.ts +6 -1
- package/dist/interactiveCLI.js +79 -25
- package/dist/main.js +125 -180
- package/dist/migrations/afterImportActions.js +2 -3
- package/dist/migrations/appwriteToX.d.ts +1 -1
- package/dist/migrations/appwriteToX.js +10 -8
- package/dist/migrations/comprehensiveTransfer.js +3 -5
- package/dist/migrations/dataLoader.d.ts +4 -2
- package/dist/migrations/dataLoader.js +42 -20
- package/dist/migrations/importController.d.ts +2 -0
- package/dist/migrations/importController.js +39 -24
- package/dist/migrations/importDataActions.js +3 -3
- package/dist/migrations/relationships.js +1 -2
- package/dist/migrations/services/DataTransformationService.js +2 -2
- package/dist/migrations/services/FileHandlerService.js +1 -1
- package/dist/migrations/services/ImportOrchestrator.d.ts +2 -0
- package/dist/migrations/services/ImportOrchestrator.js +15 -7
- package/dist/migrations/services/RateLimitManager.js +1 -1
- package/dist/migrations/services/RelationshipResolver.js +1 -1
- package/dist/migrations/services/UserMappingService.js +1 -1
- package/dist/migrations/services/ValidationService.js +1 -1
- package/dist/migrations/transfer.d.ts +8 -4
- package/dist/migrations/transfer.js +108 -55
- package/dist/migrations/yaml/YamlImportConfigLoader.js +52 -52
- package/dist/migrations/yaml/YamlImportIntegration.js +2 -2
- package/dist/migrations/yaml/generateImportSchemas.js +174 -174
- package/dist/setupCommands.d.ts +1 -1
- package/dist/setupCommands.js +5 -6
- package/dist/setupController.js +1 -1
- package/dist/shared/backupTracking.d.ts +1 -1
- package/dist/shared/backupTracking.js +2 -2
- package/dist/shared/confirmationDialogs.js +1 -1
- package/dist/shared/migrationHelpers.d.ts +1 -1
- package/dist/shared/migrationHelpers.js +4 -4
- package/dist/shared/operationQueue.d.ts +1 -1
- package/dist/shared/operationQueue.js +3 -4
- package/dist/shared/operationsTable.d.ts +1 -1
- package/dist/shared/operationsTable.js +35 -34
- package/dist/shared/operationsTableSchema.d.ts +3 -3
- package/dist/shared/operationsTableSchema.js +2 -2
- package/dist/shared/progressManager.js +1 -1
- package/dist/shared/selectionDialogs.d.ts +6 -0
- package/dist/shared/selectionDialogs.js +56 -12
- package/dist/storage/methods.d.ts +12 -0
- package/dist/storage/methods.js +92 -89
- package/dist/storage/schemas.d.ts +2 -2
- package/dist/tables/indexManager.d.ts +1 -1
- package/dist/tables/indexManager.js +2 -2
- package/dist/types.d.ts +2 -2
- package/dist/types.js +1 -1
- package/dist/users/methods.js +2 -3
- package/dist/utils/configMigration.js +1 -1
- package/dist/utils/index.d.ts +1 -1
- package/dist/utils/index.js +1 -1
- package/dist/utils/loadConfigs.d.ts +2 -2
- package/dist/utils/loadConfigs.js +6 -7
- package/dist/utils/setupFiles.js +139 -141
- package/dist/utilsController.d.ts +16 -9
- package/dist/utilsController.js +93 -68
- package/package.json +9 -3
- package/.appwrite/.yaml_schemas/appwrite-config.schema.json +0 -380
- package/.appwrite/.yaml_schemas/collection.schema.json +0 -255
- package/.appwrite/collections/Categories.yaml +0 -182
- package/.appwrite/collections/ExampleCollection.yaml +0 -36
- package/.appwrite/collections/Posts.yaml +0 -227
- package/.appwrite/collections/Users.yaml +0 -149
- package/.appwrite/config.yaml +0 -109
- package/.appwrite/import/README.md +0 -148
- package/.appwrite/import/categories-import.yaml +0 -129
- package/.appwrite/import/posts-import.yaml +0 -208
- package/.appwrite/import/users-import.yaml +0 -130
- package/.appwrite/importData/categories.json +0 -194
- package/.appwrite/importData/posts.json +0 -270
- package/.appwrite/importData/users.json +0 -220
- package/.appwrite/schemas/categories.json +0 -128
- package/.appwrite/schemas/exampleCollection.json +0 -52
- package/.appwrite/schemas/posts.json +0 -173
- package/.appwrite/schemas/users.json +0 -125
- package/CHANGELOG.md +0 -35
- package/CONFIG_TODO.md +0 -1189
- package/SELECTION_DIALOGS.md +0 -146
- package/SERVICE_IMPLEMENTATION_REPORT.md +0 -462
- package/dist/adapters/AdapterFactory.d.ts +0 -94
- package/dist/adapters/AdapterFactory.js +0 -420
- package/dist/adapters/DatabaseAdapter.d.ts +0 -243
- package/dist/adapters/DatabaseAdapter.js +0 -50
- package/dist/adapters/LegacyAdapter.d.ts +0 -50
- package/dist/adapters/LegacyAdapter.js +0 -615
- package/dist/adapters/TablesDBAdapter.d.ts +0 -45
- package/dist/adapters/TablesDBAdapter.js +0 -611
- package/dist/config/ConfigManager.d.ts +0 -450
- package/dist/config/ConfigManager.js +0 -650
- package/dist/config/configMigration.d.ts +0 -87
- package/dist/config/configMigration.js +0 -390
- package/dist/config/configValidation.d.ts +0 -66
- package/dist/config/configValidation.js +0 -358
- package/dist/config/index.d.ts +0 -8
- package/dist/config/index.js +0 -7
- package/dist/config/services/ConfigDiscoveryService.d.ts +0 -122
- package/dist/config/services/ConfigDiscoveryService.js +0 -322
- package/dist/config/services/ConfigLoaderService.d.ts +0 -129
- package/dist/config/services/ConfigLoaderService.js +0 -535
- package/dist/config/services/ConfigMergeService.d.ts +0 -208
- package/dist/config/services/ConfigMergeService.js +0 -308
- package/dist/config/services/ConfigValidationService.d.ts +0 -214
- package/dist/config/services/ConfigValidationService.js +0 -310
- package/dist/config/services/SessionAuthService.d.ts +0 -225
- package/dist/config/services/SessionAuthService.js +0 -456
- package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +0 -1
- package/dist/config/services/__tests__/ConfigMergeService.test.js +0 -271
- package/dist/config/services/index.d.ts +0 -13
- package/dist/config/services/index.js +0 -10
- package/dist/config/yamlConfig.d.ts +0 -722
- package/dist/config/yamlConfig.js +0 -702
- package/dist/functions/pathResolution.d.ts +0 -37
- package/dist/functions/pathResolution.js +0 -185
- package/dist/functions/templates/count-docs-in-collection/package.json +0 -25
- package/dist/functions/templates/count-docs-in-collection/tsconfig.json +0 -28
- package/dist/functions/templates/hono-typescript/package.json +0 -26
- package/dist/functions/templates/hono-typescript/src/index.ts +0 -54
- package/dist/functions/templates/hono-typescript/tsconfig.json +0 -20
- package/dist/functions/templates/typescript-node/package.json +0 -25
- package/dist/functions/templates/typescript-node/tsconfig.json +0 -28
- package/dist/shared/attributeMapper.d.ts +0 -20
- package/dist/shared/attributeMapper.js +0 -203
- package/dist/shared/errorUtils.d.ts +0 -54
- package/dist/shared/errorUtils.js +0 -95
- package/dist/shared/functionManager.d.ts +0 -48
- package/dist/shared/functionManager.js +0 -348
- package/dist/shared/jsonSchemaGenerator.d.ts +0 -50
- package/dist/shared/jsonSchemaGenerator.js +0 -290
- package/dist/shared/logging.d.ts +0 -61
- package/dist/shared/logging.js +0 -116
- package/dist/shared/messageFormatter.d.ts +0 -39
- package/dist/shared/messageFormatter.js +0 -162
- package/dist/shared/pydanticModelGenerator.d.ts +0 -17
- package/dist/shared/pydanticModelGenerator.js +0 -615
- package/dist/shared/schemaGenerator.d.ts +0 -40
- package/dist/shared/schemaGenerator.js +0 -556
- package/dist/utils/ClientFactory.d.ts +0 -87
- package/dist/utils/ClientFactory.js +0 -212
- package/dist/utils/configDiscovery.d.ts +0 -78
- package/dist/utils/configDiscovery.js +0 -472
- package/dist/utils/constantsGenerator.d.ts +0 -31
- package/dist/utils/constantsGenerator.js +0 -321
- package/dist/utils/dataConverters.d.ts +0 -46
- package/dist/utils/dataConverters.js +0 -139
- package/dist/utils/directoryUtils.d.ts +0 -22
- package/dist/utils/directoryUtils.js +0 -59
- package/dist/utils/getClientFromConfig.d.ts +0 -39
- package/dist/utils/getClientFromConfig.js +0 -199
- package/dist/utils/helperFunctions.d.ts +0 -63
- package/dist/utils/helperFunctions.js +0 -156
- package/dist/utils/pathResolvers.d.ts +0 -53
- package/dist/utils/pathResolvers.js +0 -72
- package/dist/utils/projectConfig.d.ts +0 -122
- package/dist/utils/projectConfig.js +0 -206
- package/dist/utils/retryFailedPromises.d.ts +0 -2
- package/dist/utils/retryFailedPromises.js +0 -23
- package/dist/utils/sessionAuth.d.ts +0 -48
- package/dist/utils/sessionAuth.js +0 -164
- package/dist/utils/typeGuards.d.ts +0 -35
- package/dist/utils/typeGuards.js +0 -57
- package/dist/utils/validationRules.d.ts +0 -43
- package/dist/utils/validationRules.js +0 -42
- package/dist/utils/versionDetection.d.ts +0 -58
- package/dist/utils/versionDetection.js +0 -251
- package/dist/utils/yamlConverter.d.ts +0 -100
- package/dist/utils/yamlConverter.js +0 -428
- package/dist/utils/yamlLoader.d.ts +0 -70
- package/dist/utils/yamlLoader.js +0 -267
- package/scripts/copy-templates.ts +0 -23
- package/src/adapters/AdapterFactory.ts +0 -529
- package/src/adapters/DatabaseAdapter.ts +0 -319
- package/src/adapters/LegacyAdapter.ts +0 -844
- package/src/adapters/TablesDBAdapter.ts +0 -823
- package/src/adapters/index.ts +0 -37
- package/src/backups/operations/bucketBackup.ts +0 -277
- package/src/backups/operations/collectionBackup.ts +0 -310
- package/src/backups/operations/comprehensiveBackup.ts +0 -342
- package/src/backups/schemas/bucketManifest.ts +0 -78
- package/src/backups/schemas/comprehensiveManifest.ts +0 -76
- package/src/backups/tracking/centralizedTracking.ts +0 -352
- package/src/cli/commands/configCommands.ts +0 -201
- package/src/cli/commands/databaseCommands.ts +0 -879
- package/src/cli/commands/functionCommands.ts +0 -418
- package/src/cli/commands/schemaCommands.ts +0 -200
- package/src/cli/commands/storageCommands.ts +0 -152
- package/src/cli/commands/transferCommands.ts +0 -457
- package/src/collections/attributes.ts +0 -2020
- package/src/collections/attributes.ts.backup +0 -1555
- package/src/collections/indexes.ts +0 -352
- package/src/collections/methods.ts +0 -700
- package/src/collections/tableOperations.ts +0 -521
- package/src/collections/transferOperations.ts +0 -590
- package/src/collections/wipeOperations.ts +0 -346
- package/src/config/ConfigManager.ts +0 -849
- package/src/config/README.md +0 -274
- package/src/config/configMigration.ts +0 -575
- package/src/config/configValidation.ts +0 -445
- package/src/config/index.ts +0 -10
- package/src/config/services/ConfigDiscoveryService.ts +0 -410
- package/src/config/services/ConfigLoaderService.ts +0 -732
- package/src/config/services/ConfigMergeService.ts +0 -388
- package/src/config/services/ConfigValidationService.ts +0 -394
- package/src/config/services/SessionAuthService.ts +0 -565
- package/src/config/services/__tests__/ConfigMergeService.test.ts +0 -351
- package/src/config/services/index.ts +0 -29
- package/src/config/yamlConfig.ts +0 -761
- package/src/databases/methods.ts +0 -49
- package/src/databases/setup.ts +0 -77
- package/src/examples/yamlTerminologyExample.ts +0 -346
- package/src/functions/deployments.ts +0 -220
- package/src/functions/fnConfigDiscovery.ts +0 -103
- package/src/functions/methods.ts +0 -284
- package/src/functions/pathResolution.ts +0 -227
- package/src/functions/templates/count-docs-in-collection/README.md +0 -54
- package/src/functions/templates/count-docs-in-collection/package.json +0 -25
- package/src/functions/templates/count-docs-in-collection/src/main.ts +0 -159
- package/src/functions/templates/count-docs-in-collection/src/request.ts +0 -9
- package/src/functions/templates/count-docs-in-collection/tsconfig.json +0 -28
- package/src/functions/templates/hono-typescript/README.md +0 -286
- package/src/functions/templates/hono-typescript/package.json +0 -26
- package/src/functions/templates/hono-typescript/src/adapters/request.ts +0 -74
- package/src/functions/templates/hono-typescript/src/adapters/response.ts +0 -106
- package/src/functions/templates/hono-typescript/src/app.ts +0 -180
- package/src/functions/templates/hono-typescript/src/context.ts +0 -103
- package/src/functions/templates/hono-typescript/src/middleware/appwrite.ts +0 -119
- package/src/functions/templates/hono-typescript/tsconfig.json +0 -20
- package/src/functions/templates/typescript-node/README.md +0 -32
- package/src/functions/templates/typescript-node/package.json +0 -25
- package/src/functions/templates/typescript-node/src/context.ts +0 -103
- package/src/functions/templates/typescript-node/src/index.ts +0 -29
- package/src/functions/templates/typescript-node/tsconfig.json +0 -28
- package/src/functions/templates/uv/README.md +0 -31
- package/src/functions/templates/uv/pyproject.toml +0 -30
- package/src/functions/templates/uv/src/__init__.py +0 -0
- package/src/functions/templates/uv/src/context.py +0 -125
- package/src/functions/templates/uv/src/index.py +0 -46
- package/src/init.ts +0 -62
- package/src/interactiveCLI.ts +0 -1136
- package/src/main.ts +0 -1670
- package/src/migrations/afterImportActions.ts +0 -580
- package/src/migrations/appwriteToX.ts +0 -664
- package/src/migrations/comprehensiveTransfer.ts +0 -2285
- package/src/migrations/dataLoader.ts +0 -1702
- package/src/migrations/importController.ts +0 -428
- package/src/migrations/importDataActions.ts +0 -315
- package/src/migrations/relationships.ts +0 -334
- package/src/migrations/services/DataTransformationService.ts +0 -196
- package/src/migrations/services/FileHandlerService.ts +0 -311
- package/src/migrations/services/ImportOrchestrator.ts +0 -666
- package/src/migrations/services/RateLimitManager.ts +0 -363
- package/src/migrations/services/RelationshipResolver.ts +0 -461
- package/src/migrations/services/UserMappingService.ts +0 -345
- package/src/migrations/services/ValidationService.ts +0 -349
- package/src/migrations/transfer.ts +0 -1068
- package/src/migrations/yaml/YamlImportConfigLoader.ts +0 -439
- package/src/migrations/yaml/YamlImportIntegration.ts +0 -446
- package/src/migrations/yaml/generateImportSchemas.ts +0 -1354
- package/src/schemas/authUser.ts +0 -23
- package/src/setup.ts +0 -8
- package/src/setupCommands.ts +0 -603
- package/src/setupController.ts +0 -43
- package/src/shared/attributeMapper.ts +0 -229
- package/src/shared/backupMetadataSchema.ts +0 -93
- package/src/shared/backupTracking.ts +0 -211
- package/src/shared/confirmationDialogs.ts +0 -327
- package/src/shared/errorUtils.ts +0 -110
- package/src/shared/functionManager.ts +0 -537
- package/src/shared/jsonSchemaGenerator.ts +0 -383
- package/src/shared/logging.ts +0 -149
- package/src/shared/messageFormatter.ts +0 -208
- package/src/shared/migrationHelpers.ts +0 -232
- package/src/shared/operationLogger.ts +0 -20
- package/src/shared/operationQueue.ts +0 -377
- package/src/shared/operationsTable.ts +0 -338
- package/src/shared/operationsTableSchema.ts +0 -60
- package/src/shared/progressManager.ts +0 -278
- package/src/shared/pydanticModelGenerator.ts +0 -618
- package/src/shared/relationshipExtractor.ts +0 -214
- package/src/shared/schemaGenerator.ts +0 -644
- package/src/shared/selectionDialogs.ts +0 -749
- package/src/storage/backupCompression.ts +0 -88
- package/src/storage/methods.ts +0 -698
- package/src/storage/schemas.ts +0 -205
- package/src/tables/indexManager.ts +0 -409
- package/src/types/node-appwrite-tablesdb.d.ts +0 -44
- package/src/types.ts +0 -9
- package/src/users/methods.ts +0 -359
- package/src/utils/ClientFactory.ts +0 -240
- package/src/utils/configDiscovery.ts +0 -557
- package/src/utils/configMigration.ts +0 -348
- package/src/utils/constantsGenerator.ts +0 -369
- package/src/utils/dataConverters.ts +0 -159
- package/src/utils/directoryUtils.ts +0 -61
- package/src/utils/getClientFromConfig.ts +0 -257
- package/src/utils/helperFunctions.ts +0 -228
- package/src/utils/index.ts +0 -2
- package/src/utils/loadConfigs.ts +0 -449
- package/src/utils/pathResolvers.ts +0 -81
- package/src/utils/projectConfig.ts +0 -340
- package/src/utils/retryFailedPromises.ts +0 -29
- package/src/utils/sessionAuth.ts +0 -230
- package/src/utils/setupFiles.ts +0 -1238
- package/src/utils/typeGuards.ts +0 -65
- package/src/utils/validationRules.ts +0 -88
- package/src/utils/versionDetection.ts +0 -292
- package/src/utils/yamlConverter.ts +0 -542
- package/src/utils/yamlLoader.ts +0 -371
- package/src/utilsController.ts +0 -1213
- package/tests/README.md +0 -497
- package/tests/adapters/AdapterFactory.test.ts +0 -277
- package/tests/integration/syncOperations.test.ts +0 -463
- package/tests/jest.config.js +0 -25
- package/tests/migration/configMigration.test.ts +0 -546
- package/tests/setup.ts +0 -62
- package/tests/testUtils.ts +0 -340
- package/tests/utils/loadConfigs.test.ts +0 -350
- package/tests/validation/configValidation.test.ts +0 -412
- package/tmp-sync-test/.appwrite/collections/TestCollection.yaml +0 -7
- package/tsconfig.json +0 -44
package/src/storage/schemas.ts
DELETED
|
@@ -1,205 +0,0 @@
|
|
|
1
|
-
import { z } from "zod";
|
|
2
|
-
import {
|
|
3
|
-
attributeSchema,
|
|
4
|
-
type Attribute,
|
|
5
|
-
parseAttribute,
|
|
6
|
-
CollectionCreateSchema,
|
|
7
|
-
} from "appwrite-utils";
|
|
8
|
-
|
|
9
|
-
export const BackupSchema = z.object({
|
|
10
|
-
$id: z.string(),
|
|
11
|
-
$createdAt: z.string(),
|
|
12
|
-
$updatedAt: z.string(),
|
|
13
|
-
database: z.string(),
|
|
14
|
-
collections: z.array(z.string()),
|
|
15
|
-
documents: z
|
|
16
|
-
.array(
|
|
17
|
-
z.object({
|
|
18
|
-
collectionId: z.string(),
|
|
19
|
-
data: z.string(),
|
|
20
|
-
})
|
|
21
|
-
)
|
|
22
|
-
.default([]),
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
export type Backup = z.infer<typeof BackupSchema>;
|
|
26
|
-
|
|
27
|
-
export const BackupCreateSchema = BackupSchema.omit({
|
|
28
|
-
$id: true,
|
|
29
|
-
$createdAt: true,
|
|
30
|
-
$updatedAt: true,
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
export type BackupCreate = z.infer<typeof BackupCreateSchema>;
|
|
34
|
-
|
|
35
|
-
export const BatchSchema = z.object({
|
|
36
|
-
$id: z.string(),
|
|
37
|
-
$createdAt: z.string(),
|
|
38
|
-
$updatedAt: z.string(),
|
|
39
|
-
data: z.string().describe("The serialized data for this batch"),
|
|
40
|
-
processed: z
|
|
41
|
-
.boolean()
|
|
42
|
-
.default(false)
|
|
43
|
-
.describe("Whether the batch has been processed"),
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
export type Batch = z.infer<typeof BatchSchema>;
|
|
47
|
-
|
|
48
|
-
export const BatchCreateSchema = BatchSchema.omit({
|
|
49
|
-
$id: true,
|
|
50
|
-
$createdAt: true,
|
|
51
|
-
$updatedAt: true,
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
export type BatchCreate = z.infer<typeof BatchCreateSchema>;
|
|
55
|
-
|
|
56
|
-
export const OperationSchema = z.object({
|
|
57
|
-
$id: z.string(),
|
|
58
|
-
$createdAt: z.string(),
|
|
59
|
-
$updatedAt: z.string(),
|
|
60
|
-
operationType: z.string(),
|
|
61
|
-
collectionId: z.string(),
|
|
62
|
-
data: z.any(),
|
|
63
|
-
batches: z.array(z.string()).default([]).optional(),
|
|
64
|
-
progress: z.number(),
|
|
65
|
-
total: z.number(),
|
|
66
|
-
error: z.string(),
|
|
67
|
-
status: z
|
|
68
|
-
.enum([
|
|
69
|
-
"pending",
|
|
70
|
-
"ready",
|
|
71
|
-
"in_progress",
|
|
72
|
-
"completed",
|
|
73
|
-
"error",
|
|
74
|
-
"cancelled",
|
|
75
|
-
])
|
|
76
|
-
.default("pending"),
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
export type Operation = z.infer<typeof OperationSchema>;
|
|
80
|
-
|
|
81
|
-
export const OperationCreateSchema = OperationSchema.omit({
|
|
82
|
-
$id: true,
|
|
83
|
-
$createdAt: true,
|
|
84
|
-
$updatedAt: true,
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
export type OperationCreate = z.infer<typeof OperationCreateSchema>;
|
|
88
|
-
|
|
89
|
-
export const getMigrationCollectionSchemas = () => {
|
|
90
|
-
const currentOperationsAttributes: Attribute[] = [
|
|
91
|
-
parseAttribute({
|
|
92
|
-
key: "operationType",
|
|
93
|
-
type: "string",
|
|
94
|
-
error: "Invalid Operation Type",
|
|
95
|
-
size: 50,
|
|
96
|
-
required: true,
|
|
97
|
-
array: false,
|
|
98
|
-
xdefault: null,
|
|
99
|
-
}),
|
|
100
|
-
attributeSchema.parse({
|
|
101
|
-
key: "collectionId",
|
|
102
|
-
type: "string",
|
|
103
|
-
error: "Invalid Collection Id",
|
|
104
|
-
size: 50,
|
|
105
|
-
array: false,
|
|
106
|
-
xdefault: null,
|
|
107
|
-
}),
|
|
108
|
-
attributeSchema.parse({
|
|
109
|
-
key: "batches",
|
|
110
|
-
type: "string",
|
|
111
|
-
error: "Invalid Batches",
|
|
112
|
-
size: 1073741824,
|
|
113
|
-
array: true,
|
|
114
|
-
}),
|
|
115
|
-
attributeSchema.parse({
|
|
116
|
-
key: "data",
|
|
117
|
-
type: "string",
|
|
118
|
-
error: "Invalid Data",
|
|
119
|
-
size: 1073741824,
|
|
120
|
-
}),
|
|
121
|
-
attributeSchema.parse({
|
|
122
|
-
key: "progress",
|
|
123
|
-
type: "integer",
|
|
124
|
-
error: "Invalid Progress",
|
|
125
|
-
required: true,
|
|
126
|
-
array: false,
|
|
127
|
-
}),
|
|
128
|
-
attributeSchema.parse({
|
|
129
|
-
key: "total",
|
|
130
|
-
type: "integer",
|
|
131
|
-
error: "Invalid Total",
|
|
132
|
-
required: true,
|
|
133
|
-
array: false,
|
|
134
|
-
}),
|
|
135
|
-
attributeSchema.parse({
|
|
136
|
-
key: "error",
|
|
137
|
-
type: "string",
|
|
138
|
-
error: "Operation Error",
|
|
139
|
-
required: false,
|
|
140
|
-
array: false,
|
|
141
|
-
}),
|
|
142
|
-
attributeSchema.parse({
|
|
143
|
-
key: "status",
|
|
144
|
-
type: "enum",
|
|
145
|
-
elements: [
|
|
146
|
-
"pending",
|
|
147
|
-
"ready",
|
|
148
|
-
"in_progress",
|
|
149
|
-
"completed",
|
|
150
|
-
"error",
|
|
151
|
-
"cancelled",
|
|
152
|
-
],
|
|
153
|
-
error: "Invalid Status",
|
|
154
|
-
array: false,
|
|
155
|
-
xdefault: "pending",
|
|
156
|
-
}),
|
|
157
|
-
];
|
|
158
|
-
|
|
159
|
-
const currentOperationsConfig = CollectionCreateSchema.parse({
|
|
160
|
-
name: "CurrentOperations",
|
|
161
|
-
enabled: true,
|
|
162
|
-
documentSecurity: false,
|
|
163
|
-
attributes: [],
|
|
164
|
-
indexes: [],
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
const batchesAttributes: Attribute[] = [
|
|
168
|
-
attributeSchema.parse({
|
|
169
|
-
key: "data",
|
|
170
|
-
type: "string",
|
|
171
|
-
size: 1073741824,
|
|
172
|
-
error: "Invalid Data",
|
|
173
|
-
required: true,
|
|
174
|
-
array: false,
|
|
175
|
-
}),
|
|
176
|
-
attributeSchema.parse({
|
|
177
|
-
key: "processed",
|
|
178
|
-
type: "boolean",
|
|
179
|
-
error: "Invalid Processed",
|
|
180
|
-
required: true,
|
|
181
|
-
array: false,
|
|
182
|
-
xdefault: false,
|
|
183
|
-
}),
|
|
184
|
-
];
|
|
185
|
-
|
|
186
|
-
const batchesConfig = CollectionCreateSchema.parse({
|
|
187
|
-
name: "Batches",
|
|
188
|
-
enabled: true,
|
|
189
|
-
documentSecurity: false,
|
|
190
|
-
attributes: [],
|
|
191
|
-
indexes: [],
|
|
192
|
-
});
|
|
193
|
-
|
|
194
|
-
const toReturn = {
|
|
195
|
-
CurrentOperations: {
|
|
196
|
-
collection: currentOperationsConfig,
|
|
197
|
-
attributes: currentOperationsAttributes,
|
|
198
|
-
},
|
|
199
|
-
Batches: {
|
|
200
|
-
collection: batchesConfig,
|
|
201
|
-
attributes: batchesAttributes,
|
|
202
|
-
},
|
|
203
|
-
};
|
|
204
|
-
return toReturn;
|
|
205
|
-
};
|
|
@@ -1,409 +0,0 @@
|
|
|
1
|
-
import type { Index } from "appwrite-utils";
|
|
2
|
-
import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
|
|
3
|
-
import type { Models } from "node-appwrite";
|
|
4
|
-
import { isIndexEqualToIndex } from "../collections/tableOperations.js";
|
|
5
|
-
import { MessageFormatter } from "../shared/messageFormatter.js";
|
|
6
|
-
import { delay, tryAwaitWithRetry } from "../utils/helperFunctions.js";
|
|
7
|
-
|
|
8
|
-
// Enhanced index operation interfaces
|
|
9
|
-
export interface IndexOperation {
|
|
10
|
-
type: 'create' | 'update' | 'skip' | 'delete';
|
|
11
|
-
index: Index;
|
|
12
|
-
existingIndex?: Models.Index;
|
|
13
|
-
reason?: string;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export interface IndexOperationPlan {
|
|
17
|
-
toCreate: IndexOperation[];
|
|
18
|
-
toUpdate: IndexOperation[];
|
|
19
|
-
toSkip: IndexOperation[];
|
|
20
|
-
toDelete: IndexOperation[];
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
export interface IndexExecutionResult {
|
|
24
|
-
created: string[];
|
|
25
|
-
updated: string[];
|
|
26
|
-
skipped: string[];
|
|
27
|
-
deleted: string[];
|
|
28
|
-
errors: Array<{ key: string; error: string }>;
|
|
29
|
-
summary: {
|
|
30
|
-
total: number;
|
|
31
|
-
created: number;
|
|
32
|
-
updated: number;
|
|
33
|
-
skipped: number;
|
|
34
|
-
deleted: number;
|
|
35
|
-
errors: number;
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Plan index operations by comparing desired indexes with existing ones
|
|
41
|
-
* Uses the existing isIndexEqualToIndex function for consistent comparison
|
|
42
|
-
*/
|
|
43
|
-
export function planIndexOperations(
|
|
44
|
-
desiredIndexes: Index[],
|
|
45
|
-
existingIndexes: Models.Index[]
|
|
46
|
-
): IndexOperationPlan {
|
|
47
|
-
const plan: IndexOperationPlan = {
|
|
48
|
-
toCreate: [],
|
|
49
|
-
toUpdate: [],
|
|
50
|
-
toSkip: [],
|
|
51
|
-
toDelete: []
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
for (const desiredIndex of desiredIndexes) {
|
|
55
|
-
const existingIndex = existingIndexes.find(idx => idx.key === desiredIndex.key);
|
|
56
|
-
|
|
57
|
-
if (!existingIndex) {
|
|
58
|
-
// Index doesn't exist - create it
|
|
59
|
-
plan.toCreate.push({
|
|
60
|
-
type: 'create',
|
|
61
|
-
index: desiredIndex,
|
|
62
|
-
reason: 'New index'
|
|
63
|
-
});
|
|
64
|
-
} else if (isIndexEqualToIndex(existingIndex, desiredIndex)) {
|
|
65
|
-
// Index exists and is identical - skip it
|
|
66
|
-
plan.toSkip.push({
|
|
67
|
-
type: 'skip',
|
|
68
|
-
index: desiredIndex,
|
|
69
|
-
existingIndex,
|
|
70
|
-
reason: 'Index unchanged'
|
|
71
|
-
});
|
|
72
|
-
} else {
|
|
73
|
-
// Index exists but is different - update it
|
|
74
|
-
plan.toUpdate.push({
|
|
75
|
-
type: 'update',
|
|
76
|
-
index: desiredIndex,
|
|
77
|
-
existingIndex,
|
|
78
|
-
reason: 'Index configuration changed'
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
return plan;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* Plan index deletions for indexes that exist but aren't in the desired configuration
|
|
88
|
-
*/
|
|
89
|
-
export function planIndexDeletions(
|
|
90
|
-
desiredIndexKeys: Set<string>,
|
|
91
|
-
existingIndexes: Models.Index[]
|
|
92
|
-
): IndexOperation[] {
|
|
93
|
-
const deletions: IndexOperation[] = [];
|
|
94
|
-
|
|
95
|
-
for (const existingIndex of existingIndexes) {
|
|
96
|
-
if (!desiredIndexKeys.has(existingIndex.key)) {
|
|
97
|
-
deletions.push({
|
|
98
|
-
type: 'delete',
|
|
99
|
-
index: existingIndex as Index, // Convert Models.Index to Index for compatibility
|
|
100
|
-
reason: 'Obsolete index'
|
|
101
|
-
});
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
return deletions;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Execute index operations with proper error handling and status monitoring
|
|
110
|
-
*/
|
|
111
|
-
export async function executeIndexOperations(
|
|
112
|
-
adapter: DatabaseAdapter,
|
|
113
|
-
databaseId: string,
|
|
114
|
-
tableId: string,
|
|
115
|
-
plan: IndexOperationPlan
|
|
116
|
-
): Promise<IndexExecutionResult> {
|
|
117
|
-
const result: IndexExecutionResult = {
|
|
118
|
-
created: [],
|
|
119
|
-
updated: [],
|
|
120
|
-
skipped: [],
|
|
121
|
-
deleted: [],
|
|
122
|
-
errors: [],
|
|
123
|
-
summary: {
|
|
124
|
-
total: 0,
|
|
125
|
-
created: 0,
|
|
126
|
-
updated: 0,
|
|
127
|
-
skipped: 0,
|
|
128
|
-
deleted: 0,
|
|
129
|
-
errors: 0
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
|
|
133
|
-
// Execute creates
|
|
134
|
-
for (const operation of plan.toCreate) {
|
|
135
|
-
try {
|
|
136
|
-
await adapter.createIndex({
|
|
137
|
-
databaseId,
|
|
138
|
-
tableId,
|
|
139
|
-
key: operation.index.key,
|
|
140
|
-
type: operation.index.type,
|
|
141
|
-
attributes: operation.index.attributes,
|
|
142
|
-
orders: operation.index.orders || []
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
result.created.push(operation.index.key);
|
|
146
|
-
MessageFormatter.success(`Created index ${operation.index.key}`, { prefix: 'Indexes' });
|
|
147
|
-
|
|
148
|
-
// Wait for index to become available
|
|
149
|
-
await waitForIndexAvailable(adapter, databaseId, tableId, operation.index.key);
|
|
150
|
-
|
|
151
|
-
await delay(150); // Brief delay between operations
|
|
152
|
-
} catch (error) {
|
|
153
|
-
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
154
|
-
result.errors.push({ key: operation.index.key, error: errorMessage });
|
|
155
|
-
MessageFormatter.error(`Failed to create index ${operation.index.key}`, error instanceof Error ? error : new Error(String(error)), { prefix: 'Indexes' });
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// Execute updates (delete + recreate)
|
|
160
|
-
for (const operation of plan.toUpdate) {
|
|
161
|
-
try {
|
|
162
|
-
// Delete existing index first
|
|
163
|
-
await adapter.deleteIndex({
|
|
164
|
-
databaseId,
|
|
165
|
-
tableId,
|
|
166
|
-
key: operation.index.key
|
|
167
|
-
});
|
|
168
|
-
|
|
169
|
-
await delay(100); // Brief delay for deletion to settle
|
|
170
|
-
|
|
171
|
-
// Create new index
|
|
172
|
-
await adapter.createIndex({
|
|
173
|
-
databaseId,
|
|
174
|
-
tableId,
|
|
175
|
-
key: operation.index.key,
|
|
176
|
-
type: operation.index.type,
|
|
177
|
-
attributes: operation.index.attributes,
|
|
178
|
-
orders: operation.index.orders || operation.existingIndex?.orders || []
|
|
179
|
-
});
|
|
180
|
-
|
|
181
|
-
result.updated.push(operation.index.key);
|
|
182
|
-
MessageFormatter.success(`Updated index ${operation.index.key}`, { prefix: 'Indexes' });
|
|
183
|
-
|
|
184
|
-
// Wait for index to become available
|
|
185
|
-
await waitForIndexAvailable(adapter, databaseId, tableId, operation.index.key);
|
|
186
|
-
|
|
187
|
-
await delay(150); // Brief delay between operations
|
|
188
|
-
} catch (error) {
|
|
189
|
-
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
190
|
-
result.errors.push({ key: operation.index.key, error: errorMessage });
|
|
191
|
-
MessageFormatter.error(`Failed to update index ${operation.index.key}`, error instanceof Error ? error : new Error(String(error)), { prefix: 'Indexes' });
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
// Execute skips
|
|
196
|
-
for (const operation of plan.toSkip) {
|
|
197
|
-
result.skipped.push(operation.index.key);
|
|
198
|
-
MessageFormatter.info(`Index ${operation.index.key} unchanged`, { prefix: 'Indexes' });
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
// Calculate summary
|
|
202
|
-
result.summary.total = result.created.length + result.updated.length + result.skipped.length + result.deleted.length;
|
|
203
|
-
result.summary.created = result.created.length;
|
|
204
|
-
result.summary.updated = result.updated.length;
|
|
205
|
-
result.summary.skipped = result.skipped.length;
|
|
206
|
-
result.summary.deleted = result.deleted.length;
|
|
207
|
-
result.summary.errors = result.errors.length;
|
|
208
|
-
|
|
209
|
-
return result;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
/**
|
|
213
|
-
* Execute index deletions with proper error handling
|
|
214
|
-
*/
|
|
215
|
-
export async function executeIndexDeletions(
|
|
216
|
-
adapter: DatabaseAdapter,
|
|
217
|
-
databaseId: string,
|
|
218
|
-
tableId: string,
|
|
219
|
-
deletions: IndexOperation[]
|
|
220
|
-
): Promise<{ deleted: string[]; errors: Array<{ key: string; error: string }> }> {
|
|
221
|
-
const result = {
|
|
222
|
-
deleted: [] as string[],
|
|
223
|
-
errors: [] as Array<{ key: string; error: string }>
|
|
224
|
-
};
|
|
225
|
-
|
|
226
|
-
for (const operation of deletions) {
|
|
227
|
-
try {
|
|
228
|
-
await adapter.deleteIndex({
|
|
229
|
-
databaseId,
|
|
230
|
-
tableId,
|
|
231
|
-
key: operation.index.key
|
|
232
|
-
});
|
|
233
|
-
|
|
234
|
-
result.deleted.push(operation.index.key);
|
|
235
|
-
MessageFormatter.info(`Deleted obsolete index ${operation.index.key}`, { prefix: 'Indexes' });
|
|
236
|
-
|
|
237
|
-
// Wait briefly for deletion to settle
|
|
238
|
-
await delay(500);
|
|
239
|
-
} catch (error) {
|
|
240
|
-
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
241
|
-
result.errors.push({ key: operation.index.key, error: errorMessage });
|
|
242
|
-
MessageFormatter.error(`Failed to delete index ${operation.index.key}`, error instanceof Error ? error : new Error(String(error)), { prefix: 'Indexes' });
|
|
243
|
-
}
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
return result;
|
|
247
|
-
}
|
|
248
|
-
|
|
249
|
-
/**
|
|
250
|
-
* Wait for an index to become available with timeout and retry logic
|
|
251
|
-
* This is an adapter-aware version of the logic from collections/indexes.ts
|
|
252
|
-
*/
|
|
253
|
-
async function waitForIndexAvailable(
|
|
254
|
-
adapter: DatabaseAdapter,
|
|
255
|
-
databaseId: string,
|
|
256
|
-
tableId: string,
|
|
257
|
-
indexKey: string,
|
|
258
|
-
maxWaitTime: number = 60000, // 1 minute
|
|
259
|
-
checkInterval: number = 2000 // 2 seconds
|
|
260
|
-
): Promise<boolean> {
|
|
261
|
-
const startTime = Date.now();
|
|
262
|
-
|
|
263
|
-
while (Date.now() - startTime < maxWaitTime) {
|
|
264
|
-
try {
|
|
265
|
-
const indexList = await adapter.listIndexes({ databaseId, tableId });
|
|
266
|
-
const indexes: any[] = (indexList as any).data || (indexList as any).indexes || [];
|
|
267
|
-
const index = indexes.find((idx: any) => idx.key === indexKey);
|
|
268
|
-
|
|
269
|
-
if (!index) {
|
|
270
|
-
MessageFormatter.error(`Index '${indexKey}' not found after creation`, undefined, { prefix: 'Indexes' });
|
|
271
|
-
return false;
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
switch (index.status) {
|
|
275
|
-
case 'available':
|
|
276
|
-
return true;
|
|
277
|
-
|
|
278
|
-
case 'failed':
|
|
279
|
-
MessageFormatter.error(`Index '${indexKey}' failed: ${index.error || 'unknown error'}`, undefined, { prefix: 'Indexes' });
|
|
280
|
-
return false;
|
|
281
|
-
|
|
282
|
-
case 'stuck':
|
|
283
|
-
MessageFormatter.warning(`Index '${indexKey}' is stuck`, { prefix: 'Indexes' });
|
|
284
|
-
return false;
|
|
285
|
-
|
|
286
|
-
case 'processing':
|
|
287
|
-
case 'deleting':
|
|
288
|
-
// Continue waiting
|
|
289
|
-
break;
|
|
290
|
-
|
|
291
|
-
default:
|
|
292
|
-
MessageFormatter.warning(`Unknown status '${index.status}' for index '${indexKey}'`, { prefix: 'Indexes' });
|
|
293
|
-
break;
|
|
294
|
-
}
|
|
295
|
-
} catch (error) {
|
|
296
|
-
MessageFormatter.error(`Error checking index '${indexKey}' status: ${error}`, undefined, { prefix: 'Indexes' });
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
await delay(checkInterval);
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
MessageFormatter.warning(`Timeout waiting for index '${indexKey}' to become available (${maxWaitTime}ms)`, { prefix: 'Indexes' });
|
|
303
|
-
return false;
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
/**
|
|
307
|
-
* Main function to create/update indexes via adapter
|
|
308
|
-
* This replaces the messy inline code in methods.ts
|
|
309
|
-
*/
|
|
310
|
-
export async function createOrUpdateIndexesViaAdapter(
|
|
311
|
-
adapter: DatabaseAdapter,
|
|
312
|
-
databaseId: string,
|
|
313
|
-
tableId: string,
|
|
314
|
-
desiredIndexes: Index[],
|
|
315
|
-
configIndexes?: Index[]
|
|
316
|
-
): Promise<void> {
|
|
317
|
-
if (!desiredIndexes || desiredIndexes.length === 0) {
|
|
318
|
-
MessageFormatter.info('No indexes to process', { prefix: 'Indexes' });
|
|
319
|
-
return;
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
MessageFormatter.info(`Processing ${desiredIndexes.length} indexes for table ${tableId}`, { prefix: 'Indexes' });
|
|
323
|
-
|
|
324
|
-
try {
|
|
325
|
-
// Get existing indexes
|
|
326
|
-
const existingIdxRes = await adapter.listIndexes({ databaseId, tableId });
|
|
327
|
-
const existingIndexes: Models.Index[] = (existingIdxRes as any).data || (existingIdxRes as any).indexes || [];
|
|
328
|
-
|
|
329
|
-
// Plan operations
|
|
330
|
-
const plan = planIndexOperations(desiredIndexes, existingIndexes);
|
|
331
|
-
|
|
332
|
-
// Show plan with icons (consistent with attribute handling)
|
|
333
|
-
const planParts: string[] = [];
|
|
334
|
-
if (plan.toCreate.length) planParts.push(`➕ ${plan.toCreate.length} (${plan.toCreate.map(op => op.index.key).join(', ')})`);
|
|
335
|
-
if (plan.toUpdate.length) planParts.push(`🔧 ${plan.toUpdate.length} (${plan.toUpdate.map(op => op.index.key).join(', ')})`);
|
|
336
|
-
if (plan.toSkip.length) planParts.push(`⏭️ ${plan.toSkip.length}`);
|
|
337
|
-
|
|
338
|
-
MessageFormatter.info(`Plan → ${planParts.join(' | ') || 'no changes'}`, { prefix: 'Indexes' });
|
|
339
|
-
|
|
340
|
-
// Execute operations
|
|
341
|
-
const result = await executeIndexOperations(adapter, databaseId, tableId, plan);
|
|
342
|
-
|
|
343
|
-
// Show summary
|
|
344
|
-
MessageFormatter.info(
|
|
345
|
-
`Summary → ➕ ${result.summary.created} | 🔧 ${result.summary.updated} | ⏭️ ${result.summary.skipped}`,
|
|
346
|
-
{ prefix: 'Indexes' }
|
|
347
|
-
);
|
|
348
|
-
|
|
349
|
-
// Handle errors if any
|
|
350
|
-
if (result.errors.length > 0) {
|
|
351
|
-
MessageFormatter.error(`${result.errors.length} index operations failed:`, undefined, { prefix: 'Indexes' });
|
|
352
|
-
for (const error of result.errors) {
|
|
353
|
-
MessageFormatter.error(` ${error.key}: ${error.error}`, undefined, { prefix: 'Indexes' });
|
|
354
|
-
}
|
|
355
|
-
}
|
|
356
|
-
|
|
357
|
-
} catch (error) {
|
|
358
|
-
MessageFormatter.error('Failed to process indexes', error instanceof Error ? error : new Error(String(error)), { prefix: 'Indexes' });
|
|
359
|
-
throw error;
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
/**
|
|
364
|
-
* Handle index deletions for obsolete indexes
|
|
365
|
-
*/
|
|
366
|
-
export async function deleteObsoleteIndexesViaAdapter(
|
|
367
|
-
adapter: DatabaseAdapter,
|
|
368
|
-
databaseId: string,
|
|
369
|
-
tableId: string,
|
|
370
|
-
desiredIndexKeys: Set<string>
|
|
371
|
-
): Promise<void> {
|
|
372
|
-
try {
|
|
373
|
-
// Get existing indexes
|
|
374
|
-
const existingIdxRes = await adapter.listIndexes({ databaseId, tableId });
|
|
375
|
-
const existingIndexes: Models.Index[] = (existingIdxRes as any).data || (existingIdxRes as any).indexes || [];
|
|
376
|
-
|
|
377
|
-
// Plan deletions
|
|
378
|
-
const deletions = planIndexDeletions(desiredIndexKeys, existingIndexes);
|
|
379
|
-
|
|
380
|
-
if (deletions.length === 0) {
|
|
381
|
-
MessageFormatter.info('Plan → 🗑️ 0 indexes', { prefix: 'Indexes' });
|
|
382
|
-
return;
|
|
383
|
-
}
|
|
384
|
-
|
|
385
|
-
// Show deletion plan
|
|
386
|
-
MessageFormatter.info(
|
|
387
|
-
`Plan → 🗑️ ${deletions.length} (${deletions.map(op => op.index.key).join(', ')})`,
|
|
388
|
-
{ prefix: 'Indexes' }
|
|
389
|
-
);
|
|
390
|
-
|
|
391
|
-
// Execute deletions
|
|
392
|
-
const result = await executeIndexDeletions(adapter, databaseId, tableId, deletions);
|
|
393
|
-
|
|
394
|
-
// Show results
|
|
395
|
-
if (result.deleted.length > 0) {
|
|
396
|
-
MessageFormatter.success(`Deleted ${result.deleted.length} indexes: ${result.deleted.join(', ')}`, { prefix: 'Indexes' });
|
|
397
|
-
}
|
|
398
|
-
|
|
399
|
-
if (result.errors.length > 0) {
|
|
400
|
-
MessageFormatter.error(`${result.errors.length} index deletions failed:`, undefined, { prefix: 'Indexes' });
|
|
401
|
-
for (const error of result.errors) {
|
|
402
|
-
MessageFormatter.error(` ${error.key}: ${error.error}`, undefined, { prefix: 'Indexes' });
|
|
403
|
-
}
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
} catch (error) {
|
|
407
|
-
MessageFormatter.warning(`Could not evaluate index deletions: ${(error as Error)?.message || error}`, { prefix: 'Indexes' });
|
|
408
|
-
}
|
|
409
|
-
}
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Type declarations for optional node-appwrite-tablesdb module
|
|
3
|
-
* This allows compilation when the module is not installed
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
declare module 'node-appwrite-tablesdb' {
|
|
7
|
-
export class Client {
|
|
8
|
-
setEndpoint(endpoint: string): this;
|
|
9
|
-
setProject(project: string): this;
|
|
10
|
-
setKey(key: string): this;
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export class TablesDB {
|
|
14
|
-
constructor(client: Client);
|
|
15
|
-
|
|
16
|
-
// Core methods based on TablesDB API
|
|
17
|
-
listTables(databaseId: string, queries?: any[]): Promise<any>;
|
|
18
|
-
createTable(databaseId: string, id: string, name: string, permissions?: string[], documentSecurity?: boolean, enabled?: boolean): Promise<any>;
|
|
19
|
-
updateTable(databaseId: string, id: string, name: string, permissions?: string[], documentSecurity?: boolean, enabled?: boolean): Promise<any>;
|
|
20
|
-
deleteTable(databaseId: string, tableId: string): Promise<void>;
|
|
21
|
-
getTable(databaseId: string, tableId: string): Promise<any>;
|
|
22
|
-
|
|
23
|
-
listRows(databaseId: string, tableId: string, queries?: any[]): Promise<any>;
|
|
24
|
-
createRow(databaseId: string, tableId: string, id: string, data: any, permissions?: string[]): Promise<any>;
|
|
25
|
-
updateRow(databaseId: string, tableId: string, id: string, data?: any, permissions?: string[]): Promise<any>;
|
|
26
|
-
deleteRow(databaseId: string, tableId: string, id: string): Promise<void>;
|
|
27
|
-
getRow(databaseId: string, tableId: string, id: string): Promise<any>;
|
|
28
|
-
|
|
29
|
-
// Bulk operations (if supported)
|
|
30
|
-
bulkCreateRows?(databaseId: string, tableId: string, rows: any[]): Promise<any>;
|
|
31
|
-
bulkUpsertRows?(databaseId: string, tableId: string, rows: any[]): Promise<any>;
|
|
32
|
-
bulkDeleteRows?(databaseId: string, tableId: string, rowIds: string[]): Promise<any>;
|
|
33
|
-
|
|
34
|
-
// Index operations
|
|
35
|
-
listIndexes(databaseId: string, tableId: string, queries?: any[]): Promise<any>;
|
|
36
|
-
createIndex(databaseId: string, tableId: string, key: string, type: string, attributes: string[], orders?: string[]): Promise<any>;
|
|
37
|
-
deleteIndex(databaseId: string, tableId: string, key: string): Promise<void>;
|
|
38
|
-
|
|
39
|
-
// Attribute operations
|
|
40
|
-
createAttribute(databaseId: string, tableId: string, key: string, type: string, ...args: any[]): Promise<any>;
|
|
41
|
-
updateAttribute(databaseId: string, tableId: string, key: string, required?: boolean, defaultValue?: any): Promise<any>;
|
|
42
|
-
deleteAttribute(databaseId: string, tableId: string, key: string): Promise<void>;
|
|
43
|
-
}
|
|
44
|
-
}
|
package/src/types.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export type { ValidationRules } from "./utils/validationRules.js";
|
|
2
|
-
export {
|
|
3
|
-
type AuthUserCreate,
|
|
4
|
-
AuthUserCreateSchema,
|
|
5
|
-
type AuthUser,
|
|
6
|
-
AuthUserSchema,
|
|
7
|
-
} from "./schemas/authUser.js";
|
|
8
|
-
export { validationRules } from "./utils/validationRules.js";
|
|
9
|
-
export { afterImportActions } from "./migrations/afterImportActions.js";
|