@zintrust/workers 0.1.27

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 (178) hide show
  1. package/README.md +861 -0
  2. package/dist/AnomalyDetection.d.ts +102 -0
  3. package/dist/AnomalyDetection.js +321 -0
  4. package/dist/AutoScaler.d.ts +127 -0
  5. package/dist/AutoScaler.js +425 -0
  6. package/dist/BroadcastWorker.d.ts +21 -0
  7. package/dist/BroadcastWorker.js +24 -0
  8. package/dist/CanaryController.d.ts +103 -0
  9. package/dist/CanaryController.js +380 -0
  10. package/dist/ChaosEngineering.d.ts +79 -0
  11. package/dist/ChaosEngineering.js +216 -0
  12. package/dist/CircuitBreaker.d.ts +106 -0
  13. package/dist/CircuitBreaker.js +374 -0
  14. package/dist/ClusterLock.d.ts +90 -0
  15. package/dist/ClusterLock.js +385 -0
  16. package/dist/ComplianceManager.d.ts +177 -0
  17. package/dist/ComplianceManager.js +556 -0
  18. package/dist/DatacenterOrchestrator.d.ts +133 -0
  19. package/dist/DatacenterOrchestrator.js +404 -0
  20. package/dist/DeadLetterQueue.d.ts +122 -0
  21. package/dist/DeadLetterQueue.js +539 -0
  22. package/dist/HealthMonitor.d.ts +42 -0
  23. package/dist/HealthMonitor.js +301 -0
  24. package/dist/MultiQueueWorker.d.ts +89 -0
  25. package/dist/MultiQueueWorker.js +277 -0
  26. package/dist/NotificationWorker.d.ts +21 -0
  27. package/dist/NotificationWorker.js +23 -0
  28. package/dist/Observability.d.ts +153 -0
  29. package/dist/Observability.js +530 -0
  30. package/dist/PluginManager.d.ts +123 -0
  31. package/dist/PluginManager.js +392 -0
  32. package/dist/PriorityQueue.d.ts +117 -0
  33. package/dist/PriorityQueue.js +244 -0
  34. package/dist/ResourceMonitor.d.ts +164 -0
  35. package/dist/ResourceMonitor.js +605 -0
  36. package/dist/SLAMonitor.d.ts +110 -0
  37. package/dist/SLAMonitor.js +274 -0
  38. package/dist/WorkerFactory.d.ts +193 -0
  39. package/dist/WorkerFactory.js +1507 -0
  40. package/dist/WorkerInit.d.ts +85 -0
  41. package/dist/WorkerInit.js +223 -0
  42. package/dist/WorkerMetrics.d.ts +114 -0
  43. package/dist/WorkerMetrics.js +509 -0
  44. package/dist/WorkerRegistry.d.ts +145 -0
  45. package/dist/WorkerRegistry.js +319 -0
  46. package/dist/WorkerShutdown.d.ts +61 -0
  47. package/dist/WorkerShutdown.js +159 -0
  48. package/dist/WorkerVersioning.d.ts +107 -0
  49. package/dist/WorkerVersioning.js +300 -0
  50. package/dist/build-manifest.json +462 -0
  51. package/dist/config/workerConfig.d.ts +3 -0
  52. package/dist/config/workerConfig.js +19 -0
  53. package/dist/createQueueWorker.d.ts +23 -0
  54. package/dist/createQueueWorker.js +113 -0
  55. package/dist/dashboard/index.d.ts +1 -0
  56. package/dist/dashboard/index.js +1 -0
  57. package/dist/dashboard/types.d.ts +117 -0
  58. package/dist/dashboard/types.js +1 -0
  59. package/dist/dashboard/workers-api.d.ts +4 -0
  60. package/dist/dashboard/workers-api.js +638 -0
  61. package/dist/dashboard/workers-dashboard-ui.d.ts +3 -0
  62. package/dist/dashboard/workers-dashboard-ui.js +1026 -0
  63. package/dist/dashboard/workers-dashboard.d.ts +4 -0
  64. package/dist/dashboard/workers-dashboard.js +904 -0
  65. package/dist/helper/index.d.ts +5 -0
  66. package/dist/helper/index.js +10 -0
  67. package/dist/http/WorkerApiController.d.ts +38 -0
  68. package/dist/http/WorkerApiController.js +312 -0
  69. package/dist/http/WorkerController.d.ts +374 -0
  70. package/dist/http/WorkerController.js +1351 -0
  71. package/dist/http/middleware/CustomValidation.d.ts +92 -0
  72. package/dist/http/middleware/CustomValidation.js +270 -0
  73. package/dist/http/middleware/DatacenterValidator.d.ts +3 -0
  74. package/dist/http/middleware/DatacenterValidator.js +94 -0
  75. package/dist/http/middleware/EditWorkerValidation.d.ts +7 -0
  76. package/dist/http/middleware/EditWorkerValidation.js +55 -0
  77. package/dist/http/middleware/FeaturesValidator.d.ts +3 -0
  78. package/dist/http/middleware/FeaturesValidator.js +60 -0
  79. package/dist/http/middleware/InfrastructureValidator.d.ts +31 -0
  80. package/dist/http/middleware/InfrastructureValidator.js +226 -0
  81. package/dist/http/middleware/OptionsValidator.d.ts +3 -0
  82. package/dist/http/middleware/OptionsValidator.js +112 -0
  83. package/dist/http/middleware/PayloadSanitizer.d.ts +7 -0
  84. package/dist/http/middleware/PayloadSanitizer.js +42 -0
  85. package/dist/http/middleware/ProcessorPathSanitizer.d.ts +3 -0
  86. package/dist/http/middleware/ProcessorPathSanitizer.js +74 -0
  87. package/dist/http/middleware/QueueNameSanitizer.d.ts +3 -0
  88. package/dist/http/middleware/QueueNameSanitizer.js +45 -0
  89. package/dist/http/middleware/ValidateDriver.d.ts +7 -0
  90. package/dist/http/middleware/ValidateDriver.js +20 -0
  91. package/dist/http/middleware/VersionSanitizer.d.ts +3 -0
  92. package/dist/http/middleware/VersionSanitizer.js +25 -0
  93. package/dist/http/middleware/WorkerNameSanitizer.d.ts +3 -0
  94. package/dist/http/middleware/WorkerNameSanitizer.js +46 -0
  95. package/dist/http/middleware/WorkerValidationChain.d.ts +27 -0
  96. package/dist/http/middleware/WorkerValidationChain.js +185 -0
  97. package/dist/index.d.ts +46 -0
  98. package/dist/index.js +48 -0
  99. package/dist/routes/workers.d.ts +12 -0
  100. package/dist/routes/workers.js +81 -0
  101. package/dist/storage/WorkerStore.d.ts +45 -0
  102. package/dist/storage/WorkerStore.js +195 -0
  103. package/dist/type.d.ts +76 -0
  104. package/dist/type.js +1 -0
  105. package/dist/ui/router/ui.d.ts +3 -0
  106. package/dist/ui/router/ui.js +83 -0
  107. package/dist/ui/types/worker-ui.d.ts +229 -0
  108. package/dist/ui/types/worker-ui.js +5 -0
  109. package/package.json +53 -0
  110. package/src/AnomalyDetection.ts +434 -0
  111. package/src/AutoScaler.ts +654 -0
  112. package/src/BroadcastWorker.ts +34 -0
  113. package/src/CanaryController.ts +531 -0
  114. package/src/ChaosEngineering.ts +301 -0
  115. package/src/CircuitBreaker.ts +495 -0
  116. package/src/ClusterLock.ts +499 -0
  117. package/src/ComplianceManager.ts +815 -0
  118. package/src/DatacenterOrchestrator.ts +561 -0
  119. package/src/DeadLetterQueue.ts +733 -0
  120. package/src/HealthMonitor.ts +390 -0
  121. package/src/MultiQueueWorker.ts +431 -0
  122. package/src/NotificationWorker.ts +33 -0
  123. package/src/Observability.ts +696 -0
  124. package/src/PluginManager.ts +551 -0
  125. package/src/PriorityQueue.ts +351 -0
  126. package/src/ResourceMonitor.ts +769 -0
  127. package/src/SLAMonitor.ts +408 -0
  128. package/src/WorkerFactory.ts +2108 -0
  129. package/src/WorkerInit.ts +313 -0
  130. package/src/WorkerMetrics.ts +709 -0
  131. package/src/WorkerRegistry.ts +443 -0
  132. package/src/WorkerShutdown.ts +210 -0
  133. package/src/WorkerVersioning.ts +422 -0
  134. package/src/config/workerConfig.ts +25 -0
  135. package/src/createQueueWorker.ts +174 -0
  136. package/src/dashboard/index.ts +6 -0
  137. package/src/dashboard/types.ts +141 -0
  138. package/src/dashboard/workers-api.ts +785 -0
  139. package/src/dashboard/zintrust.svg +30 -0
  140. package/src/helper/index.ts +11 -0
  141. package/src/http/WorkerApiController.ts +369 -0
  142. package/src/http/WorkerController.ts +1512 -0
  143. package/src/http/middleware/CustomValidation.ts +360 -0
  144. package/src/http/middleware/DatacenterValidator.ts +124 -0
  145. package/src/http/middleware/EditWorkerValidation.ts +74 -0
  146. package/src/http/middleware/FeaturesValidator.ts +82 -0
  147. package/src/http/middleware/InfrastructureValidator.ts +295 -0
  148. package/src/http/middleware/OptionsValidator.ts +144 -0
  149. package/src/http/middleware/PayloadSanitizer.ts +52 -0
  150. package/src/http/middleware/ProcessorPathSanitizer.ts +86 -0
  151. package/src/http/middleware/QueueNameSanitizer.ts +55 -0
  152. package/src/http/middleware/ValidateDriver.ts +29 -0
  153. package/src/http/middleware/VersionSanitizer.ts +30 -0
  154. package/src/http/middleware/WorkerNameSanitizer.ts +56 -0
  155. package/src/http/middleware/WorkerValidationChain.ts +230 -0
  156. package/src/index.ts +98 -0
  157. package/src/routes/workers.ts +154 -0
  158. package/src/storage/WorkerStore.ts +240 -0
  159. package/src/type.ts +89 -0
  160. package/src/types/queue-monitor.d.ts +38 -0
  161. package/src/types/queue-redis.d.ts +38 -0
  162. package/src/ui/README.md +13 -0
  163. package/src/ui/components/JsonEditor.js +670 -0
  164. package/src/ui/components/JsonViewer.js +387 -0
  165. package/src/ui/components/WorkerCard.js +178 -0
  166. package/src/ui/components/WorkerExpandPanel.js +257 -0
  167. package/src/ui/components/fetcher.js +42 -0
  168. package/src/ui/components/sla-scorecard.js +32 -0
  169. package/src/ui/components/styles.css +30 -0
  170. package/src/ui/components/table-expander.js +34 -0
  171. package/src/ui/integration/worker-ui-integration.js +565 -0
  172. package/src/ui/router/ui.ts +99 -0
  173. package/src/ui/services/workerApi.js +240 -0
  174. package/src/ui/types/worker-ui.ts +283 -0
  175. package/src/ui/utils/jsonValidator.js +444 -0
  176. package/src/ui/workers/index.html +202 -0
  177. package/src/ui/workers/main.js +1781 -0
  178. package/src/ui/workers/styles.css +1350 -0
