xypriss 1.3.8 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (221) hide show
  1. package/README.md +232 -254
  2. package/dist/cjs/mods/security/src/algorithms/hash-algorithms.js +10 -0
  3. package/dist/cjs/mods/security/src/algorithms/hash-algorithms.js.map +1 -1
  4. package/dist/cjs/mods/security/src/components/cache/cacheSys.utils.js +10 -0
  5. package/dist/cjs/mods/security/src/components/cache/cacheSys.utils.js.map +1 -1
  6. package/dist/cjs/mods/security/src/components/cache/index.js +10 -74
  7. package/dist/cjs/mods/security/src/components/cache/index.js.map +1 -1
  8. package/dist/cjs/mods/security/src/components/fortified-function/index.js +9 -0
  9. package/dist/cjs/mods/security/src/components/fortified-function/index.js.map +1 -1
  10. package/dist/cjs/mods/security/src/components/fortified-function/security/security-handler.js +10 -0
  11. package/dist/cjs/mods/security/src/components/fortified-function/security/security-handler.js.map +1 -1
  12. package/dist/cjs/mods/security/src/core/crypto.js +14 -0
  13. package/dist/cjs/mods/security/src/core/crypto.js.map +1 -1
  14. package/dist/cjs/mods/security/src/index.js +10 -4
  15. package/dist/cjs/mods/security/src/index.js.map +1 -1
  16. package/dist/cjs/shared/logger/Logger.js +374 -29
  17. package/dist/cjs/shared/logger/Logger.js.map +1 -1
  18. package/dist/cjs/src/cluster/bun-cluster-manager.js +91 -1
  19. package/dist/cjs/src/cluster/bun-cluster-manager.js.map +1 -1
  20. package/dist/cjs/src/cluster/cluster-manager.js +15 -3
  21. package/dist/cjs/src/cluster/cluster-manager.js.map +1 -1
  22. package/dist/cjs/src/cluster/modules/AutoScaler.js +4 -4
  23. package/dist/cjs/src/cluster/modules/AutoScaler.js.map +1 -1
  24. package/dist/cjs/src/cluster/modules/CrossPlatformMemory.js +2 -2
  25. package/dist/cjs/src/cluster/modules/CrossPlatformMemory.js.map +1 -1
  26. package/dist/cjs/src/cluster/modules/EventLoopMonitor.js +270 -0
  27. package/dist/cjs/src/cluster/modules/EventLoopMonitor.js.map +1 -0
  28. package/dist/cjs/src/cluster/modules/GCStatsTracker.js +200 -0
  29. package/dist/cjs/src/cluster/modules/GCStatsTracker.js.map +1 -0
  30. package/dist/cjs/src/cluster/modules/HeapStatsCollector.js +111 -0
  31. package/dist/cjs/src/cluster/modules/HeapStatsCollector.js.map +1 -0
  32. package/dist/cjs/src/cluster/modules/NetworkTracker.js +162 -0
  33. package/dist/cjs/src/cluster/modules/NetworkTracker.js.map +1 -0
  34. package/dist/cjs/src/cluster/modules/ThroughputCalculator.js +186 -0
  35. package/dist/cjs/src/cluster/modules/ThroughputCalculator.js.map +1 -0
  36. package/dist/cjs/src/cluster/modules/WorkerManager.js +14 -15
  37. package/dist/cjs/src/cluster/modules/WorkerManager.js.map +1 -1
  38. package/dist/cjs/src/cluster/modules/{LoadBalancer.js → strategy/LoadBalancer.js} +1 -1
  39. package/dist/cjs/src/cluster/modules/strategy/LoadBalancer.js.map +1 -0
  40. package/dist/cjs/src/index.js +55 -61
  41. package/dist/cjs/src/index.js.map +1 -1
  42. package/dist/cjs/src/middleware/XyPrissMiddlewareAPI.js +281 -0
  43. package/dist/cjs/src/middleware/XyPrissMiddlewareAPI.js.map +1 -0
  44. package/dist/cjs/src/middleware/built-in/index.js +325 -0
  45. package/dist/cjs/src/middleware/built-in/index.js.map +1 -0
  46. package/dist/cjs/src/middleware/built-in/sqlInjection.js +335 -0
  47. package/dist/cjs/src/middleware/built-in/sqlInjection.js.map +1 -0
  48. package/dist/cjs/src/middleware/safe-json-middleware.js +1 -1
  49. package/dist/cjs/src/middleware/safe-json-middleware.js.map +1 -1
  50. package/dist/cjs/src/middleware/security-middleware.js +447 -332
  51. package/dist/cjs/src/middleware/security-middleware.js.map +1 -1
  52. package/dist/cjs/src/plugins/modules/builtin/ResponseTimePlugin.js +1 -1
  53. package/dist/cjs/src/plugins/modules/builtin/ResponseTimePlugin.js.map +1 -1
  54. package/dist/cjs/src/plugins/modules/index.js +9 -3
  55. package/dist/cjs/src/plugins/modules/index.js.map +1 -1
  56. package/dist/cjs/src/quick-start.js +0 -4
  57. package/dist/cjs/src/quick-start.js.map +1 -1
  58. package/dist/cjs/src/server/FastServer.js +94 -412
  59. package/dist/cjs/src/server/FastServer.js.map +1 -1
  60. package/dist/cjs/src/server/ServerFactory.js +69 -64
  61. package/dist/cjs/src/server/ServerFactory.js.map +1 -1
  62. package/dist/cjs/src/server/components/fastapi/ClusterManagerComponent.js +31 -5
  63. package/dist/cjs/src/server/components/fastapi/ClusterManagerComponent.js.map +1 -1
  64. package/dist/cjs/src/server/components/fastapi/PerformanceManager.js +1 -1
  65. package/dist/cjs/src/server/components/fastapi/PerformanceManager.js.map +1 -1
  66. package/dist/cjs/src/server/components/fastapi/RouteManager.js +0 -82
  67. package/dist/cjs/src/server/components/fastapi/RouteManager.js.map +1 -1
  68. package/dist/cjs/src/server/components/fastapi/WorkerPoolComponent.js +206 -0
  69. package/dist/cjs/src/server/components/fastapi/WorkerPoolComponent.js.map +1 -0
  70. package/dist/cjs/src/server/components/fastapi/console/ConsoleInterceptor.js +3 -28
  71. package/dist/cjs/src/server/components/fastapi/console/ConsoleInterceptor.js.map +1 -1
  72. package/dist/cjs/src/server/components/fastapi/modules/UFRP/WorkerPoolManager.js +265 -0
  73. package/dist/cjs/src/server/components/fastapi/modules/UFRP/WorkerPoolManager.js.map +1 -0
  74. package/dist/cjs/src/server/components/fastapi/modules/UFRP/workers/Logger.js +236 -0
  75. package/dist/cjs/src/server/components/fastapi/modules/UFRP/workers/cpu-tasks.js +294 -0
  76. package/dist/cjs/src/server/components/fastapi/modules/UFRP/workers/enhanced-cpu-worker.js +433 -0
  77. package/dist/cjs/src/server/components/fastapi/modules/UFRP/workers/io-worker.js +1615 -0
  78. package/dist/cjs/src/server/components/lifecycle/ServerLifecycleManager.js +503 -0
  79. package/dist/cjs/src/server/components/lifecycle/ServerLifecycleManager.js.map +1 -0
  80. package/dist/cjs/src/server/const/default.js +23 -17
  81. package/dist/cjs/src/server/const/default.js.map +1 -1
  82. package/dist/cjs/src/server/core/HttpServer.js +500 -0
  83. package/dist/cjs/src/server/core/HttpServer.js.map +1 -0
  84. package/dist/cjs/src/server/core/XyprissApp.js +679 -0
  85. package/dist/cjs/src/server/core/XyprissApp.js.map +1 -0
  86. package/dist/cjs/src/server/handlers/NotFoundHandler.js +1 -1
  87. package/dist/cjs/src/server/handlers/NotFoundHandler.js.map +1 -1
  88. package/dist/cjs/src/server/middleware/MiddlewareManager.js +191 -0
  89. package/dist/cjs/src/server/middleware/MiddlewareManager.js.map +1 -0
  90. package/dist/cjs/src/server/routing/Router.js +341 -0
  91. package/dist/cjs/src/server/routing/Router.js.map +1 -0
  92. package/dist/cjs/src/server/utils/PortManager.js +1 -0
  93. package/dist/cjs/src/server/utils/PortManager.js.map +1 -1
  94. package/dist/cjs/src/server/utils/forceClosePort.js +294 -88
  95. package/dist/cjs/src/server/utils/forceClosePort.js.map +1 -1
  96. package/dist/esm/mods/security/src/algorithms/hash-algorithms.js +10 -0
  97. package/dist/esm/mods/security/src/algorithms/hash-algorithms.js.map +1 -1
  98. package/dist/esm/mods/security/src/components/cache/cacheSys.utils.js +10 -0
  99. package/dist/esm/mods/security/src/components/cache/cacheSys.utils.js.map +1 -1
  100. package/dist/esm/mods/security/src/components/cache/index.js +11 -72
  101. package/dist/esm/mods/security/src/components/cache/index.js.map +1 -1
  102. package/dist/esm/mods/security/src/components/fortified-function/index.js +9 -0
  103. package/dist/esm/mods/security/src/components/fortified-function/index.js.map +1 -1
  104. package/dist/esm/mods/security/src/components/fortified-function/security/security-handler.js +10 -0
  105. package/dist/esm/mods/security/src/components/fortified-function/security/security-handler.js.map +1 -1
  106. package/dist/esm/mods/security/src/core/crypto.js +14 -0
  107. package/dist/esm/mods/security/src/core/crypto.js.map +1 -1
  108. package/dist/esm/mods/security/src/index.js +11 -2
  109. package/dist/esm/mods/security/src/index.js.map +1 -1
  110. package/dist/esm/shared/logger/Logger.js +374 -29
  111. package/dist/esm/shared/logger/Logger.js.map +1 -1
  112. package/dist/esm/src/cluster/bun-cluster-manager.js +91 -1
  113. package/dist/esm/src/cluster/bun-cluster-manager.js.map +1 -1
  114. package/dist/esm/src/cluster/cluster-manager.js +15 -3
  115. package/dist/esm/src/cluster/cluster-manager.js.map +1 -1
  116. package/dist/esm/src/cluster/modules/AutoScaler.js +4 -4
  117. package/dist/esm/src/cluster/modules/AutoScaler.js.map +1 -1
  118. package/dist/esm/src/cluster/modules/CrossPlatformMemory.js +2 -2
  119. package/dist/esm/src/cluster/modules/CrossPlatformMemory.js.map +1 -1
  120. package/dist/esm/src/cluster/modules/EventLoopMonitor.js +268 -0
  121. package/dist/esm/src/cluster/modules/EventLoopMonitor.js.map +1 -0
  122. package/dist/esm/src/cluster/modules/GCStatsTracker.js +198 -0
  123. package/dist/esm/src/cluster/modules/GCStatsTracker.js.map +1 -0
  124. package/dist/esm/src/cluster/modules/HeapStatsCollector.js +109 -0
  125. package/dist/esm/src/cluster/modules/HeapStatsCollector.js.map +1 -0
  126. package/dist/esm/src/cluster/modules/NetworkTracker.js +160 -0
  127. package/dist/esm/src/cluster/modules/NetworkTracker.js.map +1 -0
  128. package/dist/esm/src/cluster/modules/ThroughputCalculator.js +184 -0
  129. package/dist/esm/src/cluster/modules/ThroughputCalculator.js.map +1 -0
  130. package/dist/esm/src/cluster/modules/WorkerManager.js +14 -14
  131. package/dist/esm/src/cluster/modules/WorkerManager.js.map +1 -1
  132. package/dist/esm/src/cluster/modules/{LoadBalancer.js → strategy/LoadBalancer.js} +1 -1
  133. package/dist/esm/src/cluster/modules/strategy/LoadBalancer.js.map +1 -0
  134. package/dist/esm/src/index.js +41 -11
  135. package/dist/esm/src/index.js.map +1 -1
  136. package/dist/esm/src/middleware/XyPrissMiddlewareAPI.js +279 -0
  137. package/dist/esm/src/middleware/XyPrissMiddlewareAPI.js.map +1 -0
  138. package/dist/esm/src/middleware/built-in/index.js +323 -0
  139. package/dist/esm/src/middleware/built-in/index.js.map +1 -0
  140. package/dist/esm/src/middleware/built-in/sqlInjection.js +333 -0
  141. package/dist/esm/src/middleware/built-in/sqlInjection.js.map +1 -0
  142. package/dist/esm/src/middleware/safe-json-middleware.js +1 -1
  143. package/dist/esm/src/middleware/safe-json-middleware.js.map +1 -1
  144. package/dist/esm/src/middleware/security-middleware.js +447 -332
  145. package/dist/esm/src/middleware/security-middleware.js.map +1 -1
  146. package/dist/esm/src/plugins/modules/builtin/ResponseTimePlugin.js +1 -1
  147. package/dist/esm/src/plugins/modules/builtin/ResponseTimePlugin.js.map +1 -1
  148. package/dist/esm/src/plugins/modules/index.js +9 -3
  149. package/dist/esm/src/plugins/modules/index.js.map +1 -1
  150. package/dist/esm/src/quick-start.js +0 -4
  151. package/dist/esm/src/quick-start.js.map +1 -1
  152. package/dist/esm/src/server/FastServer.js +94 -412
  153. package/dist/esm/src/server/FastServer.js.map +1 -1
  154. package/dist/esm/src/server/ServerFactory.js +70 -61
  155. package/dist/esm/src/server/ServerFactory.js.map +1 -1
  156. package/dist/esm/src/server/components/fastapi/ClusterManagerComponent.js +31 -5
  157. package/dist/esm/src/server/components/fastapi/ClusterManagerComponent.js.map +1 -1
  158. package/dist/esm/src/server/components/fastapi/PerformanceManager.js +1 -1
  159. package/dist/esm/src/server/components/fastapi/PerformanceManager.js.map +1 -1
  160. package/dist/esm/src/server/components/fastapi/RouteManager.js +0 -82
  161. package/dist/esm/src/server/components/fastapi/RouteManager.js.map +1 -1
  162. package/dist/esm/src/server/components/fastapi/WorkerPoolComponent.js +204 -0
  163. package/dist/esm/src/server/components/fastapi/WorkerPoolComponent.js.map +1 -0
  164. package/dist/esm/src/server/components/fastapi/console/ConsoleInterceptor.js +2 -27
  165. package/dist/esm/src/server/components/fastapi/console/ConsoleInterceptor.js.map +1 -1
  166. package/dist/esm/src/server/components/fastapi/modules/UFRP/WorkerPoolManager.js +263 -0
  167. package/dist/esm/src/server/components/fastapi/modules/UFRP/WorkerPoolManager.js.map +1 -0
  168. package/dist/esm/src/server/components/fastapi/modules/UFRP/workers/Logger.js +236 -0
  169. package/dist/esm/src/server/components/fastapi/modules/UFRP/workers/cpu-tasks.js +294 -0
  170. package/dist/esm/src/server/components/fastapi/modules/UFRP/workers/enhanced-cpu-worker.js +433 -0
  171. package/dist/esm/src/server/components/fastapi/modules/UFRP/workers/io-worker.js +1615 -0
  172. package/dist/esm/src/server/components/lifecycle/ServerLifecycleManager.js +501 -0
  173. package/dist/esm/src/server/components/lifecycle/ServerLifecycleManager.js.map +1 -0
  174. package/dist/esm/src/server/const/default.js +23 -17
  175. package/dist/esm/src/server/const/default.js.map +1 -1
  176. package/dist/esm/src/server/core/HttpServer.js +498 -0
  177. package/dist/esm/src/server/core/HttpServer.js.map +1 -0
  178. package/dist/esm/src/server/core/XyprissApp.js +677 -0
  179. package/dist/esm/src/server/core/XyprissApp.js.map +1 -0
  180. package/dist/esm/src/server/handlers/NotFoundHandler.js +1 -1
  181. package/dist/esm/src/server/handlers/NotFoundHandler.js.map +1 -1
  182. package/dist/esm/src/server/middleware/MiddlewareManager.js +189 -0
  183. package/dist/esm/src/server/middleware/MiddlewareManager.js.map +1 -0
  184. package/dist/esm/src/server/routing/Router.js +339 -0
  185. package/dist/esm/src/server/routing/Router.js.map +1 -0
  186. package/dist/esm/src/server/utils/PortManager.js +1 -0
  187. package/dist/esm/src/server/utils/PortManager.js.map +1 -1
  188. package/dist/esm/src/server/utils/forceClosePort.js +294 -88
  189. package/dist/esm/src/server/utils/forceClosePort.js.map +1 -1
  190. package/dist/index.d.ts +3363 -5311
  191. package/package.json +39 -28
  192. package/dist/cjs/src/cluster/index.js +0 -361
  193. package/dist/cjs/src/cluster/index.js.map +0 -1
  194. package/dist/cjs/src/cluster/modules/ClusterFactory.js +0 -539
  195. package/dist/cjs/src/cluster/modules/ClusterFactory.js.map +0 -1
  196. package/dist/cjs/src/cluster/modules/LoadBalancer.js.map +0 -1
  197. package/dist/cjs/src/server/components/fastapi/UltraFastRequestProcessor.js +0 -668
  198. package/dist/cjs/src/server/components/fastapi/UltraFastRequestProcessor.js.map +0 -1
  199. package/dist/cjs/src/server/components/fastapi/middlewares/MiddlewareAPI.js +0 -347
  200. package/dist/cjs/src/server/components/fastapi/middlewares/MiddlewareAPI.js.map +0 -1
  201. package/dist/cjs/src/server/components/fastapi/middlewares/MiddlewareMethodsManager.js +0 -204
  202. package/dist/cjs/src/server/components/fastapi/middlewares/MiddlewareMethodsManager.js.map +0 -1
  203. package/dist/cjs/src/server/components/fastapi/middlewares/middlewareManager.js +0 -953
  204. package/dist/cjs/src/server/components/fastapi/middlewares/middlewareManager.js.map +0 -1
  205. package/dist/cjs/src/server/components/fastapi/modules/UFRP/WorkerPool.js +0 -56
  206. package/dist/cjs/src/server/components/fastapi/modules/UFRP/WorkerPool.js.map +0 -1
  207. package/dist/esm/src/cluster/index.js +0 -339
  208. package/dist/esm/src/cluster/index.js.map +0 -1
  209. package/dist/esm/src/cluster/modules/ClusterFactory.js +0 -511
  210. package/dist/esm/src/cluster/modules/ClusterFactory.js.map +0 -1
  211. package/dist/esm/src/cluster/modules/LoadBalancer.js.map +0 -1
  212. package/dist/esm/src/server/components/fastapi/UltraFastRequestProcessor.js +0 -647
  213. package/dist/esm/src/server/components/fastapi/UltraFastRequestProcessor.js.map +0 -1
  214. package/dist/esm/src/server/components/fastapi/middlewares/MiddlewareAPI.js +0 -345
  215. package/dist/esm/src/server/components/fastapi/middlewares/MiddlewareAPI.js.map +0 -1
  216. package/dist/esm/src/server/components/fastapi/middlewares/MiddlewareMethodsManager.js +0 -202
  217. package/dist/esm/src/server/components/fastapi/middlewares/MiddlewareMethodsManager.js.map +0 -1
  218. package/dist/esm/src/server/components/fastapi/middlewares/middlewareManager.js +0 -951
  219. package/dist/esm/src/server/components/fastapi/middlewares/middlewareManager.js.map +0 -1
  220. package/dist/esm/src/server/components/fastapi/modules/UFRP/WorkerPool.js +0 -54
  221. package/dist/esm/src/server/components/fastapi/modules/UFRP/WorkerPool.js.map +0 -1
