@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,175 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { attributeSchema, parseAttribute, CollectionCreateSchema, } from "@njdamstra/appwrite-utils";
|
|
3
|
+
export const BackupSchema = z.object({
|
|
4
|
+
$id: z.string(),
|
|
5
|
+
$createdAt: z.string(),
|
|
6
|
+
$updatedAt: z.string(),
|
|
7
|
+
database: z.string(),
|
|
8
|
+
collections: z.array(z.string()),
|
|
9
|
+
documents: z
|
|
10
|
+
.array(z.object({
|
|
11
|
+
collectionId: z.string(),
|
|
12
|
+
data: z.string(),
|
|
13
|
+
}))
|
|
14
|
+
.default([]),
|
|
15
|
+
});
|
|
16
|
+
export const BackupCreateSchema = BackupSchema.omit({
|
|
17
|
+
$id: true,
|
|
18
|
+
$createdAt: true,
|
|
19
|
+
$updatedAt: true,
|
|
20
|
+
});
|
|
21
|
+
export const BatchSchema = z.object({
|
|
22
|
+
$id: z.string(),
|
|
23
|
+
$createdAt: z.string(),
|
|
24
|
+
$updatedAt: z.string(),
|
|
25
|
+
data: z.string().describe("The serialized data for this batch"),
|
|
26
|
+
processed: z
|
|
27
|
+
.boolean()
|
|
28
|
+
.default(false)
|
|
29
|
+
.describe("Whether the batch has been processed"),
|
|
30
|
+
});
|
|
31
|
+
export const BatchCreateSchema = BatchSchema.omit({
|
|
32
|
+
$id: true,
|
|
33
|
+
$createdAt: true,
|
|
34
|
+
$updatedAt: true,
|
|
35
|
+
});
|
|
36
|
+
export const OperationSchema = z.object({
|
|
37
|
+
$id: z.string(),
|
|
38
|
+
$createdAt: z.string(),
|
|
39
|
+
$updatedAt: z.string(),
|
|
40
|
+
operationType: z.string(),
|
|
41
|
+
collectionId: z.string(),
|
|
42
|
+
data: z.any(),
|
|
43
|
+
batches: z.array(z.string()).default([]).optional(),
|
|
44
|
+
progress: z.number(),
|
|
45
|
+
total: z.number(),
|
|
46
|
+
error: z.string(),
|
|
47
|
+
status: z
|
|
48
|
+
.enum([
|
|
49
|
+
"pending",
|
|
50
|
+
"ready",
|
|
51
|
+
"in_progress",
|
|
52
|
+
"completed",
|
|
53
|
+
"error",
|
|
54
|
+
"cancelled",
|
|
55
|
+
])
|
|
56
|
+
.default("pending"),
|
|
57
|
+
});
|
|
58
|
+
export const OperationCreateSchema = OperationSchema.omit({
|
|
59
|
+
$id: true,
|
|
60
|
+
$createdAt: true,
|
|
61
|
+
$updatedAt: true,
|
|
62
|
+
});
|
|
63
|
+
export const getMigrationCollectionSchemas = () => {
|
|
64
|
+
const currentOperationsAttributes = [
|
|
65
|
+
parseAttribute({
|
|
66
|
+
key: "operationType",
|
|
67
|
+
type: "string",
|
|
68
|
+
error: "Invalid Operation Type",
|
|
69
|
+
size: 50,
|
|
70
|
+
required: true,
|
|
71
|
+
array: false,
|
|
72
|
+
xdefault: null,
|
|
73
|
+
}),
|
|
74
|
+
attributeSchema.parse({
|
|
75
|
+
key: "collectionId",
|
|
76
|
+
type: "string",
|
|
77
|
+
error: "Invalid Collection Id",
|
|
78
|
+
size: 50,
|
|
79
|
+
array: false,
|
|
80
|
+
xdefault: null,
|
|
81
|
+
}),
|
|
82
|
+
attributeSchema.parse({
|
|
83
|
+
key: "batches",
|
|
84
|
+
type: "string",
|
|
85
|
+
error: "Invalid Batches",
|
|
86
|
+
size: 1073741824,
|
|
87
|
+
array: true,
|
|
88
|
+
}),
|
|
89
|
+
attributeSchema.parse({
|
|
90
|
+
key: "data",
|
|
91
|
+
type: "string",
|
|
92
|
+
error: "Invalid Data",
|
|
93
|
+
size: 1073741824,
|
|
94
|
+
}),
|
|
95
|
+
attributeSchema.parse({
|
|
96
|
+
key: "progress",
|
|
97
|
+
type: "integer",
|
|
98
|
+
error: "Invalid Progress",
|
|
99
|
+
required: true,
|
|
100
|
+
array: false,
|
|
101
|
+
}),
|
|
102
|
+
attributeSchema.parse({
|
|
103
|
+
key: "total",
|
|
104
|
+
type: "integer",
|
|
105
|
+
error: "Invalid Total",
|
|
106
|
+
required: true,
|
|
107
|
+
array: false,
|
|
108
|
+
}),
|
|
109
|
+
attributeSchema.parse({
|
|
110
|
+
key: "error",
|
|
111
|
+
type: "string",
|
|
112
|
+
error: "Operation Error",
|
|
113
|
+
required: false,
|
|
114
|
+
array: false,
|
|
115
|
+
}),
|
|
116
|
+
attributeSchema.parse({
|
|
117
|
+
key: "status",
|
|
118
|
+
type: "enum",
|
|
119
|
+
elements: [
|
|
120
|
+
"pending",
|
|
121
|
+
"ready",
|
|
122
|
+
"in_progress",
|
|
123
|
+
"completed",
|
|
124
|
+
"error",
|
|
125
|
+
"cancelled",
|
|
126
|
+
],
|
|
127
|
+
error: "Invalid Status",
|
|
128
|
+
array: false,
|
|
129
|
+
xdefault: "pending",
|
|
130
|
+
}),
|
|
131
|
+
];
|
|
132
|
+
const currentOperationsConfig = CollectionCreateSchema.parse({
|
|
133
|
+
name: "CurrentOperations",
|
|
134
|
+
enabled: true,
|
|
135
|
+
documentSecurity: false,
|
|
136
|
+
attributes: [],
|
|
137
|
+
indexes: [],
|
|
138
|
+
});
|
|
139
|
+
const batchesAttributes = [
|
|
140
|
+
attributeSchema.parse({
|
|
141
|
+
key: "data",
|
|
142
|
+
type: "string",
|
|
143
|
+
size: 1073741824,
|
|
144
|
+
error: "Invalid Data",
|
|
145
|
+
required: true,
|
|
146
|
+
array: false,
|
|
147
|
+
}),
|
|
148
|
+
attributeSchema.parse({
|
|
149
|
+
key: "processed",
|
|
150
|
+
type: "boolean",
|
|
151
|
+
error: "Invalid Processed",
|
|
152
|
+
required: true,
|
|
153
|
+
array: false,
|
|
154
|
+
xdefault: false,
|
|
155
|
+
}),
|
|
156
|
+
];
|
|
157
|
+
const batchesConfig = CollectionCreateSchema.parse({
|
|
158
|
+
name: "Batches",
|
|
159
|
+
enabled: true,
|
|
160
|
+
documentSecurity: false,
|
|
161
|
+
attributes: [],
|
|
162
|
+
indexes: [],
|
|
163
|
+
});
|
|
164
|
+
const toReturn = {
|
|
165
|
+
CurrentOperations: {
|
|
166
|
+
collection: currentOperationsConfig,
|
|
167
|
+
attributes: currentOperationsAttributes,
|
|
168
|
+
},
|
|
169
|
+
Batches: {
|
|
170
|
+
collection: batchesConfig,
|
|
171
|
+
attributes: batchesAttributes,
|
|
172
|
+
},
|
|
173
|
+
};
|
|
174
|
+
return toReturn;
|
|
175
|
+
};
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export type { ValidationRules } from "./utils/validationRules.js";
|
|
2
|
+
export { type AuthUserCreate, AuthUserCreateSchema, type AuthUser, AuthUserSchema, } from "./schemas/authUser.js";
|
|
3
|
+
export { validationRules } from "./utils/validationRules.js";
|
|
4
|
+
export { afterImportActions } from "./migrations/afterImportActions.js";
|
package/dist/types.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { AppwriteConfig } from "@njdamstra/appwrite-utils";
|
|
2
|
+
import { Databases, type Models } from "node-appwrite";
|
|
3
|
+
import { type AuthUserCreate } from "../schemas/authUser.js";
|
|
4
|
+
export declare class UsersController {
|
|
5
|
+
private config;
|
|
6
|
+
private users;
|
|
7
|
+
static userFields: string[];
|
|
8
|
+
constructor(config: AppwriteConfig, db: Databases);
|
|
9
|
+
wipeUsers(): Promise<void>;
|
|
10
|
+
getAllUsers(): Promise<Models.User<Models.Preferences>[]>;
|
|
11
|
+
createUsersAndReturn(items: AuthUserCreate[]): Promise<any[]>;
|
|
12
|
+
createUserAndReturn(item: AuthUserCreate): Promise<any>;
|
|
13
|
+
createAndCheckForUserAndReturn(item: AuthUserCreate): Promise<Models.User<Models.Preferences> | undefined>;
|
|
14
|
+
getUserIdByEmailOrPhone(email?: string, phone?: string): Promise<string | undefined>;
|
|
15
|
+
transferUsersBetweenDbsLocalToRemote: (endpoint: string, projectId: string, apiKey: string) => Promise<void>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
import { AppwriteException, Databases, ID, Query, Users, } from "node-appwrite";
|
|
2
|
+
import { AuthUserSchema, } from "../schemas/authUser.js";
|
|
3
|
+
import { logger } from "../shared/logging.js";
|
|
4
|
+
import { splitIntoBatches } from "../shared/migrationHelpers.js";
|
|
5
|
+
import { getAppwriteClient, tryAwaitWithRetry, } from "../utils/helperFunctions.js";
|
|
6
|
+
import { isUndefined } from "es-toolkit/compat";
|
|
7
|
+
import { isEmpty } from "es-toolkit/compat";
|
|
8
|
+
import { MessageFormatter } from "../shared/messageFormatter.js";
|
|
9
|
+
export class UsersController {
|
|
10
|
+
config;
|
|
11
|
+
users;
|
|
12
|
+
static userFields = [
|
|
13
|
+
"email",
|
|
14
|
+
"name",
|
|
15
|
+
"password",
|
|
16
|
+
"phone",
|
|
17
|
+
"labels",
|
|
18
|
+
"prefs",
|
|
19
|
+
"userId",
|
|
20
|
+
"$createdAt",
|
|
21
|
+
"$updatedAt",
|
|
22
|
+
];
|
|
23
|
+
constructor(config, db) {
|
|
24
|
+
this.config = config;
|
|
25
|
+
this.users = new Users(this.config.appwriteClient);
|
|
26
|
+
}
|
|
27
|
+
async wipeUsers() {
|
|
28
|
+
const allUsers = await this.getAllUsers();
|
|
29
|
+
MessageFormatter.progress("Deleting all users...", { prefix: "Users" });
|
|
30
|
+
const createBatches = (finalData, batchSize) => {
|
|
31
|
+
const finalBatches = [];
|
|
32
|
+
for (let i = 0; i < finalData.length; i += batchSize) {
|
|
33
|
+
finalBatches.push(finalData.slice(i, i + batchSize));
|
|
34
|
+
}
|
|
35
|
+
return finalBatches;
|
|
36
|
+
};
|
|
37
|
+
let usersDeleted = 0;
|
|
38
|
+
if (allUsers.length > 0) {
|
|
39
|
+
const batchedUserPromises = createBatches(allUsers, 25); // Batch size of 25
|
|
40
|
+
for (const batch of batchedUserPromises) {
|
|
41
|
+
MessageFormatter.progress(`Deleting ${batch.length} users...`, { prefix: "Users" });
|
|
42
|
+
await Promise.all(batch.map((user) => tryAwaitWithRetry(async () => await this.users.delete(user.$id))));
|
|
43
|
+
usersDeleted += batch.length;
|
|
44
|
+
if (usersDeleted % 100 === 0) {
|
|
45
|
+
MessageFormatter.progress(`Deleted ${usersDeleted} users...`, { prefix: "Users" });
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
MessageFormatter.info("No users to delete", { prefix: "Users" });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
async getAllUsers() {
|
|
54
|
+
const allUsers = [];
|
|
55
|
+
const users = await tryAwaitWithRetry(async () => await this.users.list([Query.limit(200)]));
|
|
56
|
+
if (users.users.length === 0) {
|
|
57
|
+
return [];
|
|
58
|
+
}
|
|
59
|
+
if (users.users.length === 200) {
|
|
60
|
+
let lastDocumentId = users.users[users.users.length - 1].$id;
|
|
61
|
+
allUsers.push(...users.users);
|
|
62
|
+
while (lastDocumentId) {
|
|
63
|
+
const moreUsers = await tryAwaitWithRetry(async () => await this.users.list([
|
|
64
|
+
Query.limit(200),
|
|
65
|
+
Query.cursorAfter(lastDocumentId),
|
|
66
|
+
]));
|
|
67
|
+
allUsers.push(...moreUsers.users);
|
|
68
|
+
if (moreUsers.users.length < 200) {
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
71
|
+
lastDocumentId = moreUsers.users[moreUsers.users.length - 1].$id;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
allUsers.push(...users.users);
|
|
76
|
+
}
|
|
77
|
+
return allUsers;
|
|
78
|
+
}
|
|
79
|
+
async createUsersAndReturn(items) {
|
|
80
|
+
const users = await Promise.all(items.map((item) => this.createUserAndReturn(item)));
|
|
81
|
+
return users;
|
|
82
|
+
}
|
|
83
|
+
async createUserAndReturn(item) {
|
|
84
|
+
try {
|
|
85
|
+
const user = await tryAwaitWithRetry(async () => {
|
|
86
|
+
const createdUser = await this.users.create(item.userId || ID.unique(), item.email || undefined, item.phone && item.phone.length < 15 && item.phone.startsWith("+")
|
|
87
|
+
? item.phone
|
|
88
|
+
: undefined, `changeMe${item.email?.toLowerCase()}` || `changeMePlease`, item.name || undefined);
|
|
89
|
+
if (item.labels) {
|
|
90
|
+
await this.users.updateLabels(createdUser.$id, item.labels);
|
|
91
|
+
}
|
|
92
|
+
if (item.prefs) {
|
|
93
|
+
await this.users.updatePrefs(createdUser.$id, item.prefs);
|
|
94
|
+
}
|
|
95
|
+
return createdUser;
|
|
96
|
+
}); // Set throwError to true since we want to handle errors
|
|
97
|
+
return user;
|
|
98
|
+
}
|
|
99
|
+
catch (e) {
|
|
100
|
+
if (e instanceof Error) {
|
|
101
|
+
logger.error("FAILED CREATING USER: ", e.message, item);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
async createAndCheckForUserAndReturn(item) {
|
|
106
|
+
let userToReturn = undefined;
|
|
107
|
+
try {
|
|
108
|
+
// Attempt to find an existing user by email or phone.
|
|
109
|
+
let foundUsers = [];
|
|
110
|
+
if (item.email) {
|
|
111
|
+
const foundUsersByEmail = await this.users.list([
|
|
112
|
+
Query.equal("email", item.email),
|
|
113
|
+
]);
|
|
114
|
+
foundUsers = foundUsersByEmail.users;
|
|
115
|
+
}
|
|
116
|
+
if (item.phone) {
|
|
117
|
+
const foundUsersByPhone = await this.users.list([
|
|
118
|
+
Query.equal("phone", item.phone),
|
|
119
|
+
]);
|
|
120
|
+
foundUsers = foundUsers.length
|
|
121
|
+
? foundUsers.concat(foundUsersByPhone.users)
|
|
122
|
+
: foundUsersByPhone.users;
|
|
123
|
+
}
|
|
124
|
+
userToReturn = foundUsers[0] || undefined;
|
|
125
|
+
if (!userToReturn) {
|
|
126
|
+
userToReturn = await this.users.create(item.userId || ID.unique(), item.email || undefined, item.phone && item.phone.length < 15 && item.phone.startsWith("+")
|
|
127
|
+
? item.phone
|
|
128
|
+
: undefined, item.password?.toLowerCase() ||
|
|
129
|
+
`changeMe${item.email?.toLowerCase()}` ||
|
|
130
|
+
`changeMePlease`, item.name || undefined);
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
// Update user details as necessary, ensuring email uniqueness if attempting an update.
|
|
134
|
+
if (item.email &&
|
|
135
|
+
item.email !== userToReturn.email &&
|
|
136
|
+
!isEmpty(item.email) &&
|
|
137
|
+
!isUndefined(item.email)) {
|
|
138
|
+
const emailExists = await this.users.list([
|
|
139
|
+
Query.equal("email", item.email),
|
|
140
|
+
]);
|
|
141
|
+
if (emailExists.users.length === 0) {
|
|
142
|
+
userToReturn = await this.users.updateEmail(userToReturn.$id, item.email);
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
MessageFormatter.warning("Email update skipped: Email already exists.", { prefix: "Users" });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
if (item.password) {
|
|
149
|
+
userToReturn = await this.users.updatePassword(userToReturn.$id, item.password.toLowerCase());
|
|
150
|
+
}
|
|
151
|
+
if (item.name && item.name !== userToReturn.name) {
|
|
152
|
+
userToReturn = await this.users.updateName(userToReturn.$id, item.name);
|
|
153
|
+
}
|
|
154
|
+
if (item.phone &&
|
|
155
|
+
item.phone !== userToReturn.phone &&
|
|
156
|
+
item.phone.length < 15 &&
|
|
157
|
+
item.phone.startsWith("+") &&
|
|
158
|
+
(isUndefined(userToReturn.phone) || isEmpty(userToReturn.phone))) {
|
|
159
|
+
const userFoundWithPhone = await this.users.list([
|
|
160
|
+
Query.equal("phone", item.phone),
|
|
161
|
+
]);
|
|
162
|
+
if (userFoundWithPhone.total === 0) {
|
|
163
|
+
userToReturn = await this.users.updatePhone(userToReturn.$id, item.phone);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
if (item.$createdAt && item.$updatedAt) {
|
|
168
|
+
MessageFormatter.warning("$createdAt and $updatedAt are not yet supported, sorry about that!", { prefix: "Users" });
|
|
169
|
+
}
|
|
170
|
+
if (item.labels && item.labels.length) {
|
|
171
|
+
userToReturn = await this.users.updateLabels(userToReturn.$id, item.labels);
|
|
172
|
+
}
|
|
173
|
+
if (item.prefs && Object.keys(item.prefs).length) {
|
|
174
|
+
await this.users.updatePrefs(userToReturn.$id, item.prefs);
|
|
175
|
+
userToReturn.prefs = item.prefs;
|
|
176
|
+
}
|
|
177
|
+
return userToReturn;
|
|
178
|
+
}
|
|
179
|
+
catch (error) {
|
|
180
|
+
return userToReturn;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
async getUserIdByEmailOrPhone(email, phone) {
|
|
184
|
+
if (!email && !phone) {
|
|
185
|
+
return undefined;
|
|
186
|
+
}
|
|
187
|
+
if (email && phone) {
|
|
188
|
+
const foundUsersByEmail = await this.users.list([
|
|
189
|
+
// @ts-ignore
|
|
190
|
+
Query.or([Query.equal("email", email), Query.equal("phone", phone)]),
|
|
191
|
+
]);
|
|
192
|
+
if (foundUsersByEmail.users.length > 0) {
|
|
193
|
+
return foundUsersByEmail.users[0]?.$id;
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
else if (email) {
|
|
197
|
+
const foundUsersByEmail = await this.users.list([
|
|
198
|
+
Query.equal("email", email),
|
|
199
|
+
]);
|
|
200
|
+
if (foundUsersByEmail.users.length > 0) {
|
|
201
|
+
return foundUsersByEmail.users[0]?.$id;
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
if (!phone) {
|
|
205
|
+
return undefined;
|
|
206
|
+
}
|
|
207
|
+
else {
|
|
208
|
+
const foundUsersByPhone = await this.users.list([
|
|
209
|
+
Query.equal("phone", phone),
|
|
210
|
+
]);
|
|
211
|
+
if (foundUsersByPhone.users.length > 0) {
|
|
212
|
+
return foundUsersByPhone.users[0]?.$id;
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
return undefined;
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
if (phone) {
|
|
221
|
+
const foundUsersByPhone = await this.users.list([
|
|
222
|
+
Query.equal("phone", phone),
|
|
223
|
+
]);
|
|
224
|
+
if (foundUsersByPhone.users.length > 0) {
|
|
225
|
+
return foundUsersByPhone.users[0]?.$id;
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
return undefined;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
transferUsersBetweenDbsLocalToRemote = async (endpoint, projectId, apiKey) => {
|
|
233
|
+
const localUsers = this.users;
|
|
234
|
+
const client = getAppwriteClient(endpoint, projectId, apiKey);
|
|
235
|
+
const remoteUsers = new Users(client);
|
|
236
|
+
let fromUsers = await localUsers.list([Query.limit(50)]);
|
|
237
|
+
if (fromUsers.users.length === 0) {
|
|
238
|
+
MessageFormatter.info("No users found", { prefix: "Users" });
|
|
239
|
+
return;
|
|
240
|
+
}
|
|
241
|
+
else if (fromUsers.users.length < 50) {
|
|
242
|
+
MessageFormatter.progress(`Transferring ${fromUsers.users.length} users to remote`, { prefix: "Users" });
|
|
243
|
+
const batchedPromises = fromUsers.users.map((user) => {
|
|
244
|
+
return tryAwaitWithRetry(async () => {
|
|
245
|
+
const toCreateObject = {
|
|
246
|
+
...user,
|
|
247
|
+
};
|
|
248
|
+
delete toCreateObject.$id;
|
|
249
|
+
delete toCreateObject.$createdAt;
|
|
250
|
+
delete toCreateObject.$updatedAt;
|
|
251
|
+
await remoteUsers.create(user.$id, user.email, user.phone, user.password, user.name);
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
await Promise.all(batchedPromises);
|
|
255
|
+
}
|
|
256
|
+
else {
|
|
257
|
+
while (fromUsers.users.length === 50) {
|
|
258
|
+
fromUsers = await localUsers.list([
|
|
259
|
+
Query.limit(50),
|
|
260
|
+
Query.cursorAfter(fromUsers.users[fromUsers.users.length - 1].$id),
|
|
261
|
+
]);
|
|
262
|
+
const batchedPromises = fromUsers.users.map((user) => {
|
|
263
|
+
return tryAwaitWithRetry(async () => {
|
|
264
|
+
const toCreateObject = {
|
|
265
|
+
...user,
|
|
266
|
+
};
|
|
267
|
+
delete toCreateObject.$id;
|
|
268
|
+
delete toCreateObject.$createdAt;
|
|
269
|
+
delete toCreateObject.$updatedAt;
|
|
270
|
+
await remoteUsers.create(user.$id, user.email, user.phone, user.password, user.name);
|
|
271
|
+
});
|
|
272
|
+
});
|
|
273
|
+
await Promise.all(batchedPromises);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
};
|
|
277
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { Client } from "node-appwrite";
|
|
2
|
+
import type { AppwriteConfig } from "@njdamstra/appwrite-utils";
|
|
3
|
+
import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
|
|
4
|
+
/**
|
|
5
|
+
* Factory for creating authenticated Appwrite clients and database adapters.
|
|
6
|
+
*
|
|
7
|
+
* This factory provides a clean separation of concerns by taking pre-configured
|
|
8
|
+
* AppwriteConfig objects (with authentication already resolved by ConfigManager)
|
|
9
|
+
* and creating the necessary client and adapter instances.
|
|
10
|
+
*
|
|
11
|
+
* Key features:
|
|
12
|
+
* - Takes pre-authenticated config from ConfigManager
|
|
13
|
+
* - Creates client with appropriate authentication method
|
|
14
|
+
* - Creates adapter with automatic version detection
|
|
15
|
+
* - Leverages AdapterFactory's internal caching for performance
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```typescript
|
|
19
|
+
* const configManager = ConfigManager.getInstance();
|
|
20
|
+
* const config = await configManager.loadConfig();
|
|
21
|
+
*
|
|
22
|
+
* // Config already has session or API key resolved
|
|
23
|
+
* const { client, adapter } = await ClientFactory.createFromConfig(config);
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare class ClientFactory {
|
|
27
|
+
/**
|
|
28
|
+
* Create authenticated client and database adapter from configuration.
|
|
29
|
+
*
|
|
30
|
+
* This method expects the config to have authentication already resolved:
|
|
31
|
+
* - Either `sessionCookie` is set (from ConfigManager's session loading)
|
|
32
|
+
* - Or `appwriteKey` is set (from config file or CLI overrides)
|
|
33
|
+
*
|
|
34
|
+
* The ConfigManager handles all session discovery and authentication priority,
|
|
35
|
+
* so this factory simply applies the resolved authentication to the client.
|
|
36
|
+
*
|
|
37
|
+
* @param config - AppwriteConfig with resolved authentication
|
|
38
|
+
* @returns Object containing authenticated client and database adapter
|
|
39
|
+
* @throws Error if no authentication method is available in config
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* const config = await ConfigManager.getInstance().loadConfig();
|
|
44
|
+
* const { client, adapter } = await ClientFactory.createFromConfig(config);
|
|
45
|
+
*
|
|
46
|
+
* // Client is now authenticated and ready to use
|
|
47
|
+
* const databases = new Databases(client);
|
|
48
|
+
* const collections = await adapter.listCollections(databaseId);
|
|
49
|
+
* ```
|
|
50
|
+
*/
|
|
51
|
+
static createFromConfig(config: AppwriteConfig): Promise<{
|
|
52
|
+
client: Client;
|
|
53
|
+
adapter: DatabaseAdapter;
|
|
54
|
+
}>;
|
|
55
|
+
/**
|
|
56
|
+
* Create client and adapter from individual parameters.
|
|
57
|
+
*
|
|
58
|
+
* This is a lower-level method for cases where you don't have a full
|
|
59
|
+
* AppwriteConfig object. For most use cases, prefer createFromConfig().
|
|
60
|
+
*
|
|
61
|
+
* @param endpoint - Appwrite endpoint URL
|
|
62
|
+
* @param project - Appwrite project ID
|
|
63
|
+
* @param options - Authentication and API mode options
|
|
64
|
+
* @returns Object containing authenticated client and database adapter
|
|
65
|
+
* @throws Error if no authentication method is provided
|
|
66
|
+
*
|
|
67
|
+
* @example
|
|
68
|
+
* ```typescript
|
|
69
|
+
* const { client, adapter } = await ClientFactory.create(
|
|
70
|
+
* "https://cloud.appwrite.io/v1",
|
|
71
|
+
* "my-project-id",
|
|
72
|
+
* {
|
|
73
|
+
* apiKey: "my-api-key",
|
|
74
|
+
* apiMode: "auto"
|
|
75
|
+
* }
|
|
76
|
+
* );
|
|
77
|
+
* ```
|
|
78
|
+
*/
|
|
79
|
+
static create(endpoint: string, project: string, options?: {
|
|
80
|
+
apiKey?: string;
|
|
81
|
+
sessionCookie?: string;
|
|
82
|
+
apiMode?: "auto" | "legacy" | "tablesdb";
|
|
83
|
+
}): Promise<{
|
|
84
|
+
client: Client;
|
|
85
|
+
adapter: DatabaseAdapter;
|
|
86
|
+
}>;
|
|
87
|
+
}
|