@@ -0,0 +1,300 @@
1
+ /**
2
+ * Worker Versioning System
3
+ * Semantic versioning support for workers with backward compatibility
4
+ * Sealed namespace for immutability
5
+ */
6
+ import { ErrorFactory, Logger } from '@zintrust/core';
7
+ // Internal state
8
+ const workerVersions = new Map();
9
+ const versionAliases = new Map(); // 'latest', 'stable', etc. -> version string
10
+ /**
11
+ * Helper: Parse version string
12
+ */
13
+ const parseVersion = (versionStr) => {
14
+ const match = new RegExp(/^(\d+)\.(\d+)\.(\d+)(?:-([a-zA-Z0-9.-]+))?(?:\+([a-zA-Z0-9.-]+))?$/).exec(versionStr);
15
+ if (!match) {
16
+ throw ErrorFactory.createConfigError(`Invalid version format: ${versionStr}`);
17
+ }
18
+ return {
19
+ major: Number.parseInt(match[1], 10),
20
+ minor: Number.parseInt(match[2], 10),
21
+ patch: Number.parseInt(match[3], 10),
22
+ prerelease: match[4],
23
+ build: match[5],
24
+ };
25
+ };
26
+ /**
27
+ * Helper: Convert version to string
28
+ */
29
+ const versionToString = (version) => {
30
+ let str = `${version.major}.${version.minor}.${version.patch}`;
31
+ if (typeof version.prerelease === 'string' && version.prerelease.length > 0) {
32
+ str += `-${version.prerelease}`;
33
+ }
34
+ if (typeof version.build === 'string' && version.build.length > 0) {
35
+ str += `+${version.build}`;
36
+ }
37
+ return str;
38
+ };
39
+ /**
40
+ * Helper: Compare versions
41
+ * Returns: -1 if v1 < v2, 0 if v1 === v2, 1 if v1 > v2
42
+ */
43
+ const compareVersions = (v1, v2) => {
44
+ if (v1.major !== v2.major)
45
+ return v1.major - v2.major;
46
+ if (v1.minor !== v2.minor)
47
+ return v1.minor - v2.minor;
48
+ if (v1.patch !== v2.patch)
49
+ return v1.patch - v2.patch;
50
+ // Prerelease versions have lower precedence
51
+ if (v1.prerelease === undefined && v2.prerelease !== undefined)
52
+ return 1;
53
+ if (v1.prerelease !== undefined && v2.prerelease === undefined)
54
+ return -1;
55
+ if (v1.prerelease !== undefined && v2.prerelease !== undefined) {
56
+ return v1.prerelease.localeCompare(v2.prerelease);
57
+ }
58
+ return 0;
59
+ };
60
+ /**
61
+ * Helper: Check if versions are compatible (no breaking changes)
62
+ */
63
+ const areVersionsCompatible = (v1, v2) => {
64
+ // Same major version = compatible (semver rules)
65
+ return v1.major === v2.major;
66
+ };
67
+ /**
68
+ * Worker Versioning - Sealed namespace
69
+ */
70
+ export const WorkerVersioning = Object.freeze({
71
+ /**
72
+ * Register a worker version
73
+ */
74
+ register(workerVersion) {
75
+ const { workerName, version } = workerVersion;
76
+ const versionStr = versionToString(version);
77
+ let versions = workerVersions.get(workerName);
78
+ if (!versions) {
79
+ versions = [];
80
+ workerVersions.set(workerName, versions);
81
+ }
82
+ // Check if version already exists
83
+ const existing = versions.find((v) => versionToString(v.version) === versionStr);
84
+ if (existing) {
85
+ ErrorFactory.createConfigError(`Version ${versionStr} already registered for worker "${workerName}"`);
86
+ }
87
+ const fullVersion = {
88
+ ...workerVersion,
89
+ createdAt: new Date(),
90
+ isActive: true,
91
+ isDeprecated: false,
92
+ };
93
+ versions.push(fullVersion);
94
+ // Sort by version (descending)
95
+ versions.sort((a, b) => -compareVersions(a.version, b.version));
96
+ // Update 'latest' alias if this is the newest version
97
+ if (versions[0] === fullVersion) {
98
+ const aliasKey = `${workerName}:latest`;
99
+ versionAliases.set(aliasKey, versionStr);
100
+ }
101
+ Logger.info(`Worker version registered: ${workerName}@${versionStr}`, {
102
+ isActive: fullVersion.isActive,
103
+ });
104
+ },
105
+ /**
106
+ * Get worker version
107
+ */
108
+ getVersion(workerName, versionStr) {
109
+ // Check if it's an alias
110
+ let newVersionStr = versionStr;
111
+ const aliasKey = `${workerName}:${newVersionStr}`;
112
+ const aliasedVersion = versionAliases.get(aliasKey);
113
+ if (aliasedVersion !== undefined) {
114
+ newVersionStr = aliasedVersion;
115
+ }
116
+ const versions = workerVersions.get(workerName);
117
+ if (!versions)
118
+ return null;
119
+ const version = parseVersion(newVersionStr);
120
+ const found = versions.find((v) => compareVersions(v.version, version) === 0);
121
+ return found ? { ...found } : null;
122
+ },
123
+ /**
124
+ * Get all versions for a worker
125
+ */
126
+ getVersions(workerName, includeDeprecated = false) {
127
+ const versions = workerVersions.get(workerName) ?? [];
128
+ if (!includeDeprecated) {
129
+ return versions.filter((v) => !v.isDeprecated);
130
+ }
131
+ return versions.map((v) => ({ ...v }));
132
+ },
133
+ /**
134
+ * Get latest version
135
+ */
136
+ getLatest(workerName) {
137
+ const versions = workerVersions.get(workerName);
138
+ if (!versions || versions.length === 0)
139
+ return null;
140
+ // Already sorted by version (descending)
141
+ const latest = versions.find((v) => v.isActive && !v.isDeprecated);
142
+ return latest ? { ...latest } : null;
143
+ },
144
+ /**
145
+ * Deprecate a version
146
+ */
147
+ deprecate(workerName, versionStr, migrationPath, eolDate) {
148
+ const version = WorkerVersioning.getVersion(workerName, versionStr);
149
+ if (!version) {
150
+ throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
151
+ }
152
+ const versions = workerVersions.get(workerName) ?? [];
153
+ const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
154
+ versions[index].isDeprecated = true;
155
+ versions[index].deprecatedAt = new Date();
156
+ versions[index].migrationPath = migrationPath;
157
+ versions[index].eolDate = eolDate;
158
+ Logger.warn(`Worker version deprecated: ${workerName}@${versionStr}`, {
159
+ migrationPath,
160
+ eolDate,
161
+ });
162
+ },
163
+ /**
164
+ * Deactivate a version (stop accepting new jobs)
165
+ */
166
+ deactivate(workerName, versionStr) {
167
+ const version = WorkerVersioning.getVersion(workerName, versionStr);
168
+ if (!version) {
169
+ throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
170
+ }
171
+ const versions = workerVersions.get(workerName) ?? [];
172
+ const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
173
+ versions[index].isActive = false;
174
+ Logger.info(`Worker version deactivated: ${workerName}@${versionStr}`);
175
+ },
176
+ /**
177
+ * Activate a version
178
+ */
179
+ activate(workerName, versionStr) {
180
+ const version = WorkerVersioning.getVersion(workerName, versionStr);
181
+ if (!version) {
182
+ throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
183
+ }
184
+ const getWorkerVersions = workerVersions.get(workerName);
185
+ const versions = getWorkerVersions ?? [];
186
+ const index = versions.findIndex((v) => versionToString(v.version) === versionStr);
187
+ versions[index].isActive = true;
188
+ Logger.info(`Worker version activated: ${workerName}@${versionStr}`);
189
+ },
190
+ /**
191
+ * Check compatibility between versions
192
+ */
193
+ checkCompatibility(workerName, sourceVersionStr, targetVersionStr) {
194
+ const sourceVersion = parseVersion(sourceVersionStr);
195
+ const targetVersion = parseVersion(targetVersionStr);
196
+ const source = WorkerVersioning.getVersion(workerName, sourceVersionStr);
197
+ const target = WorkerVersioning.getVersion(workerName, targetVersionStr);
198
+ const compatible = areVersionsCompatible(sourceVersion, targetVersion);
199
+ const requiresMigration = !compatible || sourceVersion.major < targetVersion.major;
200
+ const breakingChanges = target?.breakingChanges ?? [];
201
+ const recommendations = [];
202
+ if (target?.isDeprecated === true) {
203
+ recommendations.push(`Target version is deprecated. Consider migrating to ${(target.migrationPath ?? '') || 'latest'}`);
204
+ }
205
+ if (!compatible) {
206
+ recommendations.push('Major version change detected. Review breaking changes carefully.');
207
+ }
208
+ if (source?.eolDate && source.eolDate < new Date()) {
209
+ recommendations.push('Source version has reached end of life. Migration is required.');
210
+ }
211
+ return {
212
+ sourceVersion,
213
+ targetVersion,
214
+ compatible,
215
+ requiresMigration,
216
+ breakingChanges,
217
+ recommendations,
218
+ };
219
+ },
220
+ /**
221
+ * Set version alias
222
+ */
223
+ setAlias(workerName, alias, versionStr) {
224
+ const version = WorkerVersioning.getVersion(workerName, versionStr);
225
+ if (!version) {
226
+ throw ErrorFactory.createNotFoundError(`Version ${versionStr} not found for worker "${workerName}"`);
227
+ }
228
+ const aliasKey = `${workerName}:${alias}`;
229
+ versionAliases.set(aliasKey, versionStr);
230
+ Logger.info(`Version alias set: ${alias} -> ${workerName}@${versionStr}`);
231
+ },
232
+ /**
233
+ * Get version by alias
234
+ */
235
+ resolveAlias(workerName, alias) {
236
+ const aliasKey = `${workerName}:${alias}`;
237
+ return versionAliases.get(aliasKey) ?? null;
238
+ },
239
+ /**
240
+ * Parse version string
241
+ */
242
+ parse(versionStr) {
243
+ return parseVersion(versionStr);
244
+ },
245
+ /**
246
+ * Convert version to string
247
+ */
248
+ stringify(version) {
249
+ return versionToString(version);
250
+ },
251
+ /**
252
+ * Compare two versions
253
+ */
254
+ compare(v1Str, v2Str) {
255
+ const v1 = parseVersion(v1Str);
256
+ const v2 = parseVersion(v2Str);
257
+ return compareVersions(v1, v2);
258
+ },
259
+ /**
260
+ * Get version summary
261
+ */
262
+ getSummary(workerName) {
263
+ const versions = workerVersions.get(workerName) ?? [];
264
+ const summary = {
265
+ totalVersions: versions.length,
266
+ activeVersions: versions.filter((v) => v.isActive).length,
267
+ deprecatedVersions: versions.filter((v) => v.isDeprecated).length,
268
+ latest: WorkerVersioning.resolveAlias(workerName, 'latest'),
269
+ stable: WorkerVersioning.resolveAlias(workerName, 'stable'),
270
+ };
271
+ return summary;
272
+ },
273
+ /**
274
+ * Clear all versions for a worker
275
+ */
276
+ clear(workerName) {
277
+ workerVersions.delete(workerName);
278
+ // Remove aliases
279
+ const keysToDelete = [];
280
+ for (const [key] of versionAliases.entries()) {
281
+ if (key.startsWith(`${workerName}:`)) {
282
+ keysToDelete.push(key);
283
+ }
284
+ }
285
+ for (const key of keysToDelete) {
286
+ versionAliases.delete(key);
287
+ }
288
+ Logger.info(`All versions cleared for worker: ${workerName}`);
289
+ },
290
+ /**
291
+ * Shutdown
292
+ */
293
+ shutdown() {
294
+ Logger.info('WorkerVersioning shutting down...');
295
+ workerVersions.clear();
296
+ versionAliases.clear();
297
+ Logger.info('WorkerVersioning shutdown complete');
298
+ },
299
+ });
300
+ // Graceful shutdown handled by WorkerShutdown