@njdamstra/appwrite-utils-cli 1.8.9 → 1.10.1
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 +16 -0
- package/CONFIG_TODO.md +1189 -0
- package/SELECTION_DIALOGS.md +146 -0
- package/SERVICE_IMPLEMENTATION_REPORT.md +462 -0
- 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.d.ts +1 -0
- package/dist/cli/commands/databaseCommands.js +119 -9
- 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 +1 -1
- package/dist/collections/attributes.js +85 -35
- package/dist/collections/indexes.js +2 -4
- package/dist/collections/methods.d.ts +1 -1
- package/dist/collections/methods.js +111 -192
- package/dist/collections/tableOperations.d.ts +1 -0
- package/dist/collections/tableOperations.js +90 -23
- 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 +5 -5
- package/dist/functions/fnConfigDiscovery.js +2 -2
- package/dist/functions/methods.js +16 -4
- package/dist/init.js +1 -1
- package/dist/interactiveCLI.d.ts +6 -1
- package/dist/interactiveCLI.js +64 -10
- package/dist/main.js +130 -177
- package/dist/migrations/afterImportActions.js +2 -3
- package/dist/migrations/appwriteToX.d.ts +97 -1
- package/dist/migrations/appwriteToX.js +9 -7
- package/dist/migrations/comprehensiveTransfer.js +3 -5
- package/dist/migrations/dataLoader.d.ts +194 -2
- package/dist/migrations/dataLoader.js +2 -5
- package/dist/migrations/importController.js +3 -4
- 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.js +4 -4
- 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 +106 -55
- package/dist/migrations/yaml/YamlImportConfigLoader.js +1 -1
- package/dist/migrations/yaml/YamlImportIntegration.js +2 -2
- package/dist/migrations/yaml/generateImportSchemas.js +1 -1
- 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 +3 -3
- package/dist/shared/operationQueue.d.ts +1 -1
- package/dist/shared/operationQueue.js +2 -3
- package/dist/shared/operationsTable.d.ts +1 -1
- package/dist/shared/operationsTable.js +2 -2
- package/dist/shared/progressManager.js +1 -1
- package/dist/shared/selectionDialogs.js +9 -8
- package/dist/storage/methods.js +4 -4
- package/dist/storage/schemas.d.ts +386 -2
- package/dist/tables/indexManager.d.ts +65 -0
- package/dist/tables/indexManager.js +294 -0
- 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 +5 -7
- package/dist/utilsController.d.ts +15 -8
- package/dist/utilsController.js +57 -28
- package/package.json +8 -4
- package/src/adapters/index.ts +8 -34
- package/src/backups/operations/bucketBackup.ts +2 -2
- package/src/backups/operations/collectionBackup.ts +4 -4
- package/src/backups/operations/comprehensiveBackup.ts +3 -3
- package/src/backups/tracking/centralizedTracking.ts +3 -3
- package/src/cli/commands/configCommands.ts +72 -8
- package/src/cli/commands/databaseCommands.ts +161 -9
- package/src/cli/commands/functionCommands.ts +4 -3
- package/src/cli/commands/importFileCommands.ts +815 -0
- package/src/cli/commands/schemaCommands.ts +3 -3
- package/src/cli/commands/storageCommands.ts +2 -3
- package/src/cli/commands/transferCommands.ts +3 -6
- package/src/collections/attributes.ts +155 -39
- package/src/collections/indexes.ts +5 -7
- package/src/collections/methods.ts +115 -150
- package/src/collections/tableOperations.ts +92 -21
- package/src/collections/transferOperations.ts +4 -5
- package/src/collections/wipeOperations.ts +154 -51
- package/src/databases/methods.ts +2 -2
- package/src/databases/setup.ts +2 -2
- package/src/examples/yamlTerminologyExample.ts +2 -2
- package/src/functions/deployments.ts +6 -5
- package/src/functions/fnConfigDiscovery.ts +2 -2
- package/src/functions/methods.ts +19 -6
- package/src/init.ts +1 -1
- package/src/interactiveCLI.ts +78 -13
- package/src/main.ts +143 -287
- package/src/migrations/afterImportActions.ts +2 -3
- package/src/migrations/appwriteToX.ts +12 -8
- package/src/migrations/comprehensiveTransfer.ts +6 -6
- package/src/migrations/dataLoader.ts +2 -5
- package/src/migrations/importController.ts +3 -4
- package/src/migrations/importDataActions.ts +3 -3
- package/src/migrations/relationships.ts +1 -2
- package/src/migrations/services/DataTransformationService.ts +2 -2
- package/src/migrations/services/FileHandlerService.ts +1 -1
- package/src/migrations/services/ImportOrchestrator.ts +4 -4
- package/src/migrations/services/RateLimitManager.ts +1 -1
- package/src/migrations/services/RelationshipResolver.ts +1 -1
- package/src/migrations/services/UserMappingService.ts +1 -1
- package/src/migrations/services/ValidationService.ts +1 -1
- package/src/migrations/transfer.ts +126 -83
- package/src/migrations/yaml/YamlImportConfigLoader.ts +1 -1
- package/src/migrations/yaml/YamlImportIntegration.ts +2 -2
- package/src/migrations/yaml/generateImportSchemas.ts +1 -1
- package/src/setupCommands.ts +5 -6
- package/src/setupController.ts +1 -1
- package/src/shared/backupTracking.ts +3 -3
- package/src/shared/confirmationDialogs.ts +1 -1
- package/src/shared/migrationHelpers.ts +4 -4
- package/src/shared/operationQueue.ts +3 -4
- package/src/shared/operationsTable.ts +3 -3
- package/src/shared/progressManager.ts +1 -1
- package/src/shared/selectionDialogs.ts +9 -8
- package/src/storage/methods.ts +4 -4
- package/src/tables/indexManager.ts +409 -0
- package/src/types.ts +2 -2
- package/src/users/methods.ts +2 -3
- package/src/utils/configMigration.ts +1 -1
- package/src/utils/index.ts +1 -1
- package/src/utils/loadConfigs.ts +15 -7
- package/src/utils/setupFiles.ts +5 -7
- package/src/utilsController.ts +86 -32
- package/dist/adapters/AdapterFactory.d.ts +0 -94
- package/dist/adapters/AdapterFactory.js +0 -405
- package/dist/adapters/DatabaseAdapter.d.ts +0 -233
- package/dist/adapters/DatabaseAdapter.js +0 -50
- package/dist/adapters/LegacyAdapter.d.ts +0 -50
- package/dist/adapters/LegacyAdapter.js +0 -612
- package/dist/adapters/TablesDBAdapter.d.ts +0 -45
- package/dist/adapters/TablesDBAdapter.js +0 -571
- package/dist/config/ConfigManager.d.ts +0 -445
- package/dist/config/ConfigManager.js +0 -625
- 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 -126
- package/dist/config/services/ConfigDiscoveryService.js +0 -374
- package/dist/config/services/ConfigLoaderService.d.ts +0 -129
- package/dist/config/services/ConfigLoaderService.js +0 -540
- 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/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 -336
- package/dist/shared/indexManager.d.ts +0 -24
- package/dist/shared/indexManager.js +0 -151
- 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 -119
- package/dist/utils/projectConfig.js +0 -171
- 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/src/adapters/AdapterFactory.ts +0 -510
- package/src/adapters/DatabaseAdapter.ts +0 -306
- package/src/adapters/LegacyAdapter.ts +0 -841
- package/src/adapters/TablesDBAdapter.ts +0 -773
- package/src/config/ConfigManager.ts +0 -808
- 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 -463
- package/src/config/services/ConfigLoaderService.ts +0 -740
- 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/functions/pathResolution.ts +0 -227
- package/src/shared/attributeMapper.ts +0 -229
- package/src/shared/errorUtils.ts +0 -110
- package/src/shared/functionManager.ts +0 -525
- package/src/shared/indexManager.ts +0 -254
- package/src/shared/jsonSchemaGenerator.ts +0 -383
- package/src/shared/logging.ts +0 -149
- package/src/shared/messageFormatter.ts +0 -208
- package/src/shared/pydanticModelGenerator.ts +0 -618
- package/src/shared/schemaGenerator.ts +0 -644
- package/src/utils/ClientFactory.ts +0 -240
- package/src/utils/configDiscovery.ts +0 -557
- 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/pathResolvers.ts +0 -81
- package/src/utils/projectConfig.ts +0 -299
- package/src/utils/retryFailedPromises.ts +0 -29
- package/src/utils/sessionAuth.ts +0 -230
- 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
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
import { existsSync, statSync, readdirSync } from 'node:fs';
|
|
2
|
-
import { join, resolve, isAbsolute } from 'node:path';
|
|
3
|
-
import { homedir } from 'node:os';
|
|
4
|
-
import { MessageFormatter } from '../shared/messageFormatter.js';
|
|
5
|
-
import { logger } from '../shared/logging.js';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Expands tilde (~) in paths to the user's home directory
|
|
9
|
-
* @param pathStr - Path string that may contain ~
|
|
10
|
-
* @returns Expanded path with home directory
|
|
11
|
-
*/
|
|
12
|
-
export function expandTildePath(pathStr: string): string {
|
|
13
|
-
if (!pathStr) return pathStr;
|
|
14
|
-
|
|
15
|
-
if (pathStr.startsWith('~/') || pathStr === '~') {
|
|
16
|
-
const expandedPath = pathStr.replace(/^~(?=$|\/|\\)/, homedir());
|
|
17
|
-
logger.debug('Expanded tilde path', { original: pathStr, expanded: expandedPath });
|
|
18
|
-
return expandedPath;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
return pathStr;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
/**
|
|
25
|
-
* Normalizes function name to standard format (lowercase, dashes instead of spaces)
|
|
26
|
-
* @param name - Function name to normalize
|
|
27
|
-
* @returns Normalized function name
|
|
28
|
-
*/
|
|
29
|
-
export function normalizeFunctionName(name: string): string {
|
|
30
|
-
if (!name) return name;
|
|
31
|
-
|
|
32
|
-
const normalized = name.toLowerCase().replace(/\s+/g, '-');
|
|
33
|
-
|
|
34
|
-
if (normalized !== name) {
|
|
35
|
-
logger.debug('Normalized function name', { original: name, normalized });
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
return normalized;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Validates that a directory exists and contains function markers
|
|
43
|
-
* @param dirPath - Directory path to validate
|
|
44
|
-
* @returns True if directory is a valid function directory
|
|
45
|
-
*/
|
|
46
|
-
export function validateFunctionDirectory(dirPath: string): boolean {
|
|
47
|
-
try {
|
|
48
|
-
// Check if directory exists
|
|
49
|
-
if (!existsSync(dirPath)) {
|
|
50
|
-
logger.debug('Directory does not exist', { dirPath });
|
|
51
|
-
return false;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
// Check if it's actually a directory
|
|
55
|
-
const stats = statSync(dirPath);
|
|
56
|
-
if (!stats.isDirectory()) {
|
|
57
|
-
logger.debug('Path is not a directory', { dirPath });
|
|
58
|
-
return false;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// Check for function markers
|
|
62
|
-
const contents = readdirSync(dirPath);
|
|
63
|
-
const hasPackageJson = contents.includes('package.json');
|
|
64
|
-
const hasPyprojectToml = contents.includes('pyproject.toml');
|
|
65
|
-
const hasSrcDir = contents.includes('src');
|
|
66
|
-
|
|
67
|
-
const isValid = hasPackageJson || hasPyprojectToml || hasSrcDir;
|
|
68
|
-
|
|
69
|
-
logger.debug('Function directory validation', {
|
|
70
|
-
dirPath,
|
|
71
|
-
isValid,
|
|
72
|
-
markers: {
|
|
73
|
-
hasPackageJson,
|
|
74
|
-
hasPyprojectToml,
|
|
75
|
-
hasSrcDir
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
return isValid;
|
|
80
|
-
} catch (error) {
|
|
81
|
-
logger.debug('Error validating function directory', {
|
|
82
|
-
dirPath,
|
|
83
|
-
error: error instanceof Error ? error.message : String(error)
|
|
84
|
-
});
|
|
85
|
-
return false;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* Helper function to search for function in standard locations
|
|
91
|
-
* @param configDirPath - Directory where config file is located
|
|
92
|
-
* @param normalizedName - Normalized function name
|
|
93
|
-
* @returns First valid function directory path or undefined
|
|
94
|
-
*/
|
|
95
|
-
export function findFunctionInStandardLocations(
|
|
96
|
-
configDirPath: string,
|
|
97
|
-
normalizedName: string
|
|
98
|
-
): string | undefined {
|
|
99
|
-
const searchPaths = [
|
|
100
|
-
// Same directory as config
|
|
101
|
-
join(configDirPath, 'functions', normalizedName),
|
|
102
|
-
// Parent directory of config
|
|
103
|
-
join(configDirPath, '..', 'functions', normalizedName),
|
|
104
|
-
// Current working directory
|
|
105
|
-
join(process.cwd(), 'functions', normalizedName),
|
|
106
|
-
];
|
|
107
|
-
|
|
108
|
-
logger.debug('Searching for function in standard locations', {
|
|
109
|
-
normalizedName,
|
|
110
|
-
configDirPath,
|
|
111
|
-
searchPaths
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
for (const searchPath of searchPaths) {
|
|
115
|
-
const resolvedPath = resolve(searchPath);
|
|
116
|
-
logger.debug('Checking search path', { searchPath, resolvedPath });
|
|
117
|
-
|
|
118
|
-
if (validateFunctionDirectory(resolvedPath)) {
|
|
119
|
-
logger.debug('Found function in standard location', { resolvedPath });
|
|
120
|
-
return resolvedPath;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
logger.debug('Function not found in any standard location', { normalizedName });
|
|
125
|
-
return undefined;
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
/**
|
|
129
|
-
* Resolves the absolute path to a function directory
|
|
130
|
-
* Handles multiple resolution strategies with proper priority
|
|
131
|
-
*
|
|
132
|
-
* @param functionName - Name of the function
|
|
133
|
-
* @param configDirPath - Directory where config file is located
|
|
134
|
-
* @param dirPath - Optional explicit dirPath from config
|
|
135
|
-
* @param explicitPath - Optional path passed as parameter (highest priority)
|
|
136
|
-
* @returns Absolute path to the function directory
|
|
137
|
-
* @throws Error if function directory cannot be found or is invalid
|
|
138
|
-
*/
|
|
139
|
-
export function resolveFunctionDirectory(
|
|
140
|
-
functionName: string,
|
|
141
|
-
configDirPath: string,
|
|
142
|
-
dirPath?: string,
|
|
143
|
-
explicitPath?: string
|
|
144
|
-
): string {
|
|
145
|
-
logger.debug('Resolving function directory', {
|
|
146
|
-
functionName,
|
|
147
|
-
configDirPath,
|
|
148
|
-
dirPath,
|
|
149
|
-
explicitPath
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
const normalizedName = normalizeFunctionName(functionName);
|
|
153
|
-
|
|
154
|
-
// Priority 1: Explicit path parameter (highest priority)
|
|
155
|
-
if (explicitPath) {
|
|
156
|
-
logger.debug('Using explicit path parameter');
|
|
157
|
-
const expandedPath = expandTildePath(explicitPath);
|
|
158
|
-
const resolvedPath = isAbsolute(expandedPath)
|
|
159
|
-
? expandedPath
|
|
160
|
-
: resolve(process.cwd(), expandedPath);
|
|
161
|
-
|
|
162
|
-
if (!validateFunctionDirectory(resolvedPath)) {
|
|
163
|
-
const errorMsg = `Explicit path is not a valid function directory: ${resolvedPath}`;
|
|
164
|
-
logger.error(errorMsg);
|
|
165
|
-
MessageFormatter.error('Invalid function directory', errorMsg, { prefix: 'Path Resolution' });
|
|
166
|
-
throw new Error(errorMsg);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
logger.debug('Resolved using explicit path', { resolvedPath });
|
|
170
|
-
MessageFormatter.debug(`Resolved function directory using explicit path: ${resolvedPath}`, undefined, { prefix: 'Path Resolution' });
|
|
171
|
-
return resolvedPath;
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
// Priority 2: dirPath from config (relative to config location)
|
|
175
|
-
if (dirPath) {
|
|
176
|
-
logger.debug('Using dirPath from config');
|
|
177
|
-
const expandedPath = expandTildePath(dirPath);
|
|
178
|
-
const resolvedPath = isAbsolute(expandedPath)
|
|
179
|
-
? expandedPath
|
|
180
|
-
: resolve(configDirPath, expandedPath);
|
|
181
|
-
|
|
182
|
-
if (!validateFunctionDirectory(resolvedPath)) {
|
|
183
|
-
const errorMsg = `Config dirPath is not a valid function directory: ${resolvedPath}`;
|
|
184
|
-
logger.error(errorMsg);
|
|
185
|
-
MessageFormatter.error('Invalid function directory', errorMsg, { prefix: 'Path Resolution' });
|
|
186
|
-
throw new Error(errorMsg);
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
logger.debug('Resolved using config dirPath', { resolvedPath });
|
|
190
|
-
MessageFormatter.debug(`Resolved function directory using config dirPath: ${resolvedPath}`, undefined, { prefix: 'Path Resolution' });
|
|
191
|
-
return resolvedPath;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
// Priority 3: Search standard locations
|
|
195
|
-
logger.debug('Searching standard locations for function');
|
|
196
|
-
const foundPath = findFunctionInStandardLocations(configDirPath, normalizedName);
|
|
197
|
-
|
|
198
|
-
if (foundPath) {
|
|
199
|
-
logger.debug('Resolved using standard location search', { foundPath });
|
|
200
|
-
MessageFormatter.debug(`Found function directory in standard location: ${foundPath}`, undefined, { prefix: 'Path Resolution' });
|
|
201
|
-
return foundPath;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
// Priority 4: Not found - throw error
|
|
205
|
-
const searchedLocations = [
|
|
206
|
-
join(configDirPath, 'functions', normalizedName),
|
|
207
|
-
join(configDirPath, '..', 'functions', normalizedName),
|
|
208
|
-
join(process.cwd(), 'functions', normalizedName),
|
|
209
|
-
];
|
|
210
|
-
|
|
211
|
-
const errorMsg = `Function directory not found for '${functionName}' (normalized: '${normalizedName}'). ` +
|
|
212
|
-
`Searched locations:\n${searchedLocations.map(p => ` - ${p}`).join('\n')}`;
|
|
213
|
-
|
|
214
|
-
logger.error('Function directory not found', {
|
|
215
|
-
functionName,
|
|
216
|
-
normalizedName,
|
|
217
|
-
searchedLocations
|
|
218
|
-
});
|
|
219
|
-
|
|
220
|
-
MessageFormatter.error(
|
|
221
|
-
'Function directory not found',
|
|
222
|
-
errorMsg,
|
|
223
|
-
{ prefix: 'Path Resolution' }
|
|
224
|
-
);
|
|
225
|
-
|
|
226
|
-
throw new Error(errorMsg);
|
|
227
|
-
}
|
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
import type { CreateAttributeParams, UpdateAttributeParams } from "../adapters/DatabaseAdapter.js";
|
|
2
|
-
import type { Attribute } from "@njdamstra/appwrite-utils";
|
|
3
|
-
|
|
4
|
-
function ensureNumber(n: any): number | undefined {
|
|
5
|
-
if (n === null || n === undefined) return undefined;
|
|
6
|
-
const num = Number(n);
|
|
7
|
-
return Number.isFinite(num) ? num : undefined;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Map a schema Attribute into DatabaseAdapter CreateAttributeParams
|
|
12
|
-
* Only includes fields valid for the specific type to satisfy TS unions.
|
|
13
|
-
* Also normalizes min/max ordering for numeric types to avoid server errors.
|
|
14
|
-
*/
|
|
15
|
-
export function mapToCreateAttributeParams(
|
|
16
|
-
attr: Attribute,
|
|
17
|
-
base: { databaseId: string; tableId: string }
|
|
18
|
-
): CreateAttributeParams {
|
|
19
|
-
const type = String((attr as any).type || "").toLowerCase();
|
|
20
|
-
const required = !!(attr as any).required;
|
|
21
|
-
const array = !!(attr as any).array;
|
|
22
|
-
const xdefault = (attr as any).xdefault;
|
|
23
|
-
const encrypt = (attr as any).encrypt;
|
|
24
|
-
|
|
25
|
-
// Numeric helpers
|
|
26
|
-
const rawMin = ensureNumber((attr as any).min);
|
|
27
|
-
const rawMax = ensureNumber((attr as any).max);
|
|
28
|
-
let min = rawMin;
|
|
29
|
-
let max = rawMax;
|
|
30
|
-
if (min !== undefined && max !== undefined && min >= max) {
|
|
31
|
-
// Swap to satisfy server-side validation
|
|
32
|
-
const tmp = min;
|
|
33
|
-
min = Math.min(min, max);
|
|
34
|
-
max = Math.max(tmp, max);
|
|
35
|
-
if (min === max) {
|
|
36
|
-
// If still equal, unset max to avoid error
|
|
37
|
-
max = undefined;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
switch (type) {
|
|
42
|
-
case "string":
|
|
43
|
-
return {
|
|
44
|
-
databaseId: base.databaseId,
|
|
45
|
-
tableId: base.tableId,
|
|
46
|
-
key: attr.key,
|
|
47
|
-
type,
|
|
48
|
-
size: (attr as any).size ?? 255,
|
|
49
|
-
required,
|
|
50
|
-
default: xdefault,
|
|
51
|
-
array,
|
|
52
|
-
encrypt: !!encrypt,
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
case "integer":
|
|
56
|
-
return {
|
|
57
|
-
databaseId: base.databaseId,
|
|
58
|
-
tableId: base.tableId,
|
|
59
|
-
key: attr.key,
|
|
60
|
-
type,
|
|
61
|
-
required,
|
|
62
|
-
default: xdefault,
|
|
63
|
-
array,
|
|
64
|
-
min,
|
|
65
|
-
max,
|
|
66
|
-
};
|
|
67
|
-
|
|
68
|
-
case "double":
|
|
69
|
-
case "float":
|
|
70
|
-
return {
|
|
71
|
-
databaseId: base.databaseId,
|
|
72
|
-
tableId: base.tableId,
|
|
73
|
-
key: attr.key,
|
|
74
|
-
type,
|
|
75
|
-
required,
|
|
76
|
-
default: xdefault,
|
|
77
|
-
array,
|
|
78
|
-
min,
|
|
79
|
-
max,
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
case "boolean":
|
|
83
|
-
return {
|
|
84
|
-
databaseId: base.databaseId,
|
|
85
|
-
tableId: base.tableId,
|
|
86
|
-
key: attr.key,
|
|
87
|
-
type,
|
|
88
|
-
required,
|
|
89
|
-
default: xdefault,
|
|
90
|
-
array,
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
case "datetime":
|
|
94
|
-
case "email":
|
|
95
|
-
case "ip":
|
|
96
|
-
case "url":
|
|
97
|
-
return {
|
|
98
|
-
databaseId: base.databaseId,
|
|
99
|
-
tableId: base.tableId,
|
|
100
|
-
key: attr.key,
|
|
101
|
-
type,
|
|
102
|
-
required,
|
|
103
|
-
default: xdefault,
|
|
104
|
-
array,
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
case "enum":
|
|
108
|
-
{
|
|
109
|
-
const elements = (attr as any).elements;
|
|
110
|
-
if (!Array.isArray(elements) || elements.length === 0) {
|
|
111
|
-
// Creating an enum without elements is invalid – fail fast with clear messaging
|
|
112
|
-
throw new Error(
|
|
113
|
-
`Enum attribute '${(attr as any).key}' requires a non-empty 'elements' array for creation`
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
return {
|
|
118
|
-
databaseId: base.databaseId,
|
|
119
|
-
tableId: base.tableId,
|
|
120
|
-
key: attr.key,
|
|
121
|
-
type,
|
|
122
|
-
required,
|
|
123
|
-
default: xdefault,
|
|
124
|
-
array,
|
|
125
|
-
elements: (attr as any).elements,
|
|
126
|
-
};
|
|
127
|
-
|
|
128
|
-
case "relationship": {
|
|
129
|
-
// Relationship attributes require related collection and metadata
|
|
130
|
-
return {
|
|
131
|
-
databaseId: base.databaseId,
|
|
132
|
-
tableId: base.tableId,
|
|
133
|
-
key: attr.key,
|
|
134
|
-
type,
|
|
135
|
-
relatedCollection: (attr as any).relatedCollection,
|
|
136
|
-
relationType: (attr as any).relationType,
|
|
137
|
-
twoWay: (attr as any).twoWay,
|
|
138
|
-
twoWayKey: (attr as any).twoWayKey,
|
|
139
|
-
onDelete: (attr as any).onDelete,
|
|
140
|
-
side: (attr as any).side,
|
|
141
|
-
} as unknown as CreateAttributeParams;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
default:
|
|
145
|
-
return {
|
|
146
|
-
databaseId: base.databaseId,
|
|
147
|
-
tableId: base.tableId,
|
|
148
|
-
key: attr.key,
|
|
149
|
-
type,
|
|
150
|
-
required,
|
|
151
|
-
} as CreateAttributeParams;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
/**
|
|
156
|
-
* Map a schema Attribute into DatabaseAdapter UpdateAttributeParams
|
|
157
|
-
* Omits fields that are not explicitly provided, and guards enum updates
|
|
158
|
-
* so we never send an empty elements array (preserve existing on server).
|
|
159
|
-
*/
|
|
160
|
-
export function mapToUpdateAttributeParams(
|
|
161
|
-
attr: Attribute,
|
|
162
|
-
base: { databaseId: string; tableId: string }
|
|
163
|
-
): UpdateAttributeParams {
|
|
164
|
-
const type = String((attr as any).type || "").toLowerCase();
|
|
165
|
-
const params: UpdateAttributeParams = {
|
|
166
|
-
databaseId: base.databaseId,
|
|
167
|
-
tableId: base.tableId,
|
|
168
|
-
key: (attr as any).key,
|
|
169
|
-
};
|
|
170
|
-
|
|
171
|
-
const setIfDefined = <K extends keyof UpdateAttributeParams>(
|
|
172
|
-
key: K,
|
|
173
|
-
value: UpdateAttributeParams[K]
|
|
174
|
-
) => {
|
|
175
|
-
if (value !== undefined) (params as any)[key] = value;
|
|
176
|
-
};
|
|
177
|
-
|
|
178
|
-
// Common fields
|
|
179
|
-
setIfDefined("type", type);
|
|
180
|
-
setIfDefined("required", (attr as any).required);
|
|
181
|
-
// Only send default if explicitly provided and not on required
|
|
182
|
-
if (!(attr as any).required && (attr as any).xdefault !== undefined) {
|
|
183
|
-
setIfDefined("default", (attr as any).xdefault as any);
|
|
184
|
-
}
|
|
185
|
-
setIfDefined("array", (attr as any).array);
|
|
186
|
-
// encrypt only applies to string types
|
|
187
|
-
if (type === "string") setIfDefined("encrypt", (attr as any).encrypt);
|
|
188
|
-
|
|
189
|
-
// Numeric normalization
|
|
190
|
-
const toNum = (n: any) => (n === null || n === undefined ? undefined : (Number(n)));
|
|
191
|
-
let min = toNum((attr as any).min);
|
|
192
|
-
let max = toNum((attr as any).max);
|
|
193
|
-
if (min !== undefined && max !== undefined && min >= max) {
|
|
194
|
-
const tmp = min;
|
|
195
|
-
min = Math.min(min, max);
|
|
196
|
-
max = Math.max(tmp, max);
|
|
197
|
-
if (min === max) max = undefined;
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
switch (type) {
|
|
201
|
-
case "string":
|
|
202
|
-
setIfDefined("size", (attr as any).size);
|
|
203
|
-
break;
|
|
204
|
-
case "integer":
|
|
205
|
-
case "float":
|
|
206
|
-
case "double":
|
|
207
|
-
setIfDefined("min", min);
|
|
208
|
-
setIfDefined("max", max);
|
|
209
|
-
break;
|
|
210
|
-
case "enum": {
|
|
211
|
-
const elements = (attr as any).elements;
|
|
212
|
-
if (Array.isArray(elements) && elements.length > 0) {
|
|
213
|
-
// Only include when non-empty; otherwise preserve existing on server
|
|
214
|
-
setIfDefined("elements", elements as string[]);
|
|
215
|
-
}
|
|
216
|
-
break;
|
|
217
|
-
}
|
|
218
|
-
case "relationship": {
|
|
219
|
-
setIfDefined("relatedCollection", (attr as any).relatedCollection);
|
|
220
|
-
setIfDefined("relationType", (attr as any).relationType);
|
|
221
|
-
setIfDefined("twoWay", (attr as any).twoWay);
|
|
222
|
-
setIfDefined("twoWayKey", (attr as any).twoWayKey);
|
|
223
|
-
setIfDefined("onDelete", (attr as any).onDelete);
|
|
224
|
-
break;
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
return params;
|
|
229
|
-
}
|
package/src/shared/errorUtils.ts
DELETED
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Shared error handling utilities for consistent error processing
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Extracts error message from unknown error type
|
|
7
|
-
* @param error - Error of unknown type
|
|
8
|
-
* @returns String error message
|
|
9
|
-
*/
|
|
10
|
-
export function getErrorMessage(error: unknown): string {
|
|
11
|
-
return error instanceof Error ? error.message : String(error);
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Normalizes unknown error to Error instance
|
|
16
|
-
* @param error - Error of unknown type
|
|
17
|
-
* @returns Normalized Error object
|
|
18
|
-
*/
|
|
19
|
-
export function normalizeError(error: unknown): Error {
|
|
20
|
-
return error instanceof Error ? error : new Error(String(error));
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Checks if error is a conflict error (409)
|
|
25
|
-
* @param error - Error object to check
|
|
26
|
-
* @returns True if error is a conflict (duplicate resource)
|
|
27
|
-
*/
|
|
28
|
-
export function isConflictError(error: any): boolean {
|
|
29
|
-
return error?.code === 409 || (error?.message?.toLowerCase().includes('already exists') ?? false);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* Checks if error is a Cloudflare error (522)
|
|
34
|
-
* @param error - Error object to check
|
|
35
|
-
* @returns True if error is from Cloudflare connection timeout
|
|
36
|
-
*/
|
|
37
|
-
export function isCloudflareError(error: any): boolean {
|
|
38
|
-
return error?.code === 522 || error?.code === "522";
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Checks if error is authentication/authorization related
|
|
43
|
-
* @param error - Error object to check
|
|
44
|
-
* @returns True if error is auth-related (401, 403)
|
|
45
|
-
*/
|
|
46
|
-
export function isAuthError(error: any): boolean {
|
|
47
|
-
const code = error?.code;
|
|
48
|
-
return code === 401 || code === 403 || code === "401" || code === "403";
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* Error categorization helpers for smart fallback logic
|
|
53
|
-
*/
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Checks if an error is retryable (network issues, rate limits, etc.)
|
|
57
|
-
* @param errorMessage - Error message to check
|
|
58
|
-
* @returns True if error is retryable
|
|
59
|
-
*/
|
|
60
|
-
export function isRetryableError(errorMessage: string): boolean {
|
|
61
|
-
const retryableErrors = [
|
|
62
|
-
"rate limit",
|
|
63
|
-
"timeout",
|
|
64
|
-
"network",
|
|
65
|
-
"temporary",
|
|
66
|
-
"503",
|
|
67
|
-
"502",
|
|
68
|
-
"429"
|
|
69
|
-
];
|
|
70
|
-
return retryableErrors.some(error =>
|
|
71
|
-
errorMessage.toLowerCase().includes(error)
|
|
72
|
-
);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Checks if an error indicates bulk operations are not supported
|
|
77
|
-
* @param errorMessage - Error message to check
|
|
78
|
-
* @returns True if bulk operations not supported
|
|
79
|
-
*/
|
|
80
|
-
export function isBulkNotSupportedError(errorMessage: string): boolean {
|
|
81
|
-
const notSupportedErrors = [
|
|
82
|
-
"method not found",
|
|
83
|
-
"not implemented",
|
|
84
|
-
"unsupported",
|
|
85
|
-
"not available",
|
|
86
|
-
"404"
|
|
87
|
-
];
|
|
88
|
-
return notSupportedErrors.some(error =>
|
|
89
|
-
errorMessage.toLowerCase().includes(error)
|
|
90
|
-
);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
/**
|
|
94
|
-
* Checks if an error is critical (authentication, authorization, permissions)
|
|
95
|
-
* @param errorMessage - Error message to check
|
|
96
|
-
* @returns True if error is critical
|
|
97
|
-
*/
|
|
98
|
-
export function isCriticalError(errorMessage: string): boolean {
|
|
99
|
-
const criticalErrors = [
|
|
100
|
-
"authentication",
|
|
101
|
-
"authorization",
|
|
102
|
-
"permission",
|
|
103
|
-
"forbidden",
|
|
104
|
-
"401",
|
|
105
|
-
"403"
|
|
106
|
-
];
|
|
107
|
-
return criticalErrors.some(error =>
|
|
108
|
-
errorMessage.toLowerCase().includes(error)
|
|
109
|
-
);
|
|
110
|
-
}
|