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/users/methods.ts
DELETED
|
@@ -1,359 +0,0 @@
|
|
|
1
|
-
import type { AppwriteConfig, ConfigCollection } from "appwrite-utils";
|
|
2
|
-
import {
|
|
3
|
-
AppwriteException,
|
|
4
|
-
Databases,
|
|
5
|
-
ID,
|
|
6
|
-
Query,
|
|
7
|
-
Users,
|
|
8
|
-
type Models,
|
|
9
|
-
} from "node-appwrite";
|
|
10
|
-
import {
|
|
11
|
-
AuthUserSchema,
|
|
12
|
-
type AuthUser,
|
|
13
|
-
type AuthUserCreate,
|
|
14
|
-
} from "../schemas/authUser.js";
|
|
15
|
-
import { logger } from "../shared/logging.js";
|
|
16
|
-
import { splitIntoBatches } from "../shared/migrationHelpers.js";
|
|
17
|
-
import {
|
|
18
|
-
getAppwriteClient,
|
|
19
|
-
tryAwaitWithRetry,
|
|
20
|
-
} from "../utils/helperFunctions.js";
|
|
21
|
-
import { isUndefined } from "es-toolkit/compat";
|
|
22
|
-
import { isEmpty } from "es-toolkit/compat";
|
|
23
|
-
import { MessageFormatter } from "../shared/messageFormatter.js";
|
|
24
|
-
|
|
25
|
-
export class UsersController {
|
|
26
|
-
private config: AppwriteConfig;
|
|
27
|
-
private users: Users;
|
|
28
|
-
static userFields = [
|
|
29
|
-
"email",
|
|
30
|
-
"name",
|
|
31
|
-
"password",
|
|
32
|
-
"phone",
|
|
33
|
-
"labels",
|
|
34
|
-
"prefs",
|
|
35
|
-
"userId",
|
|
36
|
-
"$createdAt",
|
|
37
|
-
"$updatedAt",
|
|
38
|
-
];
|
|
39
|
-
|
|
40
|
-
constructor(config: AppwriteConfig, db: Databases) {
|
|
41
|
-
this.config = config;
|
|
42
|
-
this.users = new Users(this.config.appwriteClient!);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
async wipeUsers() {
|
|
46
|
-
const allUsers = await this.getAllUsers();
|
|
47
|
-
MessageFormatter.progress("Deleting all users...", { prefix: "Users" });
|
|
48
|
-
|
|
49
|
-
const createBatches = (finalData: any[], batchSize: number) => {
|
|
50
|
-
const finalBatches: any[][] = [];
|
|
51
|
-
for (let i = 0; i < finalData.length; i += batchSize) {
|
|
52
|
-
finalBatches.push(finalData.slice(i, i + batchSize));
|
|
53
|
-
}
|
|
54
|
-
return finalBatches;
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
let usersDeleted = 0;
|
|
58
|
-
if (allUsers.length > 0) {
|
|
59
|
-
const batchedUserPromises = createBatches(allUsers, 25); // Batch size of 25
|
|
60
|
-
|
|
61
|
-
for (const batch of batchedUserPromises) {
|
|
62
|
-
MessageFormatter.progress(`Deleting ${batch.length} users...`, { prefix: "Users" });
|
|
63
|
-
await Promise.all(
|
|
64
|
-
batch.map((user) =>
|
|
65
|
-
tryAwaitWithRetry(async () => await this.users.delete(user.$id))
|
|
66
|
-
)
|
|
67
|
-
);
|
|
68
|
-
usersDeleted += batch.length;
|
|
69
|
-
if (usersDeleted % 100 === 0) {
|
|
70
|
-
MessageFormatter.progress(`Deleted ${usersDeleted} users...`, { prefix: "Users" });
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
} else {
|
|
74
|
-
MessageFormatter.info("No users to delete", { prefix: "Users" });
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
async getAllUsers() {
|
|
79
|
-
const allUsers: Models.User<Models.Preferences>[] = [];
|
|
80
|
-
const users = await tryAwaitWithRetry(
|
|
81
|
-
async () => await this.users.list([Query.limit(200)])
|
|
82
|
-
);
|
|
83
|
-
if (users.users.length === 0) {
|
|
84
|
-
return [];
|
|
85
|
-
}
|
|
86
|
-
if (users.users.length === 200) {
|
|
87
|
-
let lastDocumentId = users.users[users.users.length - 1].$id;
|
|
88
|
-
allUsers.push(...users.users);
|
|
89
|
-
while (lastDocumentId) {
|
|
90
|
-
const moreUsers = await tryAwaitWithRetry(
|
|
91
|
-
async () =>
|
|
92
|
-
await this.users.list([
|
|
93
|
-
Query.limit(200),
|
|
94
|
-
Query.cursorAfter(lastDocumentId),
|
|
95
|
-
])
|
|
96
|
-
);
|
|
97
|
-
allUsers.push(...moreUsers.users);
|
|
98
|
-
if (moreUsers.users.length < 200) {
|
|
99
|
-
break;
|
|
100
|
-
}
|
|
101
|
-
lastDocumentId = moreUsers.users[moreUsers.users.length - 1].$id;
|
|
102
|
-
}
|
|
103
|
-
} else {
|
|
104
|
-
allUsers.push(...users.users);
|
|
105
|
-
}
|
|
106
|
-
return allUsers;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
async createUsersAndReturn(items: AuthUserCreate[]): Promise<any[]> {
|
|
110
|
-
const users = await Promise.all(
|
|
111
|
-
items.map((item) => this.createUserAndReturn(item))
|
|
112
|
-
);
|
|
113
|
-
return users;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
async createUserAndReturn(item: AuthUserCreate): Promise<any> {
|
|
117
|
-
try {
|
|
118
|
-
const user = await tryAwaitWithRetry(async () => {
|
|
119
|
-
const createdUser = await this.users.create(
|
|
120
|
-
item.userId || ID.unique(),
|
|
121
|
-
item.email || undefined,
|
|
122
|
-
item.phone && item.phone.length < 15 && item.phone.startsWith("+")
|
|
123
|
-
? item.phone
|
|
124
|
-
: undefined,
|
|
125
|
-
`changeMe${item.email?.toLowerCase()}` || `changeMePlease`,
|
|
126
|
-
item.name || undefined
|
|
127
|
-
);
|
|
128
|
-
|
|
129
|
-
if (item.labels) {
|
|
130
|
-
await this.users.updateLabels(createdUser.$id, item.labels);
|
|
131
|
-
}
|
|
132
|
-
if (item.prefs) {
|
|
133
|
-
await this.users.updatePrefs(createdUser.$id, item.prefs);
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
return createdUser;
|
|
137
|
-
}); // Set throwError to true since we want to handle errors
|
|
138
|
-
|
|
139
|
-
return user;
|
|
140
|
-
} catch (e) {
|
|
141
|
-
if (e instanceof Error) {
|
|
142
|
-
logger.error("FAILED CREATING USER: ", e.message, item);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
async createAndCheckForUserAndReturn(item: AuthUserCreate) {
|
|
148
|
-
let userToReturn: Models.User<Models.Preferences> | undefined = undefined;
|
|
149
|
-
try {
|
|
150
|
-
// Attempt to find an existing user by email or phone.
|
|
151
|
-
let foundUsers: Models.User<Models.Preferences>[] = [];
|
|
152
|
-
if (item.email) {
|
|
153
|
-
const foundUsersByEmail = await this.users.list([
|
|
154
|
-
Query.equal("email", item.email),
|
|
155
|
-
]);
|
|
156
|
-
foundUsers = foundUsersByEmail.users;
|
|
157
|
-
}
|
|
158
|
-
if (item.phone) {
|
|
159
|
-
const foundUsersByPhone = await this.users.list([
|
|
160
|
-
Query.equal("phone", item.phone),
|
|
161
|
-
]);
|
|
162
|
-
foundUsers = foundUsers.length
|
|
163
|
-
? foundUsers.concat(foundUsersByPhone.users)
|
|
164
|
-
: foundUsersByPhone.users;
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
userToReturn = foundUsers[0] || undefined;
|
|
168
|
-
|
|
169
|
-
if (!userToReturn) {
|
|
170
|
-
userToReturn = await this.users.create(
|
|
171
|
-
item.userId || ID.unique(),
|
|
172
|
-
item.email || undefined,
|
|
173
|
-
item.phone && item.phone.length < 15 && item.phone.startsWith("+")
|
|
174
|
-
? item.phone
|
|
175
|
-
: undefined,
|
|
176
|
-
item.password?.toLowerCase() ||
|
|
177
|
-
`changeMe${item.email?.toLowerCase()}` ||
|
|
178
|
-
`changeMePlease`,
|
|
179
|
-
item.name || undefined
|
|
180
|
-
);
|
|
181
|
-
} else {
|
|
182
|
-
// Update user details as necessary, ensuring email uniqueness if attempting an update.
|
|
183
|
-
if (
|
|
184
|
-
item.email &&
|
|
185
|
-
item.email !== userToReturn.email &&
|
|
186
|
-
!isEmpty(item.email) &&
|
|
187
|
-
!isUndefined(item.email)
|
|
188
|
-
) {
|
|
189
|
-
const emailExists = await this.users.list([
|
|
190
|
-
Query.equal("email", item.email),
|
|
191
|
-
]);
|
|
192
|
-
if (emailExists.users.length === 0) {
|
|
193
|
-
userToReturn = await this.users.updateEmail(
|
|
194
|
-
userToReturn.$id,
|
|
195
|
-
item.email
|
|
196
|
-
);
|
|
197
|
-
} else {
|
|
198
|
-
MessageFormatter.warning("Email update skipped: Email already exists.", { prefix: "Users" });
|
|
199
|
-
}
|
|
200
|
-
}
|
|
201
|
-
if (item.password) {
|
|
202
|
-
userToReturn = await this.users.updatePassword(
|
|
203
|
-
userToReturn.$id,
|
|
204
|
-
item.password.toLowerCase()
|
|
205
|
-
);
|
|
206
|
-
}
|
|
207
|
-
if (item.name && item.name !== userToReturn.name) {
|
|
208
|
-
userToReturn = await this.users.updateName(
|
|
209
|
-
userToReturn.$id,
|
|
210
|
-
item.name
|
|
211
|
-
);
|
|
212
|
-
}
|
|
213
|
-
if (
|
|
214
|
-
item.phone &&
|
|
215
|
-
item.phone !== userToReturn.phone &&
|
|
216
|
-
item.phone.length < 15 &&
|
|
217
|
-
item.phone.startsWith("+") &&
|
|
218
|
-
(isUndefined(userToReturn.phone) || isEmpty(userToReturn.phone))
|
|
219
|
-
) {
|
|
220
|
-
const userFoundWithPhone = await this.users.list([
|
|
221
|
-
Query.equal("phone", item.phone),
|
|
222
|
-
]);
|
|
223
|
-
if (userFoundWithPhone.total === 0) {
|
|
224
|
-
userToReturn = await this.users.updatePhone(
|
|
225
|
-
userToReturn.$id,
|
|
226
|
-
item.phone
|
|
227
|
-
);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
if (item.$createdAt && item.$updatedAt) {
|
|
232
|
-
MessageFormatter.warning(
|
|
233
|
-
"$createdAt and $updatedAt are not yet supported, sorry about that!",
|
|
234
|
-
{ prefix: "Users" }
|
|
235
|
-
);
|
|
236
|
-
}
|
|
237
|
-
if (item.labels && item.labels.length) {
|
|
238
|
-
userToReturn = await this.users.updateLabels(
|
|
239
|
-
userToReturn.$id,
|
|
240
|
-
item.labels
|
|
241
|
-
);
|
|
242
|
-
}
|
|
243
|
-
if (item.prefs && Object.keys(item.prefs).length) {
|
|
244
|
-
await this.users.updatePrefs(userToReturn.$id, item.prefs);
|
|
245
|
-
userToReturn.prefs = item.prefs;
|
|
246
|
-
}
|
|
247
|
-
return userToReturn;
|
|
248
|
-
} catch (error) {
|
|
249
|
-
return userToReturn;
|
|
250
|
-
}
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
async getUserIdByEmailOrPhone(email?: string, phone?: string) {
|
|
254
|
-
if (!email && !phone) {
|
|
255
|
-
return undefined;
|
|
256
|
-
}
|
|
257
|
-
if (email && phone) {
|
|
258
|
-
const foundUsersByEmail = await this.users.list([
|
|
259
|
-
// @ts-ignore
|
|
260
|
-
Query.or([Query.equal("email", email), Query.equal("phone", phone)]),
|
|
261
|
-
]);
|
|
262
|
-
if (foundUsersByEmail.users.length > 0) {
|
|
263
|
-
return foundUsersByEmail.users[0]?.$id;
|
|
264
|
-
}
|
|
265
|
-
} else if (email) {
|
|
266
|
-
const foundUsersByEmail = await this.users.list([
|
|
267
|
-
Query.equal("email", email),
|
|
268
|
-
]);
|
|
269
|
-
if (foundUsersByEmail.users.length > 0) {
|
|
270
|
-
return foundUsersByEmail.users[0]?.$id;
|
|
271
|
-
} else {
|
|
272
|
-
if (!phone) {
|
|
273
|
-
return undefined;
|
|
274
|
-
} else {
|
|
275
|
-
const foundUsersByPhone = await this.users.list([
|
|
276
|
-
Query.equal("phone", phone),
|
|
277
|
-
]);
|
|
278
|
-
if (foundUsersByPhone.users.length > 0) {
|
|
279
|
-
return foundUsersByPhone.users[0]?.$id;
|
|
280
|
-
} else {
|
|
281
|
-
return undefined;
|
|
282
|
-
}
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
}
|
|
286
|
-
if (phone) {
|
|
287
|
-
const foundUsersByPhone = await this.users.list([
|
|
288
|
-
Query.equal("phone", phone),
|
|
289
|
-
]);
|
|
290
|
-
if (foundUsersByPhone.users.length > 0) {
|
|
291
|
-
return foundUsersByPhone.users[0]?.$id;
|
|
292
|
-
} else {
|
|
293
|
-
return undefined;
|
|
294
|
-
}
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
transferUsersBetweenDbsLocalToRemote = async (
|
|
299
|
-
endpoint: string,
|
|
300
|
-
projectId: string,
|
|
301
|
-
apiKey: string
|
|
302
|
-
) => {
|
|
303
|
-
const localUsers = this.users;
|
|
304
|
-
const client = getAppwriteClient(endpoint, projectId, apiKey);
|
|
305
|
-
const remoteUsers = new Users(client);
|
|
306
|
-
|
|
307
|
-
let fromUsers = await localUsers.list([Query.limit(50)]);
|
|
308
|
-
|
|
309
|
-
if (fromUsers.users.length === 0) {
|
|
310
|
-
MessageFormatter.info("No users found", { prefix: "Users" });
|
|
311
|
-
return;
|
|
312
|
-
} else if (fromUsers.users.length < 50) {
|
|
313
|
-
MessageFormatter.progress(`Transferring ${fromUsers.users.length} users to remote`, { prefix: "Users" });
|
|
314
|
-
const batchedPromises = fromUsers.users.map((user) => {
|
|
315
|
-
return tryAwaitWithRetry(async () => {
|
|
316
|
-
const toCreateObject: Partial<typeof user> = {
|
|
317
|
-
...user,
|
|
318
|
-
};
|
|
319
|
-
delete toCreateObject.$id;
|
|
320
|
-
delete toCreateObject.$createdAt;
|
|
321
|
-
delete toCreateObject.$updatedAt;
|
|
322
|
-
await remoteUsers.create(
|
|
323
|
-
user.$id,
|
|
324
|
-
user.email,
|
|
325
|
-
user.phone,
|
|
326
|
-
user.password,
|
|
327
|
-
user.name
|
|
328
|
-
);
|
|
329
|
-
});
|
|
330
|
-
});
|
|
331
|
-
await Promise.all(batchedPromises);
|
|
332
|
-
} else {
|
|
333
|
-
while (fromUsers.users.length === 50) {
|
|
334
|
-
fromUsers = await localUsers.list([
|
|
335
|
-
Query.limit(50),
|
|
336
|
-
Query.cursorAfter(fromUsers.users[fromUsers.users.length - 1].$id),
|
|
337
|
-
]);
|
|
338
|
-
const batchedPromises = fromUsers.users.map((user) => {
|
|
339
|
-
return tryAwaitWithRetry(async () => {
|
|
340
|
-
const toCreateObject: Partial<typeof user> = {
|
|
341
|
-
...user,
|
|
342
|
-
};
|
|
343
|
-
delete toCreateObject.$id;
|
|
344
|
-
delete toCreateObject.$createdAt;
|
|
345
|
-
delete toCreateObject.$updatedAt;
|
|
346
|
-
await remoteUsers.create(
|
|
347
|
-
user.$id,
|
|
348
|
-
user.email,
|
|
349
|
-
user.phone,
|
|
350
|
-
user.password,
|
|
351
|
-
user.name
|
|
352
|
-
);
|
|
353
|
-
});
|
|
354
|
-
});
|
|
355
|
-
await Promise.all(batchedPromises);
|
|
356
|
-
}
|
|
357
|
-
}
|
|
358
|
-
};
|
|
359
|
-
}
|
|
@@ -1,240 +0,0 @@
|
|
|
1
|
-
import { Client } from "node-appwrite";
|
|
2
|
-
import type { AppwriteConfig } from "appwrite-utils";
|
|
3
|
-
import { AdapterFactory } from "../adapters/AdapterFactory.js";
|
|
4
|
-
import type { DatabaseAdapter } from "../adapters/DatabaseAdapter.js";
|
|
5
|
-
import { logger } from "../shared/logging.js";
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Factory for creating authenticated Appwrite clients and database adapters.
|
|
9
|
-
*
|
|
10
|
-
* This factory provides a clean separation of concerns by taking pre-configured
|
|
11
|
-
* AppwriteConfig objects (with authentication already resolved by ConfigManager)
|
|
12
|
-
* and creating the necessary client and adapter instances.
|
|
13
|
-
*
|
|
14
|
-
* Key features:
|
|
15
|
-
* - Takes pre-authenticated config from ConfigManager
|
|
16
|
-
* - Creates client with appropriate authentication method
|
|
17
|
-
* - Creates adapter with automatic version detection
|
|
18
|
-
* - Leverages AdapterFactory's internal caching for performance
|
|
19
|
-
*
|
|
20
|
-
* @example
|
|
21
|
-
* ```typescript
|
|
22
|
-
* const configManager = ConfigManager.getInstance();
|
|
23
|
-
* const config = await configManager.loadConfig();
|
|
24
|
-
*
|
|
25
|
-
* // Config already has session or API key resolved
|
|
26
|
-
* const { client, adapter } = await ClientFactory.createFromConfig(config);
|
|
27
|
-
* ```
|
|
28
|
-
*/
|
|
29
|
-
export class ClientFactory {
|
|
30
|
-
/**
|
|
31
|
-
* Create authenticated client and database adapter from configuration.
|
|
32
|
-
*
|
|
33
|
-
* This method expects the config to have authentication already resolved:
|
|
34
|
-
* - Either `sessionCookie` is set (from ConfigManager's session loading)
|
|
35
|
-
* - Or `appwriteKey` is set (from config file or CLI overrides)
|
|
36
|
-
*
|
|
37
|
-
* The ConfigManager handles all session discovery and authentication priority,
|
|
38
|
-
* so this factory simply applies the resolved authentication to the client.
|
|
39
|
-
*
|
|
40
|
-
* @param config - AppwriteConfig with resolved authentication
|
|
41
|
-
* @returns Object containing authenticated client and database adapter
|
|
42
|
-
* @throws Error if no authentication method is available in config
|
|
43
|
-
*
|
|
44
|
-
* @example
|
|
45
|
-
* ```typescript
|
|
46
|
-
* const config = await ConfigManager.getInstance().loadConfig();
|
|
47
|
-
* const { client, adapter } = await ClientFactory.createFromConfig(config);
|
|
48
|
-
*
|
|
49
|
-
* // Client is now authenticated and ready to use
|
|
50
|
-
* const databases = new Databases(client);
|
|
51
|
-
* const collections = await adapter.listCollections(databaseId);
|
|
52
|
-
* ```
|
|
53
|
-
*/
|
|
54
|
-
public static async createFromConfig(
|
|
55
|
-
config: AppwriteConfig
|
|
56
|
-
): Promise<{ client: Client; adapter: DatabaseAdapter }> {
|
|
57
|
-
logger.debug("Creating client from config", {
|
|
58
|
-
prefix: "ClientFactory",
|
|
59
|
-
hasSession: !!config.sessionCookie,
|
|
60
|
-
hasApiKey: !!config.appwriteKey,
|
|
61
|
-
endpoint: config.appwriteEndpoint,
|
|
62
|
-
project: config.appwriteProject,
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
// Create base client with endpoint and project
|
|
66
|
-
const client = new Client()
|
|
67
|
-
.setEndpoint(config.appwriteEndpoint)
|
|
68
|
-
.setProject(config.appwriteProject);
|
|
69
|
-
|
|
70
|
-
// Apply authentication based on authMethod preference with mode headers
|
|
71
|
-
// Mode headers: "admin" for sessions (elevated permissions), "default" for API keys
|
|
72
|
-
const authMethod = config.authMethod || "auto";
|
|
73
|
-
|
|
74
|
-
logger.debug("Applying authentication with mode headers", {
|
|
75
|
-
prefix: "ClientFactory",
|
|
76
|
-
authMethod,
|
|
77
|
-
hasApiKey: !!config.appwriteKey,
|
|
78
|
-
hasSession: !!config.sessionCookie,
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
if (authMethod === "session") {
|
|
82
|
-
// Explicit session preference - use only session with admin mode
|
|
83
|
-
if (!config.sessionCookie) {
|
|
84
|
-
const error = new Error(
|
|
85
|
-
"authMethod set to 'session' but no session cookie available.\n\n" +
|
|
86
|
-
"Either:\n" +
|
|
87
|
-
" - Run 'appwrite login' to create a session\n" +
|
|
88
|
-
" - Change authMethod to 'apikey' or 'auto'\n" +
|
|
89
|
-
" - Provide --sessionCookie flag"
|
|
90
|
-
);
|
|
91
|
-
logger.error("Failed to create client - session required", { prefix: "ClientFactory" });
|
|
92
|
-
throw error;
|
|
93
|
-
}
|
|
94
|
-
client.setSession(config.sessionCookie);
|
|
95
|
-
client.headers['X-Appwrite-Mode'] = 'admin';
|
|
96
|
-
logger.debug("Applied session authentication with admin mode (explicit preference)", {
|
|
97
|
-
prefix: "ClientFactory",
|
|
98
|
-
email: config.sessionMetadata?.email,
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
} else if (authMethod === "apikey") {
|
|
102
|
-
// Explicit API key preference - use only API key with default mode
|
|
103
|
-
if (!config.appwriteKey || config.appwriteKey.trim().length === 0) {
|
|
104
|
-
const error = new Error(
|
|
105
|
-
"authMethod set to 'apikey' but no API key provided.\n\n" +
|
|
106
|
-
"Either:\n" +
|
|
107
|
-
" - Set appwriteKey in your config file\n" +
|
|
108
|
-
" - Provide --apiKey flag\n" +
|
|
109
|
-
" - Set APPWRITE_API_KEY environment variable"
|
|
110
|
-
);
|
|
111
|
-
logger.error("Failed to create client - API key required", { prefix: "ClientFactory" });
|
|
112
|
-
throw error;
|
|
113
|
-
}
|
|
114
|
-
client.setKey(config.appwriteKey);
|
|
115
|
-
client.headers['X-Appwrite-Mode'] = 'default';
|
|
116
|
-
logger.debug("Applied API key authentication with default mode (explicit preference)", {
|
|
117
|
-
prefix: "ClientFactory",
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
} else {
|
|
121
|
-
// Auto mode: Prefer session with admin mode (like official CLI), fallback to API key
|
|
122
|
-
if (config.sessionCookie) {
|
|
123
|
-
client.setSession(config.sessionCookie);
|
|
124
|
-
client.headers['X-Appwrite-Mode'] = 'admin';
|
|
125
|
-
logger.debug("Applied session authentication with admin mode (auto - preferred)", {
|
|
126
|
-
prefix: "ClientFactory",
|
|
127
|
-
email: config.sessionMetadata?.email,
|
|
128
|
-
});
|
|
129
|
-
} else if (config.appwriteKey && config.appwriteKey.trim().length > 0) {
|
|
130
|
-
client.setKey(config.appwriteKey);
|
|
131
|
-
client.headers['X-Appwrite-Mode'] = 'default';
|
|
132
|
-
logger.debug("Applied API key authentication with default mode (auto - fallback)", {
|
|
133
|
-
prefix: "ClientFactory",
|
|
134
|
-
});
|
|
135
|
-
} else {
|
|
136
|
-
// No authentication available
|
|
137
|
-
const error = new Error(
|
|
138
|
-
"No authentication method available in configuration.\n\n" +
|
|
139
|
-
"Expected either:\n" +
|
|
140
|
-
" - config.sessionCookie (from session authentication via 'appwrite login')\n" +
|
|
141
|
-
" - config.appwriteKey (from config file, CLI flags, or environment)\n\n" +
|
|
142
|
-
"Suggestion:\n" +
|
|
143
|
-
" - Run 'appwrite login' to create a session, OR\n" +
|
|
144
|
-
" - Add appwriteKey to your config file, OR\n" +
|
|
145
|
-
" - Provide --apiKey flag"
|
|
146
|
-
);
|
|
147
|
-
logger.error("Failed to create client - no authentication", { prefix: "ClientFactory" });
|
|
148
|
-
throw error;
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
// Create adapter with version detection
|
|
153
|
-
// AdapterFactory uses internal caching, so repeated calls are fast
|
|
154
|
-
logger.debug("Creating database adapter", {
|
|
155
|
-
prefix: "ClientFactory",
|
|
156
|
-
apiMode: config.apiMode || "auto",
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
const { adapter } = await AdapterFactory.createFromConfig(config);
|
|
160
|
-
|
|
161
|
-
logger.debug("Client and adapter created successfully", {
|
|
162
|
-
prefix: "ClientFactory",
|
|
163
|
-
adapterType: adapter.getApiMode(),
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
return { client, adapter };
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
/**
|
|
170
|
-
* Create client and adapter from individual parameters.
|
|
171
|
-
*
|
|
172
|
-
* This is a lower-level method for cases where you don't have a full
|
|
173
|
-
* AppwriteConfig object. For most use cases, prefer createFromConfig().
|
|
174
|
-
*
|
|
175
|
-
* @param endpoint - Appwrite endpoint URL
|
|
176
|
-
* @param project - Appwrite project ID
|
|
177
|
-
* @param options - Authentication and API mode options
|
|
178
|
-
* @returns Object containing authenticated client and database adapter
|
|
179
|
-
* @throws Error if no authentication method is provided
|
|
180
|
-
*
|
|
181
|
-
* @example
|
|
182
|
-
* ```typescript
|
|
183
|
-
* const { client, adapter } = await ClientFactory.create(
|
|
184
|
-
* "https://cloud.appwrite.io/v1",
|
|
185
|
-
* "my-project-id",
|
|
186
|
-
* {
|
|
187
|
-
* apiKey: "my-api-key",
|
|
188
|
-
* apiMode: "auto"
|
|
189
|
-
* }
|
|
190
|
-
* );
|
|
191
|
-
* ```
|
|
192
|
-
*/
|
|
193
|
-
public static async create(
|
|
194
|
-
endpoint: string,
|
|
195
|
-
project: string,
|
|
196
|
-
options: {
|
|
197
|
-
apiKey?: string;
|
|
198
|
-
sessionCookie?: string;
|
|
199
|
-
apiMode?: "auto" | "legacy" | "tablesdb";
|
|
200
|
-
} = {}
|
|
201
|
-
): Promise<{ client: Client; adapter: DatabaseAdapter }> {
|
|
202
|
-
logger.debug("Creating client from parameters", {
|
|
203
|
-
prefix: "ClientFactory",
|
|
204
|
-
hasSession: !!options.sessionCookie,
|
|
205
|
-
hasApiKey: !!options.apiKey,
|
|
206
|
-
endpoint,
|
|
207
|
-
project,
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
// Create minimal config object
|
|
211
|
-
const config: AppwriteConfig = {
|
|
212
|
-
appwriteEndpoint: endpoint,
|
|
213
|
-
appwriteProject: project,
|
|
214
|
-
appwriteKey: options.apiKey || "",
|
|
215
|
-
sessionCookie: options.sessionCookie,
|
|
216
|
-
apiMode: options.apiMode || "auto",
|
|
217
|
-
// Minimal required fields
|
|
218
|
-
appwriteClient: null,
|
|
219
|
-
authMethod: options.sessionCookie ? "session" : "apikey",
|
|
220
|
-
enableBackups: false,
|
|
221
|
-
backupInterval: 0,
|
|
222
|
-
backupRetention: 0,
|
|
223
|
-
enableBackupCleanup: false,
|
|
224
|
-
enableMockData: false,
|
|
225
|
-
documentBucketId: "",
|
|
226
|
-
usersCollectionName: "",
|
|
227
|
-
databases: [],
|
|
228
|
-
buckets: [],
|
|
229
|
-
functions: [],
|
|
230
|
-
logging: {
|
|
231
|
-
enabled: false,
|
|
232
|
-
level: "info",
|
|
233
|
-
console: false,
|
|
234
|
-
},
|
|
235
|
-
};
|
|
236
|
-
|
|
237
|
-
// Use main createFromConfig method
|
|
238
|
-
return this.createFromConfig(config);
|
|
239
|
-
}
|
|
240
|
-
}
|