@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.
Files changed (285) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/CONFIG_TODO.md +1189 -0
  3. package/SELECTION_DIALOGS.md +146 -0
  4. package/SERVICE_IMPLEMENTATION_REPORT.md +462 -0
  5. package/dist/adapters/index.d.ts +7 -8
  6. package/dist/adapters/index.js +7 -9
  7. package/dist/backups/operations/bucketBackup.js +2 -2
  8. package/dist/backups/operations/collectionBackup.d.ts +1 -1
  9. package/dist/backups/operations/collectionBackup.js +3 -3
  10. package/dist/backups/operations/comprehensiveBackup.d.ts +1 -1
  11. package/dist/backups/operations/comprehensiveBackup.js +2 -2
  12. package/dist/backups/tracking/centralizedTracking.d.ts +1 -1
  13. package/dist/backups/tracking/centralizedTracking.js +2 -2
  14. package/dist/cli/commands/configCommands.js +51 -7
  15. package/dist/cli/commands/databaseCommands.d.ts +1 -0
  16. package/dist/cli/commands/databaseCommands.js +119 -9
  17. package/dist/cli/commands/functionCommands.js +3 -3
  18. package/dist/cli/commands/importFileCommands.d.ts +7 -0
  19. package/dist/cli/commands/importFileCommands.js +674 -0
  20. package/dist/cli/commands/schemaCommands.js +3 -3
  21. package/dist/cli/commands/storageCommands.js +2 -3
  22. package/dist/cli/commands/transferCommands.js +3 -5
  23. package/dist/collections/attributes.d.ts +1 -1
  24. package/dist/collections/attributes.js +85 -35
  25. package/dist/collections/indexes.js +2 -4
  26. package/dist/collections/methods.d.ts +1 -1
  27. package/dist/collections/methods.js +111 -192
  28. package/dist/collections/tableOperations.d.ts +1 -0
  29. package/dist/collections/tableOperations.js +90 -23
  30. package/dist/collections/transferOperations.d.ts +1 -1
  31. package/dist/collections/transferOperations.js +3 -4
  32. package/dist/collections/wipeOperations.d.ts +4 -3
  33. package/dist/collections/wipeOperations.js +112 -39
  34. package/dist/databases/methods.js +2 -2
  35. package/dist/databases/setup.js +2 -2
  36. package/dist/examples/yamlTerminologyExample.js +2 -2
  37. package/dist/functions/deployments.d.ts +1 -1
  38. package/dist/functions/deployments.js +5 -5
  39. package/dist/functions/fnConfigDiscovery.js +2 -2
  40. package/dist/functions/methods.js +16 -4
  41. package/dist/init.js +1 -1
  42. package/dist/interactiveCLI.d.ts +6 -1
  43. package/dist/interactiveCLI.js +64 -10
  44. package/dist/main.js +130 -177
  45. package/dist/migrations/afterImportActions.js +2 -3
  46. package/dist/migrations/appwriteToX.d.ts +97 -1
  47. package/dist/migrations/appwriteToX.js +9 -7
  48. package/dist/migrations/comprehensiveTransfer.js +3 -5
  49. package/dist/migrations/dataLoader.d.ts +194 -2
  50. package/dist/migrations/dataLoader.js +2 -5
  51. package/dist/migrations/importController.js +3 -4
  52. package/dist/migrations/importDataActions.js +3 -3
  53. package/dist/migrations/relationships.js +1 -2
  54. package/dist/migrations/services/DataTransformationService.js +2 -2
  55. package/dist/migrations/services/FileHandlerService.js +1 -1
  56. package/dist/migrations/services/ImportOrchestrator.js +4 -4
  57. package/dist/migrations/services/RateLimitManager.js +1 -1
  58. package/dist/migrations/services/RelationshipResolver.js +1 -1
  59. package/dist/migrations/services/UserMappingService.js +1 -1
  60. package/dist/migrations/services/ValidationService.js +1 -1
  61. package/dist/migrations/transfer.d.ts +8 -4
  62. package/dist/migrations/transfer.js +106 -55
  63. package/dist/migrations/yaml/YamlImportConfigLoader.js +1 -1
  64. package/dist/migrations/yaml/YamlImportIntegration.js +2 -2
  65. package/dist/migrations/yaml/generateImportSchemas.js +1 -1
  66. package/dist/setupCommands.d.ts +1 -1
  67. package/dist/setupCommands.js +5 -6
  68. package/dist/setupController.js +1 -1
  69. package/dist/shared/backupTracking.d.ts +1 -1
  70. package/dist/shared/backupTracking.js +2 -2
  71. package/dist/shared/confirmationDialogs.js +1 -1
  72. package/dist/shared/migrationHelpers.d.ts +1 -1
  73. package/dist/shared/migrationHelpers.js +3 -3
  74. package/dist/shared/operationQueue.d.ts +1 -1
  75. package/dist/shared/operationQueue.js +2 -3
  76. package/dist/shared/operationsTable.d.ts +1 -1
  77. package/dist/shared/operationsTable.js +2 -2
  78. package/dist/shared/progressManager.js +1 -1
  79. package/dist/shared/selectionDialogs.js +9 -8
  80. package/dist/storage/methods.js +4 -4
  81. package/dist/storage/schemas.d.ts +386 -2
  82. package/dist/tables/indexManager.d.ts +65 -0
  83. package/dist/tables/indexManager.js +294 -0
  84. package/dist/types.d.ts +2 -2
  85. package/dist/types.js +1 -1
  86. package/dist/users/methods.js +2 -3
  87. package/dist/utils/configMigration.js +1 -1
  88. package/dist/utils/index.d.ts +1 -1
  89. package/dist/utils/index.js +1 -1
  90. package/dist/utils/loadConfigs.d.ts +2 -2
  91. package/dist/utils/loadConfigs.js +6 -7
  92. package/dist/utils/setupFiles.js +5 -7
  93. package/dist/utilsController.d.ts +15 -8
  94. package/dist/utilsController.js +57 -28
  95. package/package.json +8 -4
  96. package/src/adapters/index.ts +8 -34
  97. package/src/backups/operations/bucketBackup.ts +2 -2
  98. package/src/backups/operations/collectionBackup.ts +4 -4
  99. package/src/backups/operations/comprehensiveBackup.ts +3 -3
  100. package/src/backups/tracking/centralizedTracking.ts +3 -3
  101. package/src/cli/commands/configCommands.ts +72 -8
  102. package/src/cli/commands/databaseCommands.ts +161 -9
  103. package/src/cli/commands/functionCommands.ts +4 -3
  104. package/src/cli/commands/importFileCommands.ts +815 -0
  105. package/src/cli/commands/schemaCommands.ts +3 -3
  106. package/src/cli/commands/storageCommands.ts +2 -3
  107. package/src/cli/commands/transferCommands.ts +3 -6
  108. package/src/collections/attributes.ts +155 -39
  109. package/src/collections/indexes.ts +5 -7
  110. package/src/collections/methods.ts +115 -150
  111. package/src/collections/tableOperations.ts +92 -21
  112. package/src/collections/transferOperations.ts +4 -5
  113. package/src/collections/wipeOperations.ts +154 -51
  114. package/src/databases/methods.ts +2 -2
  115. package/src/databases/setup.ts +2 -2
  116. package/src/examples/yamlTerminologyExample.ts +2 -2
  117. package/src/functions/deployments.ts +6 -5
  118. package/src/functions/fnConfigDiscovery.ts +2 -2
  119. package/src/functions/methods.ts +19 -6
  120. package/src/init.ts +1 -1
  121. package/src/interactiveCLI.ts +78 -13
  122. package/src/main.ts +143 -287
  123. package/src/migrations/afterImportActions.ts +2 -3
  124. package/src/migrations/appwriteToX.ts +12 -8
  125. package/src/migrations/comprehensiveTransfer.ts +6 -6
  126. package/src/migrations/dataLoader.ts +2 -5
  127. package/src/migrations/importController.ts +3 -4
  128. package/src/migrations/importDataActions.ts +3 -3
  129. package/src/migrations/relationships.ts +1 -2
  130. package/src/migrations/services/DataTransformationService.ts +2 -2
  131. package/src/migrations/services/FileHandlerService.ts +1 -1
  132. package/src/migrations/services/ImportOrchestrator.ts +4 -4
  133. package/src/migrations/services/RateLimitManager.ts +1 -1
  134. package/src/migrations/services/RelationshipResolver.ts +1 -1
  135. package/src/migrations/services/UserMappingService.ts +1 -1
  136. package/src/migrations/services/ValidationService.ts +1 -1
  137. package/src/migrations/transfer.ts +126 -83
  138. package/src/migrations/yaml/YamlImportConfigLoader.ts +1 -1
  139. package/src/migrations/yaml/YamlImportIntegration.ts +2 -2
  140. package/src/migrations/yaml/generateImportSchemas.ts +1 -1
  141. package/src/setupCommands.ts +5 -6
  142. package/src/setupController.ts +1 -1
  143. package/src/shared/backupTracking.ts +3 -3
  144. package/src/shared/confirmationDialogs.ts +1 -1
  145. package/src/shared/migrationHelpers.ts +4 -4
  146. package/src/shared/operationQueue.ts +3 -4
  147. package/src/shared/operationsTable.ts +3 -3
  148. package/src/shared/progressManager.ts +1 -1
  149. package/src/shared/selectionDialogs.ts +9 -8
  150. package/src/storage/methods.ts +4 -4
  151. package/src/tables/indexManager.ts +409 -0
  152. package/src/types.ts +2 -2
  153. package/src/users/methods.ts +2 -3
  154. package/src/utils/configMigration.ts +1 -1
  155. package/src/utils/index.ts +1 -1
  156. package/src/utils/loadConfigs.ts +15 -7
  157. package/src/utils/setupFiles.ts +5 -7
  158. package/src/utilsController.ts +86 -32
  159. package/dist/adapters/AdapterFactory.d.ts +0 -94
  160. package/dist/adapters/AdapterFactory.js +0 -405
  161. package/dist/adapters/DatabaseAdapter.d.ts +0 -233
  162. package/dist/adapters/DatabaseAdapter.js +0 -50
  163. package/dist/adapters/LegacyAdapter.d.ts +0 -50
  164. package/dist/adapters/LegacyAdapter.js +0 -612
  165. package/dist/adapters/TablesDBAdapter.d.ts +0 -45
  166. package/dist/adapters/TablesDBAdapter.js +0 -571
  167. package/dist/config/ConfigManager.d.ts +0 -445
  168. package/dist/config/ConfigManager.js +0 -625
  169. package/dist/config/configMigration.d.ts +0 -87
  170. package/dist/config/configMigration.js +0 -390
  171. package/dist/config/configValidation.d.ts +0 -66
  172. package/dist/config/configValidation.js +0 -358
  173. package/dist/config/index.d.ts +0 -8
  174. package/dist/config/index.js +0 -7
  175. package/dist/config/services/ConfigDiscoveryService.d.ts +0 -126
  176. package/dist/config/services/ConfigDiscoveryService.js +0 -374
  177. package/dist/config/services/ConfigLoaderService.d.ts +0 -129
  178. package/dist/config/services/ConfigLoaderService.js +0 -540
  179. package/dist/config/services/ConfigMergeService.d.ts +0 -208
  180. package/dist/config/services/ConfigMergeService.js +0 -308
  181. package/dist/config/services/ConfigValidationService.d.ts +0 -214
  182. package/dist/config/services/ConfigValidationService.js +0 -310
  183. package/dist/config/services/SessionAuthService.d.ts +0 -225
  184. package/dist/config/services/SessionAuthService.js +0 -456
  185. package/dist/config/services/__tests__/ConfigMergeService.test.d.ts +0 -1
  186. package/dist/config/services/__tests__/ConfigMergeService.test.js +0 -271
  187. package/dist/config/services/index.d.ts +0 -13
  188. package/dist/config/services/index.js +0 -10
  189. package/dist/config/yamlConfig.d.ts +0 -722
  190. package/dist/config/yamlConfig.js +0 -702
  191. package/dist/functions/pathResolution.d.ts +0 -37
  192. package/dist/functions/pathResolution.js +0 -185
  193. package/dist/shared/attributeMapper.d.ts +0 -20
  194. package/dist/shared/attributeMapper.js +0 -203
  195. package/dist/shared/errorUtils.d.ts +0 -54
  196. package/dist/shared/errorUtils.js +0 -95
  197. package/dist/shared/functionManager.d.ts +0 -48
  198. package/dist/shared/functionManager.js +0 -336
  199. package/dist/shared/indexManager.d.ts +0 -24
  200. package/dist/shared/indexManager.js +0 -151
  201. package/dist/shared/jsonSchemaGenerator.d.ts +0 -50
  202. package/dist/shared/jsonSchemaGenerator.js +0 -290
  203. package/dist/shared/logging.d.ts +0 -61
  204. package/dist/shared/logging.js +0 -116
  205. package/dist/shared/messageFormatter.d.ts +0 -39
  206. package/dist/shared/messageFormatter.js +0 -162
  207. package/dist/shared/pydanticModelGenerator.d.ts +0 -17
  208. package/dist/shared/pydanticModelGenerator.js +0 -615
  209. package/dist/shared/schemaGenerator.d.ts +0 -40
  210. package/dist/shared/schemaGenerator.js +0 -556
  211. package/dist/utils/ClientFactory.d.ts +0 -87
  212. package/dist/utils/ClientFactory.js +0 -212
  213. package/dist/utils/configDiscovery.d.ts +0 -78
  214. package/dist/utils/configDiscovery.js +0 -472
  215. package/dist/utils/constantsGenerator.d.ts +0 -31
  216. package/dist/utils/constantsGenerator.js +0 -321
  217. package/dist/utils/dataConverters.d.ts +0 -46
  218. package/dist/utils/dataConverters.js +0 -139
  219. package/dist/utils/directoryUtils.d.ts +0 -22
  220. package/dist/utils/directoryUtils.js +0 -59
  221. package/dist/utils/getClientFromConfig.d.ts +0 -39
  222. package/dist/utils/getClientFromConfig.js +0 -199
  223. package/dist/utils/helperFunctions.d.ts +0 -63
  224. package/dist/utils/helperFunctions.js +0 -156
  225. package/dist/utils/pathResolvers.d.ts +0 -53
  226. package/dist/utils/pathResolvers.js +0 -72
  227. package/dist/utils/projectConfig.d.ts +0 -119
  228. package/dist/utils/projectConfig.js +0 -171
  229. package/dist/utils/retryFailedPromises.d.ts +0 -2
  230. package/dist/utils/retryFailedPromises.js +0 -23
  231. package/dist/utils/sessionAuth.d.ts +0 -48
  232. package/dist/utils/sessionAuth.js +0 -164
  233. package/dist/utils/typeGuards.d.ts +0 -35
  234. package/dist/utils/typeGuards.js +0 -57
  235. package/dist/utils/validationRules.d.ts +0 -43
  236. package/dist/utils/validationRules.js +0 -42
  237. package/dist/utils/versionDetection.d.ts +0 -58
  238. package/dist/utils/versionDetection.js +0 -251
  239. package/dist/utils/yamlConverter.d.ts +0 -100
  240. package/dist/utils/yamlConverter.js +0 -428
  241. package/dist/utils/yamlLoader.d.ts +0 -70
  242. package/dist/utils/yamlLoader.js +0 -267
  243. package/src/adapters/AdapterFactory.ts +0 -510
  244. package/src/adapters/DatabaseAdapter.ts +0 -306
  245. package/src/adapters/LegacyAdapter.ts +0 -841
  246. package/src/adapters/TablesDBAdapter.ts +0 -773
  247. package/src/config/ConfigManager.ts +0 -808
  248. package/src/config/README.md +0 -274
  249. package/src/config/configMigration.ts +0 -575
  250. package/src/config/configValidation.ts +0 -445
  251. package/src/config/index.ts +0 -10
  252. package/src/config/services/ConfigDiscoveryService.ts +0 -463
  253. package/src/config/services/ConfigLoaderService.ts +0 -740
  254. package/src/config/services/ConfigMergeService.ts +0 -388
  255. package/src/config/services/ConfigValidationService.ts +0 -394
  256. package/src/config/services/SessionAuthService.ts +0 -565
  257. package/src/config/services/__tests__/ConfigMergeService.test.ts +0 -351
  258. package/src/config/services/index.ts +0 -29
  259. package/src/config/yamlConfig.ts +0 -761
  260. package/src/functions/pathResolution.ts +0 -227
  261. package/src/shared/attributeMapper.ts +0 -229
  262. package/src/shared/errorUtils.ts +0 -110
  263. package/src/shared/functionManager.ts +0 -525
  264. package/src/shared/indexManager.ts +0 -254
  265. package/src/shared/jsonSchemaGenerator.ts +0 -383
  266. package/src/shared/logging.ts +0 -149
  267. package/src/shared/messageFormatter.ts +0 -208
  268. package/src/shared/pydanticModelGenerator.ts +0 -618
  269. package/src/shared/schemaGenerator.ts +0 -644
  270. package/src/utils/ClientFactory.ts +0 -240
  271. package/src/utils/configDiscovery.ts +0 -557
  272. package/src/utils/constantsGenerator.ts +0 -369
  273. package/src/utils/dataConverters.ts +0 -159
  274. package/src/utils/directoryUtils.ts +0 -61
  275. package/src/utils/getClientFromConfig.ts +0 -257
  276. package/src/utils/helperFunctions.ts +0 -228
  277. package/src/utils/pathResolvers.ts +0 -81
  278. package/src/utils/projectConfig.ts +0 -299
  279. package/src/utils/retryFailedPromises.ts +0 -29
  280. package/src/utils/sessionAuth.ts +0 -230
  281. package/src/utils/typeGuards.ts +0 -65
  282. package/src/utils/validationRules.ts +0 -88
  283. package/src/utils/versionDetection.ts +0 -292
  284. package/src/utils/yamlConverter.ts +0 -542
  285. package/src/utils/yamlLoader.ts +0 -371