@@ -0,0 +1,677 @@
1
+ import '../../../shared/logger/Logger.js';
2
+ import { XyPrissHttpServer } from './HttpServer.js';
3
+ import { XyPrissMiddleware } from '../../middleware/XyPrissMiddlewareAPI.js';
4
+ import { XyPrissRouter } from '../routing/Router.js';
5
+
6
+ /**
7
+ * XyprissApp - Express-free UltraFastApp implementation
8
+ *
9
+ * This module provides a complete UltraFastApp implementation that doesn't
10
+ * depend on Express, using our XyPrisHttpServer for maximum performance.
11
+ */
12
+ /**
13
+ * UltraFastApp implementation without Express dependency
14
+ */
15
+ class XyprissApp {
16
+ constructor(logger) {
17
+ this.isStarted = false;
18
+ // App properties
19
+ this.locals = {};
20
+ this.mountpath = "/";
21
+ this.settings = {};
22
+ // ===== MISSING ULTRAFASTAPP METHODS (STUB IMPLEMENTATIONS) =====
23
+ this.invalidateCache = async (pattern) => {
24
+ if (this.cache) {
25
+ try {
26
+ // Get all cache keys and filter by pattern
27
+ const stats = await this.cache.getStats();
28
+ let invalidatedCount = 0;
29
+ // For pattern-based invalidation, we need to implement a key scanning approach
30
+ // Since the cache doesn't expose all keys directly, we'll use tags if available
31
+ if (pattern.includes("*")) {
32
+ // Convert glob pattern to regex
33
+ const regexPattern = pattern
34
+ .replace(/\*/g, ".*")
35
+ .replace(/\?/g, ".");
36
+ const regex = new RegExp(`^${regexPattern}$`);
37
+ // For now, we'll clear all cache if it's a wildcard pattern
38
+ // In a production system, you'd want to implement key scanning
39
+ if (pattern === "*" || pattern === "**") {
40
+ await this.cache.clear();
41
+ invalidatedCount = stats.memory.size || 0;
42
+ }
43
+ else {
44
+ // For specific patterns, we'd need to implement key enumeration
45
+ // This is a limitation of the current cache implementation
46
+ this.logger.warn("server", `Pattern-based cache invalidation not fully supported: ${pattern}`);
47
+ }
48
+ }
49
+ else {
50
+ // Direct key deletion
51
+ const deleted = await this.cache.delete(pattern);
52
+ invalidatedCount = deleted ? 1 : 0;
53
+ }
54
+ this.logger.debug("server", `Cache invalidation completed for pattern: ${pattern}, invalidated: ${invalidatedCount} entries`);
55
+ }
56
+ catch (error) {
57
+ this.logger.error("server", `Cache invalidation failed for pattern ${pattern}: ${error}`);
58
+ throw error;
59
+ }
60
+ }
61
+ };
62
+ this.getCacheStats = async () => {
63
+ if (this.cache) {
64
+ try {
65
+ const stats = await this.cache.getStats();
66
+ // Transform cache stats to a more user-friendly format
67
+ return {
68
+ memory: {
69
+ hitRate: stats.memory.hitRate || 0,
70
+ missRate: 1 - (stats.memory.hitRate || 0),
71
+ size: stats.memory.size || 0,
72
+ hits: stats.memory.hits || 0,
73
+ misses: stats.memory.misses || 0,
74
+ totalOperations: (stats.memory.hits || 0) +
75
+ (stats.memory.misses || 0),
76
+ memoryUsage: stats.memory.memoryUsage || 0,
77
+ evictions: stats.memory.evictions || 0,
78
+ },
79
+ redis: stats.redis
80
+ ? {
81
+ connected: stats.redis.connected,
82
+ hitRate: stats.redis.hitRate || 0,
83
+ hits: stats.redis.hits || 0,
84
+ misses: stats.redis.misses || 0,
85
+ keys: stats.redis.keys || 0,
86
+ memoryUsage: stats.redis.memoryUsage,
87
+ uptime: stats.redis.uptime || 0,
88
+ }
89
+ : null,
90
+ performance: stats.performance
91
+ ? {
92
+ totalOperations: stats.performance.totalOperations || 0,
93
+ averageResponseTime: stats.performance.averageResponseTime || 0,
94
+ compressionRatio: stats.performance.compressionRatio || 0,
95
+ }
96
+ : null,
97
+ security: stats.security
98
+ ? {
99
+ encryptedEntries: stats.security.encryptedEntries || 0,
100
+ keyRotations: stats.security.keyRotations || 0,
101
+ }
102
+ : null,
103
+ timestamp: Date.now(),
104
+ };
105
+ }
106
+ catch (error) {
107
+ this.logger.error("server", `Failed to get cache stats: ${error}`);
108
+ return { error: "Failed to retrieve cache statistics" };
109
+ }
110
+ }
111
+ return null;
112
+ };
113
+ this.warmUpCache = async (data) => {
114
+ if (this.cache && data && data.length > 0) {
115
+ try {
116
+ this.logger.debug("server", `Starting cache warmup for ${data.length} entries`);
117
+ let successCount = 0;
118
+ let errorCount = 0;
119
+ const batchSize = 10; // Process in batches to avoid overwhelming the cache
120
+ // Process entries in batches
121
+ for (let i = 0; i < data.length; i += batchSize) {
122
+ const batch = data.slice(i, i + batchSize);
123
+ const batchPromises = batch.map(async (entry) => {
124
+ try {
125
+ const options = entry.ttl
126
+ ? { ttl: entry.ttl }
127
+ : undefined;
128
+ await this.cache.set(entry.key, entry.value, options);
129
+ successCount++;
130
+ }
131
+ catch (error) {
132
+ errorCount++;
133
+ this.logger.warn("server", `Failed to warm up cache entry ${entry.key}: ${error}`);
134
+ }
135
+ });
136
+ // Wait for batch to complete
137
+ await Promise.allSettled(batchPromises);
138
+ // Small delay between batches to prevent overwhelming the system
139
+ if (i + batchSize < data.length) {
140
+ await new Promise((resolve) => setTimeout(resolve, 10));
141
+ }
142
+ }
143
+ this.logger.debug("server", `Cache warmup completed: ${successCount} successful, ${errorCount} failed`);
144
+ }
145
+ catch (error) {
146
+ this.logger.error("server", `Cache warmup failed: ${error}`);
147
+ throw error;
148
+ }
149
+ }
150
+ };
151
+ this.getRequestPreCompiler = () => {
152
+ // RequestPreCompiler is not implemented in the current architecture
153
+ // This would be a component for pre-compiling request handlers for performance
154
+ this.logger.debug("server", "RequestPreCompiler not implemented");
155
+ return {
156
+ compile: (routes) => {
157
+ this.logger.debug("server", `Pre-compiling ${routes.length} routes`);
158
+ return routes; // Pass-through for now
159
+ },
160
+ isEnabled: () => false,
161
+ getStats: () => ({ compiledRoutes: 0, compilationTime: 0 }),
162
+ };
163
+ };
164
+ this.getConsoleInterceptor = () => null;
165
+ this.enableConsoleInterception = () => { };
166
+ this.disableConsoleInterception = () => { };
167
+ this.getConsoleStats = () => null;
168
+ this.resetConsoleStats = () => { };
169
+ this.getFileWatcherStatus = () => null;
170
+ this.getFileWatcherStats = () => null;
171
+ this.stopFileWatcher = async () => { };
172
+ this.getFileWatcherManager = () => null;
173
+ this.checkTypeScript = async (files) => null;
174
+ this.getTypeScriptStatus = () => null;
175
+ this.enableTypeScriptChecking = () => { };
176
+ this.disableTypeScriptChecking = () => { };
177
+ this.ultraGet = (path, options, handler) => {
178
+ return this.get(path, handler);
179
+ };
180
+ this.ultraPost = (path, options, handler) => {
181
+ return this.post(path, handler);
182
+ };
183
+ this.ultraPut = (path, options, handler) => {
184
+ return this.put(path, handler);
185
+ };
186
+ this.ultraDelete = (path, options, handler) => {
187
+ return this.delete(path, handler);
188
+ };
189
+ this.ultraRoutes = (routes) => {
190
+ if (!routes || !Array.isArray(routes)) {
191
+ this.logger.warn("server", "Invalid routes array provided to ultraRoutes");
192
+ return this;
193
+ }
194
+ try {
195
+ this.logger.debug("server", `Bulk registering ${routes.length} routes`);
196
+ let successCount = 0;
197
+ let errorCount = 0;
198
+ routes.forEach((route, index) => {
199
+ try {
200
+ const { method, path, handler } = route;
201
+ if (!method || !path || !handler) {
202
+ throw new Error(`Invalid route at index ${index}: missing method, path, or handler`);
203
+ }
204
+ // Register route based on method
205
+ switch (method.toUpperCase()) {
206
+ case "GET":
207
+ this.get(path, handler);
208
+ break;
209
+ case "POST":
210
+ this.post(path, handler);
211
+ break;
212
+ case "PUT":
213
+ this.put(path, handler);
214
+ break;
215
+ case "DELETE":
216
+ this.delete(path, handler);
217
+ break;
218
+ case "PATCH":
219
+ this.patch(path, handler);
220
+ break;
221
+ case "OPTIONS":
222
+ this.options(path, handler);
223
+ break;
224
+ case "HEAD":
225
+ this.head(path, handler);
226
+ break;
227
+ default:
228
+ throw new Error(`Unsupported HTTP method: ${method}`);
229
+ }
230
+ successCount++;
231
+ }
232
+ catch (error) {
233
+ errorCount++;
234
+ this.logger.error("server", `Failed to register route at index ${index}: ${error}`);
235
+ }
236
+ });
237
+ this.logger.debug("server", `Bulk route registration completed: ${successCount} successful, ${errorCount} failed`);
238
+ return this;
239
+ }
240
+ catch (error) {
241
+ this.logger.error("server", `Bulk route registration failed: ${error}`);
242
+ return this;
243
+ }
244
+ };
245
+ this.getRouterStats = () => null;
246
+ this.getRouterInfo = () => null;
247
+ this.warmUpRoutes = async () => { };
248
+ this.resetRouterStats = () => { };
249
+ this.useCached = (middleware, ttl) => {
250
+ if (!this.cache) {
251
+ this.logger.warn("server", "Cache not available, using middleware without caching");
252
+ return this.use(middleware);
253
+ }
254
+ // Create a caching wrapper for the middleware
255
+ const cachedMiddleware = async (req, res, next) => {
256
+ try {
257
+ // Generate cache key based on request
258
+ const cacheKey = `middleware:${req.method}:${req.path}:${JSON.stringify(req.query)}`;
259
+ // Check if response is cached
260
+ const cachedResponse = await this.cache.get(cacheKey);
261
+ if (cachedResponse) {
262
+ this.logger.debug("server", `Serving cached middleware response for ${cacheKey}`);
263
+ res.json(cachedResponse);
264
+ return;
265
+ }
266
+ // Intercept response to cache it
267
+ const originalJson = res.json;
268
+ const self = this;
269
+ res.json = function (data) {
270
+ // Cache the response
271
+ if (ttl && self.cache) {
272
+ self.cache
273
+ .set(cacheKey, data, { ttl })
274
+ .catch((error) => {
275
+ self.logger.warn("server", `Failed to cache middleware response: ${error}`);
276
+ });
277
+ }
278
+ return originalJson.call(this, data);
279
+ };
280
+ // Execute original middleware
281
+ middleware(req, res, next);
282
+ }
283
+ catch (error) {
284
+ this.logger.error("server", `Cached middleware error: ${error}`);
285
+ middleware(req, res, next);
286
+ }
287
+ };
288
+ return this.use(cachedMiddleware);
289
+ };
290
+ this.removeMiddleware = (name) => {
291
+ try {
292
+ // Middleware removal is complex in the current architecture
293
+ // This would require tracking middleware by name and rebuilding the middleware stack
294
+ this.logger.warn("server", `Middleware removal not fully implemented for: ${name}`);
295
+ // For now, we can only disable middleware through the middleware API
296
+ if (this.middlewareAPI) {
297
+ const disabled = this.middlewareAPI.disable(name);
298
+ if (disabled) {
299
+ this.logger.debug("server", `Disabled middleware: ${name}`);
300
+ return true;
301
+ }
302
+ }
303
+ return false;
304
+ }
305
+ catch (error) {
306
+ this.logger.error("server", `Failed to remove middleware ${name}: ${error}`);
307
+ return false;
308
+ }
309
+ };
310
+ this.enableSecurity = (options) => {
311
+ try {
312
+ this.logger.debug("server", "Enabling security middleware");
313
+ if (this.middlewareAPI) {
314
+ // Enable all security middleware
315
+ const securityMiddleware = [
316
+ "helmet",
317
+ "cors",
318
+ "rateLimit",
319
+ "csrf",
320
+ "compression",
321
+ "hpp",
322
+ "mongoSanitize",
323
+ "xss",
324
+ ];
325
+ securityMiddleware.forEach((middleware) => {
326
+ try {
327
+ this.middlewareAPI.enable(middleware);
328
+ this.logger.debug("server", `Enabled security middleware: ${middleware}`);
329
+ }
330
+ catch (error) {
331
+ this.logger.warn("server", `Failed to enable ${middleware}: ${error}`);
332
+ }
333
+ });
334
+ // Apply custom security options if provided
335
+ if (options) {
336
+ if (options.helmet) {
337
+ this.middlewareAPI.helmet(options.helmet);
338
+ }
339
+ if (options.cors) {
340
+ this.middlewareAPI.cors(options.cors);
341
+ }
342
+ if (options.rateLimit) {
343
+ this.middlewareAPI.rateLimit(options.rateLimit);
344
+ }
345
+ }
346
+ this.logger.debug("server", "Security middleware enabled successfully");
347
+ }
348
+ else {
349
+ this.logger.warn("server", "Middleware API not available, cannot enable security");
350
+ }
351
+ return this;
352
+ }
353
+ catch (error) {
354
+ this.logger.error("server", `Failed to enable security middleware: ${error}`);
355
+ return this;
356
+ }
357
+ };
358
+ // More missing methods
359
+ this.enableConsoleEncryption = () => { };
360
+ this.disableConsoleEncryption = () => { };
361
+ this.encrypt = (data) => data;
362
+ this.setConsoleEncryptionKey = (key) => { };
363
+ this.enableCors = (options) => this;
364
+ this.enableCompression = (options) => this;
365
+ this.enableRateLimit = (options) => this;
366
+ this.getWithCache = (path, options, handler) => this.get(path, handler);
367
+ this.postWithCache = (path, options, handler) => this.post(path, handler);
368
+ this.putWithCache = (path, options, handler) => this.put(path, handler);
369
+ this.deleteWithCache = (path, options, handler) => this.delete(path, handler);
370
+ this.patchWithCache = (path, options, handler) => this.patch(path, handler);
371
+ this.optionsWithCache = (path, options, handler) => this.options(path, handler);
372
+ this.headWithCache = (path, options, handler) => this.head(path, handler);
373
+ // Final missing methods
374
+ this.setConsoleEncryptionDisplayMode = (_mode) => { };
375
+ this.getEncryptedLogs = () => [];
376
+ this.restoreConsoleFromEncrypted = async (_encryptedData, _key) => [];
377
+ this.isConsoleEncryptionEnabled = () => false;
378
+ this.getConsoleEncryptionKey = () => "";
379
+ this.clearEncryptedLogs = () => { };
380
+ this.exportEncryptedLogs = (_format) => null;
381
+ this.importEncryptedLogs = (_data) => { };
382
+ this.getConsoleEncryptionStats = () => null;
383
+ this.getConsoleEncryptionStatus = () => null;
384
+ this.useSecure = (_options) => this;
385
+ this.usePerformance = (_options) => this;
386
+ this.getMiddleware = () => null;
387
+ this.getMiddlewareStats = () => null;
388
+ this.logger = logger;
389
+ this.httpServer = new XyPrissHttpServer(logger);
390
+ this.middlewareAPI = new XyPrissMiddleware(this);
391
+ this.setupDefaultSettings();
392
+ this.logger.debug("routing", "XyprissApp created with new XyPrisHttpServer");
393
+ }
394
+ /**
395
+ * Setup default Express-like settings
396
+ */
397
+ setupDefaultSettings() {
398
+ this.settings = {
399
+ "x-powered-by": false,
400
+ etag: "weak",
401
+ env: process.env.NODE_ENV || "development",
402
+ "subdomain offset": 2,
403
+ "trust proxy": false,
404
+ "view cache": true,
405
+ "view engine": false,
406
+ views: process.cwd() + "/views",
407
+ };
408
+ }
409
+ // ===== HTTP METHOD IMPLEMENTATIONS =====
410
+ get(path, ...handlers) {
411
+ this.logger.debug("server", `Registering GET route: ${path}`);
412
+ this.httpServer.get(path, ...this.convertHandlers(handlers));
413
+ }
414
+ post(path, ...handlers) {
415
+ this.httpServer.post(path, ...this.convertHandlers(handlers));
416
+ }
417
+ put(path, ...handlers) {
418
+ this.httpServer.put(path, ...this.convertHandlers(handlers));
419
+ }
420
+ delete(path, ...handlers) {
421
+ this.httpServer.delete(path, ...this.convertHandlers(handlers));
422
+ }
423
+ patch(path, ...handlers) {
424
+ this.httpServer.patch(path, ...this.convertHandlers(handlers));
425
+ }
426
+ options(path, ...handlers) {
427
+ this.httpServer.options(path, ...this.convertHandlers(handlers));
428
+ }
429
+ head(path, ...handlers) {
430
+ this.httpServer.head(path, ...this.convertHandlers(handlers));
431
+ }
432
+ all(path, ...handlers) {
433
+ // Implement all HTTP methods
434
+ const convertedHandlers = this.convertHandlers(handlers);
435
+ this.httpServer.get(path, ...convertedHandlers);
436
+ this.httpServer.post(path, ...convertedHandlers);
437
+ this.httpServer.put(path, ...convertedHandlers);
438
+ this.httpServer.delete(path, ...convertedHandlers);
439
+ this.httpServer.patch(path, ...convertedHandlers);
440
+ this.httpServer.options(path, ...convertedHandlers);
441
+ this.httpServer.head(path, ...convertedHandlers);
442
+ }
443
+ // ===== MIDDLEWARE METHODS =====
444
+ use(pathOrRouter, router) {
445
+ if (typeof pathOrRouter === "string" &&
446
+ router instanceof XyPrissRouter) {
447
+ // app.use('/api', router)
448
+ this.mountRouter(pathOrRouter, router);
449
+ }
450
+ else if (pathOrRouter instanceof XyPrissRouter) {
451
+ // app.use(router)
452
+ this.mountRouter("/", pathOrRouter);
453
+ }
454
+ else if (typeof pathOrRouter === "function") {
455
+ // app.use(middleware)
456
+ this.httpServer.use(pathOrRouter);
457
+ }
458
+ else if (typeof pathOrRouter === "string" &&
459
+ typeof router === "function") {
460
+ // app.use(path, middleware)
461
+ this.httpServer.use(pathOrRouter, router);
462
+ }
463
+ return this;
464
+ }
465
+ listen(port, hostnameOrCallback, callback) {
466
+ let hostname = "localhost";
467
+ let cb = callback;
468
+ if (typeof hostnameOrCallback === "string") {
469
+ hostname = hostnameOrCallback;
470
+ }
471
+ else if (typeof hostnameOrCallback === "function") {
472
+ cb = hostnameOrCallback;
473
+ }
474
+ this.logger.debug("server", `listen() called: ${hostname}:${port}`);
475
+ const server = this.httpServer.listen(port, hostname, cb);
476
+ this.logger.debug("server", `listen() returning server: ${typeof server}, has 'on': ${typeof server?.on}`);
477
+ return server;
478
+ }
479
+ set(setting, val) {
480
+ this.settings[setting] = val;
481
+ }
482
+ getSetting(setting) {
483
+ return this.settings[setting];
484
+ }
485
+ enabled(setting) {
486
+ return Boolean(this.settings[setting]);
487
+ }
488
+ disabled(setting) {
489
+ return !this.settings[setting];
490
+ }
491
+ enable(setting) {
492
+ this.settings[setting] = true;
493
+ }
494
+ disable(setting) {
495
+ this.settings[setting] = false;
496
+ }
497
+ engine(ext, fn) {
498
+ // Template engine support - basic implementation
499
+ this.settings[`engine:${ext}`] = fn;
500
+ return this;
501
+ }
502
+ param(name, handler) {
503
+ // Parameter preprocessing - basic implementation
504
+ this.settings[`param:${name}`] = handler;
505
+ }
506
+ path() {
507
+ return this.mountpath;
508
+ }
509
+ render(_view, _options, callback) {
510
+ // Template rendering - basic implementation
511
+ if (callback) {
512
+ callback(new Error("Template rendering not implemented"));
513
+ }
514
+ }
515
+ route(path) {
516
+ // Route creation - basic implementation
517
+ return {
518
+ get: (handler) => this.get(path, handler),
519
+ post: (handler) => this.post(path, handler),
520
+ put: (handler) => this.put(path, handler),
521
+ delete: (handler) => this.delete(path, handler),
522
+ patch: (handler) => this.patch(path, handler),
523
+ options: (handler) => this.options(path, handler),
524
+ head: (handler) => this.head(path, handler),
525
+ all: (handler) => this.all(path, handler),
526
+ };
527
+ }
528
+ // ===== CACHE METHODS =====
529
+ setCache(cache) {
530
+ this.cache = cache;
531
+ }
532
+ getCache() {
533
+ return this.cache;
534
+ }
535
+ /**
536
+ * Access the middleware management API
537
+ */
538
+ middleware(config) {
539
+ return this.middlewareAPI;
540
+ }
541
+ /**
542
+ * Mount a router at a specific path
543
+ */
544
+ mountRouter(basePath, router) {
545
+ const routes = router.getRoutes();
546
+ const middleware = router.getMiddleware();
547
+ this.logger.debug("server", `🔧 Mounting router at ${basePath} with ${routes.length} routes`);
548
+ routes.forEach((route) => {
549
+ this.logger.debug("server", `🔧 Router route: ${route.method} ${route.path} (has pattern: ${!!route.pattern})`);
550
+ });
551
+ // Register router middleware first
552
+ middleware.forEach((mw) => {
553
+ this.httpServer.use(mw);
554
+ });
555
+ // Register all routes from the router
556
+ routes.forEach((route) => {
557
+ const fullPath = this.joinPaths(basePath, route.path);
558
+ // Register route-specific middleware
559
+ route.middleware.forEach((mw) => {
560
+ this.httpServer.use(mw);
561
+ });
562
+ // If the route has a compiled pattern, we need to create a new pattern
563
+ // that includes the base path
564
+ let routePath = fullPath;
565
+ if (route.pattern && basePath !== "/") {
566
+ // Create a new pattern that includes the base path
567
+ const originalPattern = route.pattern.source;
568
+ const flags = route.pattern.flags;
569
+ // Remove the ^ and $ anchors from the original pattern
570
+ const cleanPattern = originalPattern
571
+ .replace(/^\^/, "")
572
+ .replace(/\$$/, "");
573
+ // Create new pattern with base path
574
+ const basePathEscaped = basePath.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
575
+ const newPatternSource = `^${basePathEscaped}${cleanPattern}$`;
576
+ routePath = new RegExp(newPatternSource, flags);
577
+ this.logger.debug("server", `🔧 Registering route: ${route.method} ${fullPath} (compiled pattern with base path)`);
578
+ }
579
+ else if (route.pattern) {
580
+ // Use the original pattern if no base path
581
+ routePath = route.pattern;
582
+ this.logger.debug("server", `🔧 Registering route: ${route.method} ${fullPath} (original compiled pattern)`);
583
+ }
584
+ else {
585
+ this.logger.debug("server", `🔧 Registering route: ${route.method} ${fullPath} (string path)`);
586
+ }
587
+ // Register the route using the appropriate HTTP method
588
+ const allHandlers = [...route.middleware, route.handler];
589
+ // For RegExp routes, we need to manually add the route with parameter names
590
+ if (routePath instanceof RegExp && route.paramNames) {
591
+ // Manually add route to HTTP server with parameter names
592
+ this.httpServer.addRouteWithParams(route.method.toUpperCase(), routePath, route.paramNames, allHandlers);
593
+ }
594
+ else {
595
+ // Use standard HTTP method registration
596
+ switch (route.method.toUpperCase()) {
597
+ case "GET":
598
+ this.httpServer.get(routePath, ...allHandlers);
599
+ break;
600
+ case "POST":
601
+ this.httpServer.post(routePath, ...allHandlers);
602
+ break;
603
+ case "PUT":
604
+ this.httpServer.put(routePath, ...allHandlers);
605
+ break;
606
+ case "DELETE":
607
+ this.httpServer.delete(routePath, ...allHandlers);
608
+ break;
609
+ case "PATCH":
610
+ this.httpServer.patch(routePath, ...allHandlers);
611
+ break;
612
+ case "OPTIONS":
613
+ this.httpServer.options(routePath, ...allHandlers);
614
+ break;
615
+ case "HEAD":
616
+ this.httpServer.head(routePath, ...allHandlers);
617
+ break;
618
+ default:
619
+ this.logger.warn("server", `Unsupported HTTP method: ${route.method}`);
620
+ break;
621
+ }
622
+ }
623
+ this.logger.debug("server", `Mounted route: ${route.method} ${fullPath}`);
624
+ });
625
+ this.logger.debug("server", `Mounted router at ${basePath} with ${routes.length} routes`);
626
+ }
627
+ /**
628
+ * Join two paths correctly
629
+ */
630
+ joinPaths(basePath, subPath) {
631
+ const normalizedBase = basePath.endsWith("/")
632
+ ? basePath.slice(0, -1)
633
+ : basePath;
634
+ const normalizedSub = subPath.startsWith("/") ? subPath : "/" + subPath;
635
+ if (normalizedBase === "" || normalizedBase === "/") {
636
+ return normalizedSub;
637
+ }
638
+ return normalizedBase + normalizedSub;
639
+ }
640
+ // ===== HELPER METHODS =====
641
+ /**
642
+ * Convert Express RequestHandler to XyPrisHttpServer handler
643
+ */
644
+ convertHandler(handler) {
645
+ return (req, res, next) => {
646
+ // Type assertion to make it compatible
647
+ return handler(req, res, next);
648
+ };
649
+ }
650
+ /**
651
+ * Convert array of Express RequestHandlers to XyPrisHttpServer handlers
652
+ */
653
+ convertHandlers(handlers) {
654
+ return handlers.map((handler) => this.convertHandler(handler));
655
+ }
656
+ /**
657
+ * Get the underlying HTTP server
658
+ */
659
+ getHttpServer() {
660
+ return this.httpServer;
661
+ }
662
+ /**
663
+ * Close the server
664
+ */
665
+ close(callback) {
666
+ this.httpServer.close(callback);
667
+ }
668
+ /**
669
+ * Get server address
670
+ */
671
+ address() {
672
+ return this.httpServer.address();
673
+ }
674
+ }
675
+
676
+ export { XyprissApp };
677
+ //# sourceMappingURL=XyprissApp.js.map