@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,37 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Expands tilde (~) in paths to the user's home directory
|
|
3
|
-
* @param pathStr - Path string that may contain ~
|
|
4
|
-
* @returns Expanded path with home directory
|
|
5
|
-
*/
|
|
6
|
-
export declare function expandTildePath(pathStr: string): string;
|
|
7
|
-
/**
|
|
8
|
-
* Normalizes function name to standard format (lowercase, dashes instead of spaces)
|
|
9
|
-
* @param name - Function name to normalize
|
|
10
|
-
* @returns Normalized function name
|
|
11
|
-
*/
|
|
12
|
-
export declare function normalizeFunctionName(name: string): string;
|
|
13
|
-
/**
|
|
14
|
-
* Validates that a directory exists and contains function markers
|
|
15
|
-
* @param dirPath - Directory path to validate
|
|
16
|
-
* @returns True if directory is a valid function directory
|
|
17
|
-
*/
|
|
18
|
-
export declare function validateFunctionDirectory(dirPath: string): boolean;
|
|
19
|
-
/**
|
|
20
|
-
* Helper function to search for function in standard locations
|
|
21
|
-
* @param configDirPath - Directory where config file is located
|
|
22
|
-
* @param normalizedName - Normalized function name
|
|
23
|
-
* @returns First valid function directory path or undefined
|
|
24
|
-
*/
|
|
25
|
-
export declare function findFunctionInStandardLocations(configDirPath: string, normalizedName: string): string | undefined;
|
|
26
|
-
/**
|
|
27
|
-
* Resolves the absolute path to a function directory
|
|
28
|
-
* Handles multiple resolution strategies with proper priority
|
|
29
|
-
*
|
|
30
|
-
* @param functionName - Name of the function
|
|
31
|
-
* @param configDirPath - Directory where config file is located
|
|
32
|
-
* @param dirPath - Optional explicit dirPath from config
|
|
33
|
-
* @param explicitPath - Optional path passed as parameter (highest priority)
|
|
34
|
-
* @returns Absolute path to the function directory
|
|
35
|
-
* @throws Error if function directory cannot be found or is invalid
|
|
36
|
-
*/
|
|
37
|
-
export declare function resolveFunctionDirectory(functionName: string, configDirPath: string, dirPath?: string, explicitPath?: string): string;
|
|
@@ -1,185 +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
|
-
* Expands tilde (~) in paths to the user's home directory
|
|
8
|
-
* @param pathStr - Path string that may contain ~
|
|
9
|
-
* @returns Expanded path with home directory
|
|
10
|
-
*/
|
|
11
|
-
export function expandTildePath(pathStr) {
|
|
12
|
-
if (!pathStr)
|
|
13
|
-
return pathStr;
|
|
14
|
-
if (pathStr.startsWith('~/') || pathStr === '~') {
|
|
15
|
-
const expandedPath = pathStr.replace(/^~(?=$|\/|\\)/, homedir());
|
|
16
|
-
logger.debug('Expanded tilde path', { original: pathStr, expanded: expandedPath });
|
|
17
|
-
return expandedPath;
|
|
18
|
-
}
|
|
19
|
-
return pathStr;
|
|
20
|
-
}
|
|
21
|
-
/**
|
|
22
|
-
* Normalizes function name to standard format (lowercase, dashes instead of spaces)
|
|
23
|
-
* @param name - Function name to normalize
|
|
24
|
-
* @returns Normalized function name
|
|
25
|
-
*/
|
|
26
|
-
export function normalizeFunctionName(name) {
|
|
27
|
-
if (!name)
|
|
28
|
-
return name;
|
|
29
|
-
const normalized = name.toLowerCase().replace(/\s+/g, '-');
|
|
30
|
-
if (normalized !== name) {
|
|
31
|
-
logger.debug('Normalized function name', { original: name, normalized });
|
|
32
|
-
}
|
|
33
|
-
return normalized;
|
|
34
|
-
}
|
|
35
|
-
/**
|
|
36
|
-
* Validates that a directory exists and contains function markers
|
|
37
|
-
* @param dirPath - Directory path to validate
|
|
38
|
-
* @returns True if directory is a valid function directory
|
|
39
|
-
*/
|
|
40
|
-
export function validateFunctionDirectory(dirPath) {
|
|
41
|
-
try {
|
|
42
|
-
// Check if directory exists
|
|
43
|
-
if (!existsSync(dirPath)) {
|
|
44
|
-
logger.debug('Directory does not exist', { dirPath });
|
|
45
|
-
return false;
|
|
46
|
-
}
|
|
47
|
-
// Check if it's actually a directory
|
|
48
|
-
const stats = statSync(dirPath);
|
|
49
|
-
if (!stats.isDirectory()) {
|
|
50
|
-
logger.debug('Path is not a directory', { dirPath });
|
|
51
|
-
return false;
|
|
52
|
-
}
|
|
53
|
-
// Check for function markers
|
|
54
|
-
const contents = readdirSync(dirPath);
|
|
55
|
-
const hasPackageJson = contents.includes('package.json');
|
|
56
|
-
const hasPyprojectToml = contents.includes('pyproject.toml');
|
|
57
|
-
const hasSrcDir = contents.includes('src');
|
|
58
|
-
const isValid = hasPackageJson || hasPyprojectToml || hasSrcDir;
|
|
59
|
-
logger.debug('Function directory validation', {
|
|
60
|
-
dirPath,
|
|
61
|
-
isValid,
|
|
62
|
-
markers: {
|
|
63
|
-
hasPackageJson,
|
|
64
|
-
hasPyprojectToml,
|
|
65
|
-
hasSrcDir
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
return isValid;
|
|
69
|
-
}
|
|
70
|
-
catch (error) {
|
|
71
|
-
logger.debug('Error validating function directory', {
|
|
72
|
-
dirPath,
|
|
73
|
-
error: error instanceof Error ? error.message : String(error)
|
|
74
|
-
});
|
|
75
|
-
return false;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* Helper function to search for function in standard locations
|
|
80
|
-
* @param configDirPath - Directory where config file is located
|
|
81
|
-
* @param normalizedName - Normalized function name
|
|
82
|
-
* @returns First valid function directory path or undefined
|
|
83
|
-
*/
|
|
84
|
-
export function findFunctionInStandardLocations(configDirPath, normalizedName) {
|
|
85
|
-
const searchPaths = [
|
|
86
|
-
// Same directory as config
|
|
87
|
-
join(configDirPath, 'functions', normalizedName),
|
|
88
|
-
// Parent directory of config
|
|
89
|
-
join(configDirPath, '..', 'functions', normalizedName),
|
|
90
|
-
// Current working directory
|
|
91
|
-
join(process.cwd(), 'functions', normalizedName),
|
|
92
|
-
];
|
|
93
|
-
logger.debug('Searching for function in standard locations', {
|
|
94
|
-
normalizedName,
|
|
95
|
-
configDirPath,
|
|
96
|
-
searchPaths
|
|
97
|
-
});
|
|
98
|
-
for (const searchPath of searchPaths) {
|
|
99
|
-
const resolvedPath = resolve(searchPath);
|
|
100
|
-
logger.debug('Checking search path', { searchPath, resolvedPath });
|
|
101
|
-
if (validateFunctionDirectory(resolvedPath)) {
|
|
102
|
-
logger.debug('Found function in standard location', { resolvedPath });
|
|
103
|
-
return resolvedPath;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
logger.debug('Function not found in any standard location', { normalizedName });
|
|
107
|
-
return undefined;
|
|
108
|
-
}
|
|
109
|
-
/**
|
|
110
|
-
* Resolves the absolute path to a function directory
|
|
111
|
-
* Handles multiple resolution strategies with proper priority
|
|
112
|
-
*
|
|
113
|
-
* @param functionName - Name of the function
|
|
114
|
-
* @param configDirPath - Directory where config file is located
|
|
115
|
-
* @param dirPath - Optional explicit dirPath from config
|
|
116
|
-
* @param explicitPath - Optional path passed as parameter (highest priority)
|
|
117
|
-
* @returns Absolute path to the function directory
|
|
118
|
-
* @throws Error if function directory cannot be found or is invalid
|
|
119
|
-
*/
|
|
120
|
-
export function resolveFunctionDirectory(functionName, configDirPath, dirPath, explicitPath) {
|
|
121
|
-
logger.debug('Resolving function directory', {
|
|
122
|
-
functionName,
|
|
123
|
-
configDirPath,
|
|
124
|
-
dirPath,
|
|
125
|
-
explicitPath
|
|
126
|
-
});
|
|
127
|
-
const normalizedName = normalizeFunctionName(functionName);
|
|
128
|
-
// Priority 1: Explicit path parameter (highest priority)
|
|
129
|
-
if (explicitPath) {
|
|
130
|
-
logger.debug('Using explicit path parameter');
|
|
131
|
-
const expandedPath = expandTildePath(explicitPath);
|
|
132
|
-
const resolvedPath = isAbsolute(expandedPath)
|
|
133
|
-
? expandedPath
|
|
134
|
-
: resolve(process.cwd(), expandedPath);
|
|
135
|
-
if (!validateFunctionDirectory(resolvedPath)) {
|
|
136
|
-
const errorMsg = `Explicit path is not a valid function directory: ${resolvedPath}`;
|
|
137
|
-
logger.error(errorMsg);
|
|
138
|
-
MessageFormatter.error('Invalid function directory', errorMsg, { prefix: 'Path Resolution' });
|
|
139
|
-
throw new Error(errorMsg);
|
|
140
|
-
}
|
|
141
|
-
logger.debug('Resolved using explicit path', { resolvedPath });
|
|
142
|
-
MessageFormatter.debug(`Resolved function directory using explicit path: ${resolvedPath}`, undefined, { prefix: 'Path Resolution' });
|
|
143
|
-
return resolvedPath;
|
|
144
|
-
}
|
|
145
|
-
// Priority 2: dirPath from config (relative to config location)
|
|
146
|
-
if (dirPath) {
|
|
147
|
-
logger.debug('Using dirPath from config');
|
|
148
|
-
const expandedPath = expandTildePath(dirPath);
|
|
149
|
-
const resolvedPath = isAbsolute(expandedPath)
|
|
150
|
-
? expandedPath
|
|
151
|
-
: resolve(configDirPath, expandedPath);
|
|
152
|
-
if (!validateFunctionDirectory(resolvedPath)) {
|
|
153
|
-
const errorMsg = `Config dirPath is not a valid function directory: ${resolvedPath}`;
|
|
154
|
-
logger.error(errorMsg);
|
|
155
|
-
MessageFormatter.error('Invalid function directory', errorMsg, { prefix: 'Path Resolution' });
|
|
156
|
-
throw new Error(errorMsg);
|
|
157
|
-
}
|
|
158
|
-
logger.debug('Resolved using config dirPath', { resolvedPath });
|
|
159
|
-
MessageFormatter.debug(`Resolved function directory using config dirPath: ${resolvedPath}`, undefined, { prefix: 'Path Resolution' });
|
|
160
|
-
return resolvedPath;
|
|
161
|
-
}
|
|
162
|
-
// Priority 3: Search standard locations
|
|
163
|
-
logger.debug('Searching standard locations for function');
|
|
164
|
-
const foundPath = findFunctionInStandardLocations(configDirPath, normalizedName);
|
|
165
|
-
if (foundPath) {
|
|
166
|
-
logger.debug('Resolved using standard location search', { foundPath });
|
|
167
|
-
MessageFormatter.debug(`Found function directory in standard location: ${foundPath}`, undefined, { prefix: 'Path Resolution' });
|
|
168
|
-
return foundPath;
|
|
169
|
-
}
|
|
170
|
-
// Priority 4: Not found - throw error
|
|
171
|
-
const searchedLocations = [
|
|
172
|
-
join(configDirPath, 'functions', normalizedName),
|
|
173
|
-
join(configDirPath, '..', 'functions', normalizedName),
|
|
174
|
-
join(process.cwd(), 'functions', normalizedName),
|
|
175
|
-
];
|
|
176
|
-
const errorMsg = `Function directory not found for '${functionName}' (normalized: '${normalizedName}'). ` +
|
|
177
|
-
`Searched locations:\n${searchedLocations.map(p => ` - ${p}`).join('\n')}`;
|
|
178
|
-
logger.error('Function directory not found', {
|
|
179
|
-
functionName,
|
|
180
|
-
normalizedName,
|
|
181
|
-
searchedLocations
|
|
182
|
-
});
|
|
183
|
-
MessageFormatter.error('Function directory not found', errorMsg, { prefix: 'Path Resolution' });
|
|
184
|
-
throw new Error(errorMsg);
|
|
185
|
-
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import type { CreateAttributeParams, UpdateAttributeParams } from "../adapters/DatabaseAdapter.js";
|
|
2
|
-
import type { Attribute } from "@njdamstra/appwrite-utils";
|
|
3
|
-
/**
|
|
4
|
-
* Map a schema Attribute into DatabaseAdapter CreateAttributeParams
|
|
5
|
-
* Only includes fields valid for the specific type to satisfy TS unions.
|
|
6
|
-
* Also normalizes min/max ordering for numeric types to avoid server errors.
|
|
7
|
-
*/
|
|
8
|
-
export declare function mapToCreateAttributeParams(attr: Attribute, base: {
|
|
9
|
-
databaseId: string;
|
|
10
|
-
tableId: string;
|
|
11
|
-
}): CreateAttributeParams;
|
|
12
|
-
/**
|
|
13
|
-
* Map a schema Attribute into DatabaseAdapter UpdateAttributeParams
|
|
14
|
-
* Omits fields that are not explicitly provided, and guards enum updates
|
|
15
|
-
* so we never send an empty elements array (preserve existing on server).
|
|
16
|
-
*/
|
|
17
|
-
export declare function mapToUpdateAttributeParams(attr: Attribute, base: {
|
|
18
|
-
databaseId: string;
|
|
19
|
-
tableId: string;
|
|
20
|
-
}): UpdateAttributeParams;
|
|
@@ -1,203 +0,0 @@
|
|
|
1
|
-
function ensureNumber(n) {
|
|
2
|
-
if (n === null || n === undefined)
|
|
3
|
-
return undefined;
|
|
4
|
-
const num = Number(n);
|
|
5
|
-
return Number.isFinite(num) ? num : undefined;
|
|
6
|
-
}
|
|
7
|
-
/**
|
|
8
|
-
* Map a schema Attribute into DatabaseAdapter CreateAttributeParams
|
|
9
|
-
* Only includes fields valid for the specific type to satisfy TS unions.
|
|
10
|
-
* Also normalizes min/max ordering for numeric types to avoid server errors.
|
|
11
|
-
*/
|
|
12
|
-
export function mapToCreateAttributeParams(attr, base) {
|
|
13
|
-
const type = String(attr.type || "").toLowerCase();
|
|
14
|
-
const required = !!attr.required;
|
|
15
|
-
const array = !!attr.array;
|
|
16
|
-
const xdefault = attr.xdefault;
|
|
17
|
-
const encrypt = attr.encrypt;
|
|
18
|
-
// Numeric helpers
|
|
19
|
-
const rawMin = ensureNumber(attr.min);
|
|
20
|
-
const rawMax = ensureNumber(attr.max);
|
|
21
|
-
let min = rawMin;
|
|
22
|
-
let max = rawMax;
|
|
23
|
-
if (min !== undefined && max !== undefined && min >= max) {
|
|
24
|
-
// Swap to satisfy server-side validation
|
|
25
|
-
const tmp = min;
|
|
26
|
-
min = Math.min(min, max);
|
|
27
|
-
max = Math.max(tmp, max);
|
|
28
|
-
if (min === max) {
|
|
29
|
-
// If still equal, unset max to avoid error
|
|
30
|
-
max = undefined;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
switch (type) {
|
|
34
|
-
case "string":
|
|
35
|
-
return {
|
|
36
|
-
databaseId: base.databaseId,
|
|
37
|
-
tableId: base.tableId,
|
|
38
|
-
key: attr.key,
|
|
39
|
-
type,
|
|
40
|
-
size: attr.size ?? 255,
|
|
41
|
-
required,
|
|
42
|
-
default: xdefault,
|
|
43
|
-
array,
|
|
44
|
-
encrypt: !!encrypt,
|
|
45
|
-
};
|
|
46
|
-
case "integer":
|
|
47
|
-
return {
|
|
48
|
-
databaseId: base.databaseId,
|
|
49
|
-
tableId: base.tableId,
|
|
50
|
-
key: attr.key,
|
|
51
|
-
type,
|
|
52
|
-
required,
|
|
53
|
-
default: xdefault,
|
|
54
|
-
array,
|
|
55
|
-
min,
|
|
56
|
-
max,
|
|
57
|
-
};
|
|
58
|
-
case "double":
|
|
59
|
-
case "float":
|
|
60
|
-
return {
|
|
61
|
-
databaseId: base.databaseId,
|
|
62
|
-
tableId: base.tableId,
|
|
63
|
-
key: attr.key,
|
|
64
|
-
type,
|
|
65
|
-
required,
|
|
66
|
-
default: xdefault,
|
|
67
|
-
array,
|
|
68
|
-
min,
|
|
69
|
-
max,
|
|
70
|
-
};
|
|
71
|
-
case "boolean":
|
|
72
|
-
return {
|
|
73
|
-
databaseId: base.databaseId,
|
|
74
|
-
tableId: base.tableId,
|
|
75
|
-
key: attr.key,
|
|
76
|
-
type,
|
|
77
|
-
required,
|
|
78
|
-
default: xdefault,
|
|
79
|
-
array,
|
|
80
|
-
};
|
|
81
|
-
case "datetime":
|
|
82
|
-
case "email":
|
|
83
|
-
case "ip":
|
|
84
|
-
case "url":
|
|
85
|
-
return {
|
|
86
|
-
databaseId: base.databaseId,
|
|
87
|
-
tableId: base.tableId,
|
|
88
|
-
key: attr.key,
|
|
89
|
-
type,
|
|
90
|
-
required,
|
|
91
|
-
default: xdefault,
|
|
92
|
-
array,
|
|
93
|
-
};
|
|
94
|
-
case "enum":
|
|
95
|
-
{
|
|
96
|
-
const elements = attr.elements;
|
|
97
|
-
if (!Array.isArray(elements) || elements.length === 0) {
|
|
98
|
-
// Creating an enum without elements is invalid – fail fast with clear messaging
|
|
99
|
-
throw new Error(`Enum attribute '${attr.key}' requires a non-empty 'elements' array for creation`);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
return {
|
|
103
|
-
databaseId: base.databaseId,
|
|
104
|
-
tableId: base.tableId,
|
|
105
|
-
key: attr.key,
|
|
106
|
-
type,
|
|
107
|
-
required,
|
|
108
|
-
default: xdefault,
|
|
109
|
-
array,
|
|
110
|
-
elements: attr.elements,
|
|
111
|
-
};
|
|
112
|
-
case "relationship": {
|
|
113
|
-
// Relationship attributes require related collection and metadata
|
|
114
|
-
return {
|
|
115
|
-
databaseId: base.databaseId,
|
|
116
|
-
tableId: base.tableId,
|
|
117
|
-
key: attr.key,
|
|
118
|
-
type,
|
|
119
|
-
relatedCollection: attr.relatedCollection,
|
|
120
|
-
relationType: attr.relationType,
|
|
121
|
-
twoWay: attr.twoWay,
|
|
122
|
-
twoWayKey: attr.twoWayKey,
|
|
123
|
-
onDelete: attr.onDelete,
|
|
124
|
-
side: attr.side,
|
|
125
|
-
};
|
|
126
|
-
}
|
|
127
|
-
default:
|
|
128
|
-
return {
|
|
129
|
-
databaseId: base.databaseId,
|
|
130
|
-
tableId: base.tableId,
|
|
131
|
-
key: attr.key,
|
|
132
|
-
type,
|
|
133
|
-
required,
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
/**
|
|
138
|
-
* Map a schema Attribute into DatabaseAdapter UpdateAttributeParams
|
|
139
|
-
* Omits fields that are not explicitly provided, and guards enum updates
|
|
140
|
-
* so we never send an empty elements array (preserve existing on server).
|
|
141
|
-
*/
|
|
142
|
-
export function mapToUpdateAttributeParams(attr, base) {
|
|
143
|
-
const type = String(attr.type || "").toLowerCase();
|
|
144
|
-
const params = {
|
|
145
|
-
databaseId: base.databaseId,
|
|
146
|
-
tableId: base.tableId,
|
|
147
|
-
key: attr.key,
|
|
148
|
-
};
|
|
149
|
-
const setIfDefined = (key, value) => {
|
|
150
|
-
if (value !== undefined)
|
|
151
|
-
params[key] = value;
|
|
152
|
-
};
|
|
153
|
-
// Common fields
|
|
154
|
-
setIfDefined("type", type);
|
|
155
|
-
setIfDefined("required", attr.required);
|
|
156
|
-
// Only send default if explicitly provided and not on required
|
|
157
|
-
if (!attr.required && attr.xdefault !== undefined) {
|
|
158
|
-
setIfDefined("default", attr.xdefault);
|
|
159
|
-
}
|
|
160
|
-
setIfDefined("array", attr.array);
|
|
161
|
-
// encrypt only applies to string types
|
|
162
|
-
if (type === "string")
|
|
163
|
-
setIfDefined("encrypt", attr.encrypt);
|
|
164
|
-
// Numeric normalization
|
|
165
|
-
const toNum = (n) => (n === null || n === undefined ? undefined : (Number(n)));
|
|
166
|
-
let min = toNum(attr.min);
|
|
167
|
-
let max = toNum(attr.max);
|
|
168
|
-
if (min !== undefined && max !== undefined && min >= max) {
|
|
169
|
-
const tmp = min;
|
|
170
|
-
min = Math.min(min, max);
|
|
171
|
-
max = Math.max(tmp, max);
|
|
172
|
-
if (min === max)
|
|
173
|
-
max = undefined;
|
|
174
|
-
}
|
|
175
|
-
switch (type) {
|
|
176
|
-
case "string":
|
|
177
|
-
setIfDefined("size", attr.size);
|
|
178
|
-
break;
|
|
179
|
-
case "integer":
|
|
180
|
-
case "float":
|
|
181
|
-
case "double":
|
|
182
|
-
setIfDefined("min", min);
|
|
183
|
-
setIfDefined("max", max);
|
|
184
|
-
break;
|
|
185
|
-
case "enum": {
|
|
186
|
-
const elements = attr.elements;
|
|
187
|
-
if (Array.isArray(elements) && elements.length > 0) {
|
|
188
|
-
// Only include when non-empty; otherwise preserve existing on server
|
|
189
|
-
setIfDefined("elements", elements);
|
|
190
|
-
}
|
|
191
|
-
break;
|
|
192
|
-
}
|
|
193
|
-
case "relationship": {
|
|
194
|
-
setIfDefined("relatedCollection", attr.relatedCollection);
|
|
195
|
-
setIfDefined("relationType", attr.relationType);
|
|
196
|
-
setIfDefined("twoWay", attr.twoWay);
|
|
197
|
-
setIfDefined("twoWayKey", attr.twoWayKey);
|
|
198
|
-
setIfDefined("onDelete", attr.onDelete);
|
|
199
|
-
break;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
return params;
|
|
203
|
-
}
|
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Shared error handling utilities for consistent error processing
|
|
3
|
-
*/
|
|
4
|
-
/**
|
|
5
|
-
* Extracts error message from unknown error type
|
|
6
|
-
* @param error - Error of unknown type
|
|
7
|
-
* @returns String error message
|
|
8
|
-
*/
|
|
9
|
-
export declare function getErrorMessage(error: unknown): string;
|
|
10
|
-
/**
|
|
11
|
-
* Normalizes unknown error to Error instance
|
|
12
|
-
* @param error - Error of unknown type
|
|
13
|
-
* @returns Normalized Error object
|
|
14
|
-
*/
|
|
15
|
-
export declare function normalizeError(error: unknown): Error;
|
|
16
|
-
/**
|
|
17
|
-
* Checks if error is a conflict error (409)
|
|
18
|
-
* @param error - Error object to check
|
|
19
|
-
* @returns True if error is a conflict (duplicate resource)
|
|
20
|
-
*/
|
|
21
|
-
export declare function isConflictError(error: any): boolean;
|
|
22
|
-
/**
|
|
23
|
-
* Checks if error is a Cloudflare error (522)
|
|
24
|
-
* @param error - Error object to check
|
|
25
|
-
* @returns True if error is from Cloudflare connection timeout
|
|
26
|
-
*/
|
|
27
|
-
export declare function isCloudflareError(error: any): boolean;
|
|
28
|
-
/**
|
|
29
|
-
* Checks if error is authentication/authorization related
|
|
30
|
-
* @param error - Error object to check
|
|
31
|
-
* @returns True if error is auth-related (401, 403)
|
|
32
|
-
*/
|
|
33
|
-
export declare function isAuthError(error: any): boolean;
|
|
34
|
-
/**
|
|
35
|
-
* Error categorization helpers for smart fallback logic
|
|
36
|
-
*/
|
|
37
|
-
/**
|
|
38
|
-
* Checks if an error is retryable (network issues, rate limits, etc.)
|
|
39
|
-
* @param errorMessage - Error message to check
|
|
40
|
-
* @returns True if error is retryable
|
|
41
|
-
*/
|
|
42
|
-
export declare function isRetryableError(errorMessage: string): boolean;
|
|
43
|
-
/**
|
|
44
|
-
* Checks if an error indicates bulk operations are not supported
|
|
45
|
-
* @param errorMessage - Error message to check
|
|
46
|
-
* @returns True if bulk operations not supported
|
|
47
|
-
*/
|
|
48
|
-
export declare function isBulkNotSupportedError(errorMessage: string): boolean;
|
|
49
|
-
/**
|
|
50
|
-
* Checks if an error is critical (authentication, authorization, permissions)
|
|
51
|
-
* @param errorMessage - Error message to check
|
|
52
|
-
* @returns True if error is critical
|
|
53
|
-
*/
|
|
54
|
-
export declare function isCriticalError(errorMessage: string): boolean;
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Shared error handling utilities for consistent error processing
|
|
3
|
-
*/
|
|
4
|
-
/**
|
|
5
|
-
* Extracts error message from unknown error type
|
|
6
|
-
* @param error - Error of unknown type
|
|
7
|
-
* @returns String error message
|
|
8
|
-
*/
|
|
9
|
-
export function getErrorMessage(error) {
|
|
10
|
-
return error instanceof Error ? error.message : String(error);
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Normalizes unknown error to Error instance
|
|
14
|
-
* @param error - Error of unknown type
|
|
15
|
-
* @returns Normalized Error object
|
|
16
|
-
*/
|
|
17
|
-
export function normalizeError(error) {
|
|
18
|
-
return error instanceof Error ? error : new Error(String(error));
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Checks if error is a conflict error (409)
|
|
22
|
-
* @param error - Error object to check
|
|
23
|
-
* @returns True if error is a conflict (duplicate resource)
|
|
24
|
-
*/
|
|
25
|
-
export function isConflictError(error) {
|
|
26
|
-
return error?.code === 409 || (error?.message?.toLowerCase().includes('already exists') ?? false);
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Checks if error is a Cloudflare error (522)
|
|
30
|
-
* @param error - Error object to check
|
|
31
|
-
* @returns True if error is from Cloudflare connection timeout
|
|
32
|
-
*/
|
|
33
|
-
export function isCloudflareError(error) {
|
|
34
|
-
return error?.code === 522 || error?.code === "522";
|
|
35
|
-
}
|
|
36
|
-
/**
|
|
37
|
-
* Checks if error is authentication/authorization related
|
|
38
|
-
* @param error - Error object to check
|
|
39
|
-
* @returns True if error is auth-related (401, 403)
|
|
40
|
-
*/
|
|
41
|
-
export function isAuthError(error) {
|
|
42
|
-
const code = error?.code;
|
|
43
|
-
return code === 401 || code === 403 || code === "401" || code === "403";
|
|
44
|
-
}
|
|
45
|
-
/**
|
|
46
|
-
* Error categorization helpers for smart fallback logic
|
|
47
|
-
*/
|
|
48
|
-
/**
|
|
49
|
-
* Checks if an error is retryable (network issues, rate limits, etc.)
|
|
50
|
-
* @param errorMessage - Error message to check
|
|
51
|
-
* @returns True if error is retryable
|
|
52
|
-
*/
|
|
53
|
-
export function isRetryableError(errorMessage) {
|
|
54
|
-
const retryableErrors = [
|
|
55
|
-
"rate limit",
|
|
56
|
-
"timeout",
|
|
57
|
-
"network",
|
|
58
|
-
"temporary",
|
|
59
|
-
"503",
|
|
60
|
-
"502",
|
|
61
|
-
"429"
|
|
62
|
-
];
|
|
63
|
-
return retryableErrors.some(error => errorMessage.toLowerCase().includes(error));
|
|
64
|
-
}
|
|
65
|
-
/**
|
|
66
|
-
* Checks if an error indicates bulk operations are not supported
|
|
67
|
-
* @param errorMessage - Error message to check
|
|
68
|
-
* @returns True if bulk operations not supported
|
|
69
|
-
*/
|
|
70
|
-
export function isBulkNotSupportedError(errorMessage) {
|
|
71
|
-
const notSupportedErrors = [
|
|
72
|
-
"method not found",
|
|
73
|
-
"not implemented",
|
|
74
|
-
"unsupported",
|
|
75
|
-
"not available",
|
|
76
|
-
"404"
|
|
77
|
-
];
|
|
78
|
-
return notSupportedErrors.some(error => errorMessage.toLowerCase().includes(error));
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
|
-
* Checks if an error is critical (authentication, authorization, permissions)
|
|
82
|
-
* @param errorMessage - Error message to check
|
|
83
|
-
* @returns True if error is critical
|
|
84
|
-
*/
|
|
85
|
-
export function isCriticalError(errorMessage) {
|
|
86
|
-
const criticalErrors = [
|
|
87
|
-
"authentication",
|
|
88
|
-
"authorization",
|
|
89
|
-
"permission",
|
|
90
|
-
"forbidden",
|
|
91
|
-
"401",
|
|
92
|
-
"403"
|
|
93
|
-
];
|
|
94
|
-
return criticalErrors.some(error => errorMessage.toLowerCase().includes(error));
|
|
95
|
-
}
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
import { Client, type Models } from "node-appwrite";
|
|
2
|
-
import { type AppwriteFunction } from "@njdamstra/appwrite-utils";
|
|
3
|
-
export interface FunctionSearchOptions {
|
|
4
|
-
searchPaths?: string[];
|
|
5
|
-
caseSensitive?: boolean;
|
|
6
|
-
allowFuzzyMatch?: boolean;
|
|
7
|
-
verbose?: boolean;
|
|
8
|
-
}
|
|
9
|
-
export interface FunctionDeploymentOptions {
|
|
10
|
-
activate?: boolean;
|
|
11
|
-
entrypoint?: string;
|
|
12
|
-
commands?: string;
|
|
13
|
-
ignored?: string[];
|
|
14
|
-
verbose?: boolean;
|
|
15
|
-
forceRedeploy?: boolean;
|
|
16
|
-
}
|
|
17
|
-
export declare class FunctionManager {
|
|
18
|
-
private client;
|
|
19
|
-
private functions;
|
|
20
|
-
constructor(client: Client);
|
|
21
|
-
/**
|
|
22
|
-
* Improved function directory detection with multiple strategies
|
|
23
|
-
*/
|
|
24
|
-
findFunctionDirectory(functionName: string, options?: FunctionSearchOptions): Promise<string | null>;
|
|
25
|
-
private generateNameVariations;
|
|
26
|
-
private getStandardFunctionPaths;
|
|
27
|
-
private recursiveDirectorySearch;
|
|
28
|
-
private shouldSkipDirectory;
|
|
29
|
-
private isValidFunctionDirectory;
|
|
30
|
-
/**
|
|
31
|
-
* Enhanced function deployment with better error handling and validation
|
|
32
|
-
*/
|
|
33
|
-
deployFunction(functionConfig: AppwriteFunction, functionPath: string, options?: FunctionDeploymentOptions): Promise<Models.Deployment>;
|
|
34
|
-
private createFunction;
|
|
35
|
-
private updateFunction;
|
|
36
|
-
private executePredeployCommands;
|
|
37
|
-
private createDeployment;
|
|
38
|
-
getFunction(functionId: string): Promise<Models.Function>;
|
|
39
|
-
listFunctions(): Promise<Models.FunctionList>;
|
|
40
|
-
deleteFunction(functionId: string): Promise<void>;
|
|
41
|
-
/**
|
|
42
|
-
* Validate function configuration
|
|
43
|
-
*/
|
|
44
|
-
validateFunctionConfig(functionConfig: AppwriteFunction): {
|
|
45
|
-
valid: boolean;
|
|
46
|
-
errors: string[];
|
|
47
|
-
};
|
|
48
|
-
}
|