@@ -1,149 +0,0 @@
1
- import winston from "winston";
2
- import fs from "fs";
3
- import path from "path";
4
-
5
- export interface LoggingConfig {
6
- enabled: boolean;
7
- level: string;
8
- logDirectory?: string;
9
- console: boolean;
10
- }
11
-
12
- /**
13
- * Predefined logging configurations for common debugging scenarios
14
- */
15
- export const LOGGING_PRESETS = {
16
- /** Minimal logging - errors only to console */
17
- minimal: {
18
- enabled: false,
19
- level: 'error',
20
- console: true
21
- },
22
- /** Standard logging - info level to file and console */
23
- standard: {
24
- enabled: true,
25
- level: 'info',
26
- console: true
27
- },
28
- /** Debug logging - verbose debug output for troubleshooting */
29
- debug: {
30
- enabled: true,
31
- level: 'debug',
32
- console: true
33
- },
34
- /** Silent - no logging output */
35
- silent: {
36
- enabled: false,
37
- level: 'error',
38
- console: false
39
- }
40
- } as const;
41
-
42
- const DEFAULT_LOGGING_CONFIG: LoggingConfig = {
43
- enabled: false,
44
- level: "info",
45
- console: false,
46
- };
47
-
48
- let loggingConfig: LoggingConfig = DEFAULT_LOGGING_CONFIG;
49
-
50
- export const configureLogging = (config: Partial<LoggingConfig> = {}) => {
51
- loggingConfig = { ...DEFAULT_LOGGING_CONFIG, ...config };
52
- };
53
-
54
- /**
55
- * Configure logging using a preset
56
- */
57
- export const configureLoggingPreset = (preset: keyof typeof LOGGING_PRESETS, logDirectory?: string) => {
58
- const presetConfig = LOGGING_PRESETS[preset];
59
- configureLogging({
60
- ...presetConfig,
61
- ...(logDirectory && { logDirectory })
62
- });
63
- updateLogger();
64
- };
65
-
66
- const createLogger = () => {
67
- const transports: winston.transport[] = [];
68
-
69
- // Add console transport if enabled
70
- if (loggingConfig.console) {
71
- transports.push(new winston.transports.Console({
72
- format: winston.format.combine(
73
- winston.format.colorize(),
74
- winston.format.simple()
75
- )
76
- }));
77
- }
78
-
79
- // Add file transports if logging is enabled
80
- if (loggingConfig.enabled) {
81
- const logDir = loggingConfig.logDirectory || path.join(process.cwd(), "zlogs");
82
-
83
- if (!fs.existsSync(logDir)) {
84
- fs.mkdirSync(logDir, { recursive: true });
85
- }
86
-
87
- transports.push(
88
- new winston.transports.File({
89
- filename: path.join(logDir, "error.log"),
90
- level: "error",
91
- }),
92
- new winston.transports.File({
93
- filename: path.join(logDir, "combined.log"),
94
- })
95
- );
96
- }
97
-
98
- return winston.createLogger({
99
- level: loggingConfig.level,
100
- format: winston.format.combine(
101
- winston.format.timestamp(),
102
- winston.format.errors({ stack: true }),
103
- winston.format.json()
104
- ),
105
- defaultMeta: { service: "@njdamstra/appwrite-utils-cli" },
106
- transports,
107
- silent: !loggingConfig.enabled && !loggingConfig.console,
108
- });
109
- };
110
-
111
- export let logger = createLogger();
112
-
113
- // Recreate logger when config changes
114
- export const updateLogger = () => {
115
- logger = createLogger();
116
- };
117
-
118
- /**
119
- * Enable debug logging for troubleshooting push process issues
120
- * This is a convenience function for quickly enabling comprehensive logging
121
- */
122
- export const enableDebugLogging = (logDirectory?: string) => {
123
- configureLogging({
124
- enabled: true,
125
- level: 'debug',
126
- console: true,
127
- logDirectory
128
- });
129
- updateLogger();
130
- logger.info('Debug logging enabled for push process troubleshooting', {
131
- level: 'debug',
132
- console: true,
133
- logDirectory: logDirectory || 'zlogs',
134
- operation: 'enableDebugLogging'
135
- });
136
- };
137
-
138
- /**
139
- * Disable logging (reset to default)
140
- */
141
- export const disableLogging = () => {
142
- configureLogging(DEFAULT_LOGGING_CONFIG);
143
- updateLogger();
144
- };
145
-
146
- /**
147
- * Get current logging configuration
148
- */
149
- export const getLoggingConfig = () => ({ ...loggingConfig });
@@ -1,208 +0,0 @@
1
- import chalk from "chalk";
2
- import { logger } from "./logging.js";
3
-
4
- export interface MessageOptions {
5
- prefix?: string;
6
- skipLogging?: boolean;
7
- logLevel?: "info" | "warn" | "error" | "debug";
8
- }
9
-
10
- export class MessageFormatter {
11
- static success(message: string, options: MessageOptions = {}) {
12
- const formatted = `${chalk.green("✅")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
13
- console.log(formatted);
14
-
15
- if (!options.skipLogging) {
16
- logger.info(`SUCCESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
17
- }
18
- }
19
-
20
- static error(message: string, error?: Error | string, options: MessageOptions = {}) {
21
- const errorDetails = error instanceof Error ? error.message : error;
22
- const formatted = `${chalk.red("❌")} ${options.prefix ? `${options.prefix}: ` : ""}${message}${errorDetails ? `\n ${chalk.gray(errorDetails)}` : ""}`;
23
- console.error(formatted);
24
-
25
- if (!options.skipLogging) {
26
- logger.error(`ERROR: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, {
27
- error: errorDetails,
28
- stack: error instanceof Error ? error.stack : undefined,
29
- });
30
- }
31
- }
32
-
33
- static warning(message: string, options: MessageOptions = {}) {
34
- const formatted = `${chalk.yellow("⚠️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
35
- console.log(formatted);
36
-
37
- if (!options.skipLogging) {
38
- logger.warn(`WARNING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
39
- }
40
- }
41
-
42
- static info(message: string, options: MessageOptions = {}) {
43
- const formatted = `${chalk.blue("ℹ️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
44
- console.log(formatted);
45
-
46
- if (!options.skipLogging) {
47
- logger.info(`INFO: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
48
- }
49
- }
50
-
51
- static step(step: number, total: number, message: string, options: MessageOptions = {}) {
52
- const formatted = `${chalk.cyan(`[${step}/${total}]`)} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
53
- console.log(formatted);
54
-
55
- if (!options.skipLogging) {
56
- logger.info(`STEP ${step}/${total}: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
57
- }
58
- }
59
-
60
- static progress(message: string, options: MessageOptions = {}) {
61
- const formatted = `${chalk.gray("⏳")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
62
- console.log(formatted);
63
-
64
- if (!options.skipLogging) {
65
- logger.debug(`PROGRESS: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
66
- }
67
- }
68
-
69
- static debug(message: string, data?: any, options: MessageOptions = {}) {
70
- if (process.env.NODE_ENV === "development" || process.env.DEBUG) {
71
- const formatted = `${chalk.magenta("🔍")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
72
- console.log(formatted);
73
- if (data) {
74
- console.log(chalk.gray(JSON.stringify(data, null, 2)));
75
- }
76
- }
77
-
78
- if (!options.skipLogging) {
79
- logger.debug(`DEBUG: ${options.prefix ? `${options.prefix}: ` : ""}${message}`, data);
80
- }
81
- }
82
-
83
- static processing(message: string, options: MessageOptions = {}) {
84
- const formatted = `${chalk.cyan("⚙️")} ${options.prefix ? `${options.prefix}: ` : ""}${message}`;
85
- console.log(formatted);
86
-
87
- if (!options.skipLogging) {
88
- logger.info(`PROCESSING: ${options.prefix ? `${options.prefix}: ` : ""}${message}`);
89
- }
90
- }
91
-
92
- static divider() {
93
- console.log(chalk.gray("─".repeat(60)));
94
- }
95
-
96
- static banner(title: string, subtitle?: string) {
97
- const divider = chalk.cyan("═".repeat(60));
98
- console.log(`\n${divider}`);
99
- console.log(chalk.cyan.bold(` ${title}`));
100
- if (subtitle) {
101
- console.log(chalk.gray(` ${subtitle}`));
102
- }
103
- console.log(`${divider}\n`);
104
- }
105
-
106
- static section(title: string) {
107
- console.log(`\n${chalk.bold.underline(title)}`);
108
- }
109
-
110
- static list(items: string[], title?: string) {
111
- if (title) {
112
- console.log(chalk.bold(title));
113
- }
114
- items.forEach((item, index) => {
115
- console.log(`${chalk.gray(` ${index + 1}.`)} ${item}`);
116
- });
117
- }
118
-
119
- static table(data: Record<string, string | number>[], headers?: string[]) {
120
- if (data.length === 0) return;
121
-
122
- const keys = headers || Object.keys(data[0]);
123
- const maxWidths = keys.map(key =>
124
- Math.max(
125
- key.length,
126
- ...data.map(row => String(row[key]).length)
127
- )
128
- );
129
-
130
- // Header
131
- const headerRow = keys.map((key, i) =>
132
- chalk.bold(key.padEnd(maxWidths[i]))
133
- ).join(" │ ");
134
- console.log(`┌─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┐`);
135
- console.log(`│ ${headerRow} │`);
136
- console.log(`├─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┼─")}─┤`);
137
-
138
- // Rows
139
- data.forEach(row => {
140
- const dataRow = keys.map((key, i) =>
141
- String(row[key]).padEnd(maxWidths[i])
142
- ).join(" │ ");
143
- console.log(`│ ${dataRow} │`);
144
- });
145
- console.log(`└─${keys.map((_, i) => "─".repeat(maxWidths[i])).join("─┴─")}─┘`);
146
- }
147
-
148
- static operationSummary(title: string, stats: Record<string, string | number>, duration?: number) {
149
- this.section(`${title} Summary`);
150
-
151
- Object.entries(stats).forEach(([key, value]) => {
152
- const formattedKey = key.replace(/([A-Z])/g, ' $1').replace(/^./, str => str.toUpperCase());
153
- console.log(`${chalk.gray("●")} ${formattedKey}: ${chalk.cyan(String(value))}`);
154
- });
155
-
156
- if (duration) {
157
- console.log(`${chalk.gray("●")} Duration: ${chalk.cyan(this.formatDuration(duration))}`);
158
- }
159
- console.log();
160
- }
161
-
162
- static formatBytes(bytes: number): string {
163
- const units = ['B', 'KB', 'MB', 'GB', 'TB'];
164
- let size = bytes;
165
- let unitIndex = 0;
166
-
167
- while (size >= 1024 && unitIndex < units.length - 1) {
168
- size /= 1024;
169
- unitIndex++;
170
- }
171
-
172
- return `${size.toFixed(1)} ${units[unitIndex]}`;
173
- }
174
-
175
- static formatDuration(ms: number): string {
176
- const seconds = Math.floor(ms / 1000);
177
- const minutes = Math.floor(seconds / 60);
178
- const hours = Math.floor(minutes / 60);
179
-
180
- if (hours > 0) {
181
- return `${hours}h ${minutes % 60}m ${seconds % 60}s`;
182
- } else if (minutes > 0) {
183
- return `${minutes}m ${seconds % 60}s`;
184
- } else {
185
- return `${seconds}s`;
186
- }
187
- }
188
-
189
- static formatNumber(num: number): string {
190
- return num.toLocaleString();
191
- }
192
- }
193
-
194
- export const Messages = {
195
- CONFIG_NOT_FOUND: "Appwrite configuration not found. Run 'appwrite-migrate setup' first.",
196
- CONFIG_LOADED: (type: string, path: string) => `Loaded ${type} configuration from ${path}`,
197
- DATABASE_CONNECTION_FAILED: "Failed to connect to Appwrite. Check your endpoint and API key.",
198
- OPERATION_CANCELLED: "Operation cancelled by user.",
199
- OPERATION_COMPLETED: (operation: string) => `${operation} completed successfully`,
200
- BACKUP_STARTED: (database: string) => `Starting backup for database: ${database}`,
201
- BACKUP_COMPLETED: (database: string, size: number) => `Backup completed for ${database} (${MessageFormatter.formatBytes(size)})`,
202
- IMPORT_STARTED: (collections: number) => `Starting import process for ${collections} collection(s)`,
203
- IMPORT_COMPLETED: (documents: number) => `Import completed. Processed ${MessageFormatter.formatNumber(documents)} documents`,
204
- FUNCTION_DEPLOYED: (name: string) => `Function '${name}' deployed successfully`,
205
- FUNCTION_DEPLOYMENT_FAILED: (name: string, error: string) => `Function '${name}' deployment failed: ${error}`,
206
- TRANSFER_STARTED: (source: string, target: string) => `Starting transfer from ${source} to ${target}`,
207
- TRANSFER_COMPLETED: (items: number) => `Transfer completed. Moved ${MessageFormatter.formatNumber(items)} items`,
208
- } as const;