@morojs/moro 1.0.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 (345) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +233 -0
  3. package/dist/core/config/index.d.ts +19 -0
  4. package/dist/core/config/index.js +59 -0
  5. package/dist/core/config/index.js.map +1 -0
  6. package/dist/core/config/loader.d.ts +6 -0
  7. package/dist/core/config/loader.js +288 -0
  8. package/dist/core/config/loader.js.map +1 -0
  9. package/dist/core/config/schema.d.ts +335 -0
  10. package/dist/core/config/schema.js +286 -0
  11. package/dist/core/config/schema.js.map +1 -0
  12. package/dist/core/config/utils.d.ts +50 -0
  13. package/dist/core/config/utils.js +185 -0
  14. package/dist/core/config/utils.js.map +1 -0
  15. package/dist/core/database/adapters/drizzle.d.ts +29 -0
  16. package/dist/core/database/adapters/drizzle.js +366 -0
  17. package/dist/core/database/adapters/drizzle.js.map +1 -0
  18. package/dist/core/database/adapters/index.d.ts +8 -0
  19. package/dist/core/database/adapters/index.js +48 -0
  20. package/dist/core/database/adapters/index.js.map +1 -0
  21. package/dist/core/database/adapters/mongodb.d.ts +35 -0
  22. package/dist/core/database/adapters/mongodb.js +215 -0
  23. package/dist/core/database/adapters/mongodb.js.map +1 -0
  24. package/dist/core/database/adapters/mysql.d.ts +23 -0
  25. package/dist/core/database/adapters/mysql.js +149 -0
  26. package/dist/core/database/adapters/mysql.js.map +1 -0
  27. package/dist/core/database/adapters/postgresql.d.ts +24 -0
  28. package/dist/core/database/adapters/postgresql.js +160 -0
  29. package/dist/core/database/adapters/postgresql.js.map +1 -0
  30. package/dist/core/database/adapters/redis.d.ts +50 -0
  31. package/dist/core/database/adapters/redis.js +266 -0
  32. package/dist/core/database/adapters/redis.js.map +1 -0
  33. package/dist/core/database/adapters/sqlite.d.ts +23 -0
  34. package/dist/core/database/adapters/sqlite.js +194 -0
  35. package/dist/core/database/adapters/sqlite.js.map +1 -0
  36. package/dist/core/database/index.d.ts +2 -0
  37. package/dist/core/database/index.js +20 -0
  38. package/dist/core/database/index.js.map +1 -0
  39. package/dist/core/docs/index.d.ts +63 -0
  40. package/dist/core/docs/index.js +170 -0
  41. package/dist/core/docs/index.js.map +1 -0
  42. package/dist/core/docs/openapi-generator.d.ts +124 -0
  43. package/dist/core/docs/openapi-generator.js +413 -0
  44. package/dist/core/docs/openapi-generator.js.map +1 -0
  45. package/dist/core/docs/simple-docs.d.ts +21 -0
  46. package/dist/core/docs/simple-docs.js +268 -0
  47. package/dist/core/docs/simple-docs.js.map +1 -0
  48. package/dist/core/docs/swagger-ui.d.ts +28 -0
  49. package/dist/core/docs/swagger-ui.js +317 -0
  50. package/dist/core/docs/swagger-ui.js.map +1 -0
  51. package/dist/core/docs/zod-to-openapi.d.ts +29 -0
  52. package/dist/core/docs/zod-to-openapi.js +414 -0
  53. package/dist/core/docs/zod-to-openapi.js.map +1 -0
  54. package/dist/core/events/event-bus.d.ts +27 -0
  55. package/dist/core/events/event-bus.js +193 -0
  56. package/dist/core/events/event-bus.js.map +1 -0
  57. package/dist/core/events/index.d.ts +2 -0
  58. package/dist/core/events/index.js +7 -0
  59. package/dist/core/events/index.js.map +1 -0
  60. package/dist/core/framework.d.ts +57 -0
  61. package/dist/core/framework.js +432 -0
  62. package/dist/core/framework.js.map +1 -0
  63. package/dist/core/http/http-server.d.ts +114 -0
  64. package/dist/core/http/http-server.js +1154 -0
  65. package/dist/core/http/http-server.js.map +1 -0
  66. package/dist/core/http/index.d.ts +3 -0
  67. package/dist/core/http/index.js +10 -0
  68. package/dist/core/http/index.js.map +1 -0
  69. package/dist/core/http/router.d.ts +14 -0
  70. package/dist/core/http/router.js +113 -0
  71. package/dist/core/http/router.js.map +1 -0
  72. package/dist/core/logger/filters.d.ts +9 -0
  73. package/dist/core/logger/filters.js +134 -0
  74. package/dist/core/logger/filters.js.map +1 -0
  75. package/dist/core/logger/index.d.ts +3 -0
  76. package/dist/core/logger/index.js +26 -0
  77. package/dist/core/logger/index.js.map +1 -0
  78. package/dist/core/logger/logger.d.ts +49 -0
  79. package/dist/core/logger/logger.js +332 -0
  80. package/dist/core/logger/logger.js.map +1 -0
  81. package/dist/core/logger/outputs.d.ts +42 -0
  82. package/dist/core/logger/outputs.js +110 -0
  83. package/dist/core/logger/outputs.js.map +1 -0
  84. package/dist/core/middleware/built-in/adapters/cache/file.d.ts +15 -0
  85. package/dist/core/middleware/built-in/adapters/cache/file.js +128 -0
  86. package/dist/core/middleware/built-in/adapters/cache/file.js.map +1 -0
  87. package/dist/core/middleware/built-in/adapters/cache/index.d.ts +5 -0
  88. package/dist/core/middleware/built-in/adapters/cache/index.js +28 -0
  89. package/dist/core/middleware/built-in/adapters/cache/index.js.map +1 -0
  90. package/dist/core/middleware/built-in/adapters/cache/memory.d.ts +11 -0
  91. package/dist/core/middleware/built-in/adapters/cache/memory.js +65 -0
  92. package/dist/core/middleware/built-in/adapters/cache/memory.js.map +1 -0
  93. package/dist/core/middleware/built-in/adapters/cache/redis.d.ts +17 -0
  94. package/dist/core/middleware/built-in/adapters/cache/redis.js +91 -0
  95. package/dist/core/middleware/built-in/adapters/cache/redis.js.map +1 -0
  96. package/dist/core/middleware/built-in/adapters/cdn/azure.d.ts +21 -0
  97. package/dist/core/middleware/built-in/adapters/cdn/azure.js +40 -0
  98. package/dist/core/middleware/built-in/adapters/cdn/azure.js.map +1 -0
  99. package/dist/core/middleware/built-in/adapters/cdn/cloudflare.d.ts +14 -0
  100. package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js +77 -0
  101. package/dist/core/middleware/built-in/adapters/cdn/cloudflare.js.map +1 -0
  102. package/dist/core/middleware/built-in/adapters/cdn/cloudfront.d.ts +15 -0
  103. package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js +73 -0
  104. package/dist/core/middleware/built-in/adapters/cdn/cloudfront.js.map +1 -0
  105. package/dist/core/middleware/built-in/adapters/cdn/index.d.ts +5 -0
  106. package/dist/core/middleware/built-in/adapters/cdn/index.js +28 -0
  107. package/dist/core/middleware/built-in/adapters/cdn/index.js.map +1 -0
  108. package/dist/core/middleware/built-in/adapters/index.d.ts +4 -0
  109. package/dist/core/middleware/built-in/adapters/index.js +26 -0
  110. package/dist/core/middleware/built-in/adapters/index.js.map +1 -0
  111. package/dist/core/middleware/built-in/auth.d.ts +2 -0
  112. package/dist/core/middleware/built-in/auth.js +38 -0
  113. package/dist/core/middleware/built-in/auth.js.map +1 -0
  114. package/dist/core/middleware/built-in/cache.d.ts +3 -0
  115. package/dist/core/middleware/built-in/cache.js +188 -0
  116. package/dist/core/middleware/built-in/cache.js.map +1 -0
  117. package/dist/core/middleware/built-in/cdn.d.ts +3 -0
  118. package/dist/core/middleware/built-in/cdn.js +115 -0
  119. package/dist/core/middleware/built-in/cdn.js.map +1 -0
  120. package/dist/core/middleware/built-in/cookie.d.ts +14 -0
  121. package/dist/core/middleware/built-in/cookie.js +68 -0
  122. package/dist/core/middleware/built-in/cookie.js.map +1 -0
  123. package/dist/core/middleware/built-in/cors.d.ts +2 -0
  124. package/dist/core/middleware/built-in/cors.js +29 -0
  125. package/dist/core/middleware/built-in/cors.js.map +1 -0
  126. package/dist/core/middleware/built-in/csp.d.ts +22 -0
  127. package/dist/core/middleware/built-in/csp.js +74 -0
  128. package/dist/core/middleware/built-in/csp.js.map +1 -0
  129. package/dist/core/middleware/built-in/csrf.d.ts +9 -0
  130. package/dist/core/middleware/built-in/csrf.js +66 -0
  131. package/dist/core/middleware/built-in/csrf.js.map +1 -0
  132. package/dist/core/middleware/built-in/error-tracker.d.ts +1 -0
  133. package/dist/core/middleware/built-in/error-tracker.js +19 -0
  134. package/dist/core/middleware/built-in/error-tracker.js.map +1 -0
  135. package/dist/core/middleware/built-in/index.d.ts +70 -0
  136. package/dist/core/middleware/built-in/index.js +70 -0
  137. package/dist/core/middleware/built-in/index.js.map +1 -0
  138. package/dist/core/middleware/built-in/performance-monitor.d.ts +1 -0
  139. package/dist/core/middleware/built-in/performance-monitor.js +22 -0
  140. package/dist/core/middleware/built-in/performance-monitor.js.map +1 -0
  141. package/dist/core/middleware/built-in/rate-limit.d.ts +6 -0
  142. package/dist/core/middleware/built-in/rate-limit.js +47 -0
  143. package/dist/core/middleware/built-in/rate-limit.js.map +1 -0
  144. package/dist/core/middleware/built-in/request-logger.d.ts +1 -0
  145. package/dist/core/middleware/built-in/request-logger.js +15 -0
  146. package/dist/core/middleware/built-in/request-logger.js.map +1 -0
  147. package/dist/core/middleware/built-in/session.d.ts +41 -0
  148. package/dist/core/middleware/built-in/session.js +209 -0
  149. package/dist/core/middleware/built-in/session.js.map +1 -0
  150. package/dist/core/middleware/built-in/sse.d.ts +6 -0
  151. package/dist/core/middleware/built-in/sse.js +73 -0
  152. package/dist/core/middleware/built-in/sse.js.map +1 -0
  153. package/dist/core/middleware/built-in/validation.d.ts +2 -0
  154. package/dist/core/middleware/built-in/validation.js +31 -0
  155. package/dist/core/middleware/built-in/validation.js.map +1 -0
  156. package/dist/core/middleware/index.d.ts +21 -0
  157. package/dist/core/middleware/index.js +152 -0
  158. package/dist/core/middleware/index.js.map +1 -0
  159. package/dist/core/modules/auto-discovery.d.ts +27 -0
  160. package/dist/core/modules/auto-discovery.js +255 -0
  161. package/dist/core/modules/auto-discovery.js.map +1 -0
  162. package/dist/core/modules/index.d.ts +2 -0
  163. package/dist/core/modules/index.js +11 -0
  164. package/dist/core/modules/index.js.map +1 -0
  165. package/dist/core/modules/modules.d.ts +10 -0
  166. package/dist/core/modules/modules.js +137 -0
  167. package/dist/core/modules/modules.js.map +1 -0
  168. package/dist/core/networking/index.d.ts +2 -0
  169. package/dist/core/networking/index.js +9 -0
  170. package/dist/core/networking/index.js.map +1 -0
  171. package/dist/core/networking/service-discovery.d.ts +38 -0
  172. package/dist/core/networking/service-discovery.js +233 -0
  173. package/dist/core/networking/service-discovery.js.map +1 -0
  174. package/dist/core/networking/websocket-manager.d.ts +27 -0
  175. package/dist/core/networking/websocket-manager.js +211 -0
  176. package/dist/core/networking/websocket-manager.js.map +1 -0
  177. package/dist/core/routing/app-integration.d.ts +42 -0
  178. package/dist/core/routing/app-integration.js +152 -0
  179. package/dist/core/routing/app-integration.js.map +1 -0
  180. package/dist/core/routing/index.d.ts +106 -0
  181. package/dist/core/routing/index.js +343 -0
  182. package/dist/core/routing/index.js.map +1 -0
  183. package/dist/core/runtime/aws-lambda-adapter.d.ts +43 -0
  184. package/dist/core/runtime/aws-lambda-adapter.js +108 -0
  185. package/dist/core/runtime/aws-lambda-adapter.js.map +1 -0
  186. package/dist/core/runtime/base-adapter.d.ts +16 -0
  187. package/dist/core/runtime/base-adapter.js +105 -0
  188. package/dist/core/runtime/base-adapter.js.map +1 -0
  189. package/dist/core/runtime/cloudflare-workers-adapter.d.ts +18 -0
  190. package/dist/core/runtime/cloudflare-workers-adapter.js +131 -0
  191. package/dist/core/runtime/cloudflare-workers-adapter.js.map +1 -0
  192. package/dist/core/runtime/index.d.ts +14 -0
  193. package/dist/core/runtime/index.js +56 -0
  194. package/dist/core/runtime/index.js.map +1 -0
  195. package/dist/core/runtime/node-adapter.d.ts +15 -0
  196. package/dist/core/runtime/node-adapter.js +204 -0
  197. package/dist/core/runtime/node-adapter.js.map +1 -0
  198. package/dist/core/runtime/vercel-edge-adapter.d.ts +10 -0
  199. package/dist/core/runtime/vercel-edge-adapter.js +106 -0
  200. package/dist/core/runtime/vercel-edge-adapter.js.map +1 -0
  201. package/dist/core/utilities/circuit-breaker.d.ts +14 -0
  202. package/dist/core/utilities/circuit-breaker.js +42 -0
  203. package/dist/core/utilities/circuit-breaker.js.map +1 -0
  204. package/dist/core/utilities/container.d.ts +116 -0
  205. package/dist/core/utilities/container.js +529 -0
  206. package/dist/core/utilities/container.js.map +1 -0
  207. package/dist/core/utilities/hooks.d.ts +24 -0
  208. package/dist/core/utilities/hooks.js +131 -0
  209. package/dist/core/utilities/hooks.js.map +1 -0
  210. package/dist/core/utilities/index.d.ts +4 -0
  211. package/dist/core/utilities/index.js +22 -0
  212. package/dist/core/utilities/index.js.map +1 -0
  213. package/dist/core/validation/index.d.ts +30 -0
  214. package/dist/core/validation/index.js +144 -0
  215. package/dist/core/validation/index.js.map +1 -0
  216. package/dist/index.d.ts +30 -0
  217. package/dist/index.js +72 -0
  218. package/dist/index.js.map +1 -0
  219. package/dist/moro.d.ts +82 -0
  220. package/dist/moro.js +679 -0
  221. package/dist/moro.js.map +1 -0
  222. package/dist/types/cache.d.ts +34 -0
  223. package/dist/types/cache.js +3 -0
  224. package/dist/types/cache.js.map +1 -0
  225. package/dist/types/cdn.d.ts +19 -0
  226. package/dist/types/cdn.js +3 -0
  227. package/dist/types/cdn.js.map +1 -0
  228. package/dist/types/core.d.ts +13 -0
  229. package/dist/types/core.js +3 -0
  230. package/dist/types/core.js.map +1 -0
  231. package/dist/types/database.d.ts +29 -0
  232. package/dist/types/database.js +3 -0
  233. package/dist/types/database.js.map +1 -0
  234. package/dist/types/discovery.d.ts +6 -0
  235. package/dist/types/discovery.js +3 -0
  236. package/dist/types/discovery.js.map +1 -0
  237. package/dist/types/events.d.ts +116 -0
  238. package/dist/types/events.js +3 -0
  239. package/dist/types/events.js.map +1 -0
  240. package/dist/types/hooks.d.ts +38 -0
  241. package/dist/types/hooks.js +3 -0
  242. package/dist/types/hooks.js.map +1 -0
  243. package/dist/types/http.d.ts +51 -0
  244. package/dist/types/http.js +3 -0
  245. package/dist/types/http.js.map +1 -0
  246. package/dist/types/logger.d.ts +77 -0
  247. package/dist/types/logger.js +3 -0
  248. package/dist/types/logger.js.map +1 -0
  249. package/dist/types/module.d.ts +91 -0
  250. package/dist/types/module.js +3 -0
  251. package/dist/types/module.js.map +1 -0
  252. package/dist/types/runtime.d.ts +48 -0
  253. package/dist/types/runtime.js +3 -0
  254. package/dist/types/runtime.js.map +1 -0
  255. package/dist/types/session.d.ts +66 -0
  256. package/dist/types/session.js +3 -0
  257. package/dist/types/session.js.map +1 -0
  258. package/package.json +176 -0
  259. package/src/core/config/index.ts +47 -0
  260. package/src/core/config/loader.ts +366 -0
  261. package/src/core/config/schema.ts +346 -0
  262. package/src/core/config/utils.ts +220 -0
  263. package/src/core/database/README.md +228 -0
  264. package/src/core/database/adapters/drizzle.ts +425 -0
  265. package/src/core/database/adapters/index.ts +45 -0
  266. package/src/core/database/adapters/mongodb.ts +292 -0
  267. package/src/core/database/adapters/mysql.ts +217 -0
  268. package/src/core/database/adapters/postgresql.ts +211 -0
  269. package/src/core/database/adapters/redis.ts +331 -0
  270. package/src/core/database/adapters/sqlite.ts +255 -0
  271. package/src/core/database/index.ts +3 -0
  272. package/src/core/docs/index.ts +245 -0
  273. package/src/core/docs/openapi-generator.ts +588 -0
  274. package/src/core/docs/simple-docs.ts +305 -0
  275. package/src/core/docs/swagger-ui.ts +370 -0
  276. package/src/core/docs/zod-to-openapi.ts +532 -0
  277. package/src/core/events/event-bus.ts +249 -0
  278. package/src/core/events/index.ts +12 -0
  279. package/src/core/framework.ts +621 -0
  280. package/src/core/http/http-server.ts +1421 -0
  281. package/src/core/http/index.ts +11 -0
  282. package/src/core/http/router.ts +153 -0
  283. package/src/core/logger/filters.ts +148 -0
  284. package/src/core/logger/index.ts +20 -0
  285. package/src/core/logger/logger.ts +434 -0
  286. package/src/core/logger/outputs.ts +136 -0
  287. package/src/core/middleware/built-in/adapters/cache/file.ts +106 -0
  288. package/src/core/middleware/built-in/adapters/cache/index.ts +26 -0
  289. package/src/core/middleware/built-in/adapters/cache/memory.ts +73 -0
  290. package/src/core/middleware/built-in/adapters/cache/redis.ts +103 -0
  291. package/src/core/middleware/built-in/adapters/cdn/azure.ts +68 -0
  292. package/src/core/middleware/built-in/adapters/cdn/cloudflare.ts +100 -0
  293. package/src/core/middleware/built-in/adapters/cdn/cloudfront.ts +92 -0
  294. package/src/core/middleware/built-in/adapters/cdn/index.ts +23 -0
  295. package/src/core/middleware/built-in/adapters/index.ts +7 -0
  296. package/src/core/middleware/built-in/auth.ts +39 -0
  297. package/src/core/middleware/built-in/cache.ts +228 -0
  298. package/src/core/middleware/built-in/cdn.ts +151 -0
  299. package/src/core/middleware/built-in/cookie.ts +90 -0
  300. package/src/core/middleware/built-in/cors.ts +38 -0
  301. package/src/core/middleware/built-in/csp.ts +107 -0
  302. package/src/core/middleware/built-in/csrf.ts +87 -0
  303. package/src/core/middleware/built-in/error-tracker.ts +16 -0
  304. package/src/core/middleware/built-in/index.ts +57 -0
  305. package/src/core/middleware/built-in/performance-monitor.ts +25 -0
  306. package/src/core/middleware/built-in/rate-limit.ts +60 -0
  307. package/src/core/middleware/built-in/request-logger.ts +14 -0
  308. package/src/core/middleware/built-in/session.ts +311 -0
  309. package/src/core/middleware/built-in/sse.ts +91 -0
  310. package/src/core/middleware/built-in/validation.ts +33 -0
  311. package/src/core/middleware/index.ts +188 -0
  312. package/src/core/modules/auto-discovery.ts +265 -0
  313. package/src/core/modules/index.ts +6 -0
  314. package/src/core/modules/modules.ts +125 -0
  315. package/src/core/networking/index.ts +7 -0
  316. package/src/core/networking/service-discovery.ts +309 -0
  317. package/src/core/networking/websocket-manager.ts +259 -0
  318. package/src/core/routing/app-integration.ts +229 -0
  319. package/src/core/routing/index.ts +519 -0
  320. package/src/core/runtime/aws-lambda-adapter.ts +157 -0
  321. package/src/core/runtime/base-adapter.ts +140 -0
  322. package/src/core/runtime/cloudflare-workers-adapter.ts +166 -0
  323. package/src/core/runtime/index.ts +74 -0
  324. package/src/core/runtime/node-adapter.ts +210 -0
  325. package/src/core/runtime/vercel-edge-adapter.ts +125 -0
  326. package/src/core/utilities/circuit-breaker.ts +46 -0
  327. package/src/core/utilities/container.ts +760 -0
  328. package/src/core/utilities/hooks.ts +148 -0
  329. package/src/core/utilities/index.ts +16 -0
  330. package/src/core/validation/index.ts +216 -0
  331. package/src/index.ts +120 -0
  332. package/src/moro.ts +842 -0
  333. package/src/types/cache.ts +38 -0
  334. package/src/types/cdn.ts +22 -0
  335. package/src/types/core.ts +17 -0
  336. package/src/types/database.ts +40 -0
  337. package/src/types/discovery.ts +7 -0
  338. package/src/types/events.ts +90 -0
  339. package/src/types/hooks.ts +47 -0
  340. package/src/types/http.ts +70 -0
  341. package/src/types/logger.ts +109 -0
  342. package/src/types/module.ts +87 -0
  343. package/src/types/runtime.ts +91 -0
  344. package/src/types/session.ts +89 -0
  345. package/tsconfig.json +21 -0
@@ -0,0 +1,332 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createFrameworkLogger = exports.logger = exports.MoroLogger = void 0;
4
+ exports.configureGlobalLogger = configureGlobalLogger;
5
+ exports.applyLoggingConfiguration = applyLoggingConfiguration;
6
+ // Moro Logger - Beautiful, Fast, Feature-Rich
7
+ const perf_hooks_1 = require("perf_hooks");
8
+ class MoroLogger {
9
+ constructor(options = {}) {
10
+ this.level = "info";
11
+ this.outputs = new Map();
12
+ this.filters = new Map();
13
+ this.history = [];
14
+ this.timers = new Map();
15
+ this.metrics = {
16
+ totalLogs: 0,
17
+ logsByLevel: { debug: 0, info: 0, warn: 0, error: 0, fatal: 0 },
18
+ logsByContext: {},
19
+ averageLogRate: 0,
20
+ errorRate: 0,
21
+ memoryUsage: 0,
22
+ };
23
+ this.startTime = Date.now();
24
+ this.options = {
25
+ level: "info",
26
+ enableColors: true,
27
+ enableTimestamp: true,
28
+ enableContext: true,
29
+ enableMetadata: true,
30
+ enablePerformance: true,
31
+ format: "pretty",
32
+ outputs: [],
33
+ filters: [],
34
+ maxEntries: 1000,
35
+ ...options,
36
+ };
37
+ this.level = this.options.level || "info";
38
+ // Add default console output
39
+ this.addOutput({
40
+ name: "console",
41
+ write: this.writeToConsole.bind(this),
42
+ format: this.options.format,
43
+ });
44
+ // Add custom outputs
45
+ this.options.outputs?.forEach((output) => this.addOutput(output));
46
+ this.options.filters?.forEach((filter) => this.addFilter(filter));
47
+ }
48
+ debug(message, context, metadata) {
49
+ this.log("debug", message, context, metadata);
50
+ }
51
+ info(message, context, metadata) {
52
+ this.log("info", message, context, metadata);
53
+ }
54
+ warn(message, context, metadata) {
55
+ this.log("warn", message, context, metadata);
56
+ }
57
+ error(message, context, metadata) {
58
+ const msg = message instanceof Error ? message.message : message;
59
+ const stack = message instanceof Error ? message.stack : undefined;
60
+ this.log("error", msg, context, { ...metadata, stack });
61
+ }
62
+ fatal(message, context, metadata) {
63
+ const msg = message instanceof Error ? message.message : message;
64
+ const stack = message instanceof Error ? message.stack : undefined;
65
+ this.log("fatal", msg, context, { ...metadata, stack });
66
+ }
67
+ time(label) {
68
+ this.timers.set(label, perf_hooks_1.performance.now());
69
+ }
70
+ timeEnd(label, context, metadata) {
71
+ const startTime = this.timers.get(label);
72
+ if (startTime !== undefined) {
73
+ const duration = perf_hooks_1.performance.now() - startTime;
74
+ this.timers.delete(label);
75
+ this.log("info", `Timer: ${label}`, context, {
76
+ ...metadata,
77
+ performance: { duration: Math.round(duration * 100) / 100 },
78
+ });
79
+ }
80
+ }
81
+ child(context, metadata) {
82
+ const childLogger = new MoroLogger(this.options);
83
+ childLogger.contextPrefix = this.contextPrefix
84
+ ? `${this.contextPrefix}:${context}`
85
+ : context;
86
+ childLogger.contextMetadata = { ...this.contextMetadata, ...metadata };
87
+ childLogger.outputs = this.outputs;
88
+ childLogger.filters = this.filters;
89
+ return childLogger;
90
+ }
91
+ setLevel(level) {
92
+ this.level = level;
93
+ }
94
+ addOutput(output) {
95
+ this.outputs.set(output.name, output);
96
+ }
97
+ removeOutput(name) {
98
+ this.outputs.delete(name);
99
+ }
100
+ addFilter(filter) {
101
+ this.filters.set(filter.name, filter);
102
+ }
103
+ removeFilter(name) {
104
+ this.filters.delete(name);
105
+ }
106
+ getHistory(count) {
107
+ const entries = [...this.history];
108
+ return count ? entries.slice(-count) : entries;
109
+ }
110
+ getMetrics() {
111
+ const now = Date.now();
112
+ const uptime = (now - this.startTime) / 1000; // seconds
113
+ const avgRate = uptime > 0 ? this.metrics.totalLogs / uptime : 0;
114
+ const errorCount = this.metrics.logsByLevel.error + this.metrics.logsByLevel.fatal;
115
+ const errorRate = this.metrics.totalLogs > 0
116
+ ? (errorCount / this.metrics.totalLogs) * 100
117
+ : 0;
118
+ return {
119
+ ...this.metrics,
120
+ averageLogRate: Math.round(avgRate * 100) / 100,
121
+ errorRate: Math.round(errorRate * 100) / 100,
122
+ memoryUsage: process.memoryUsage().heapUsed / 1024 / 1024, // MB
123
+ };
124
+ }
125
+ clear() {
126
+ this.history = [];
127
+ this.metrics = {
128
+ totalLogs: 0,
129
+ logsByLevel: { debug: 0, info: 0, warn: 0, error: 0, fatal: 0 },
130
+ logsByContext: {},
131
+ averageLogRate: 0,
132
+ errorRate: 0,
133
+ memoryUsage: 0,
134
+ };
135
+ }
136
+ log(level, message, context, metadata) {
137
+ // Check level threshold
138
+ if (MoroLogger.LEVELS[level] < MoroLogger.LEVELS[this.level]) {
139
+ return;
140
+ }
141
+ // Create log entry
142
+ const entry = {
143
+ timestamp: new Date(),
144
+ level,
145
+ message,
146
+ context: this.contextPrefix
147
+ ? context
148
+ ? `${this.contextPrefix}:${context}`
149
+ : this.contextPrefix
150
+ : context,
151
+ metadata: { ...this.contextMetadata, ...metadata },
152
+ performance: this.options.enablePerformance
153
+ ? {
154
+ memory: process.memoryUsage().heapUsed / 1024 / 1024,
155
+ }
156
+ : undefined,
157
+ };
158
+ // Apply filters
159
+ for (const filter of this.filters.values()) {
160
+ if (!filter.filter(entry)) {
161
+ return;
162
+ }
163
+ }
164
+ // Update metrics
165
+ this.updateMetrics(entry);
166
+ // Store in history
167
+ this.history.push(entry);
168
+ if (this.history.length > (this.options.maxEntries || 1000)) {
169
+ this.history.shift();
170
+ }
171
+ // Write to outputs
172
+ for (const output of this.outputs.values()) {
173
+ if (!output.level ||
174
+ MoroLogger.LEVELS[level] >= MoroLogger.LEVELS[output.level]) {
175
+ try {
176
+ output.write(entry);
177
+ }
178
+ catch (error) {
179
+ console.error("Logger output error:", error);
180
+ }
181
+ }
182
+ }
183
+ }
184
+ updateMetrics(entry) {
185
+ this.metrics.totalLogs++;
186
+ this.metrics.logsByLevel[entry.level]++;
187
+ if (entry.context) {
188
+ this.metrics.logsByContext[entry.context] =
189
+ (this.metrics.logsByContext[entry.context] || 0) + 1;
190
+ }
191
+ }
192
+ writeToConsole(entry) {
193
+ const format = this.options.format || "pretty";
194
+ if (format === "json") {
195
+ console.log(JSON.stringify(entry));
196
+ return;
197
+ }
198
+ if (format === "compact") {
199
+ const level = entry.level.toUpperCase().padEnd(5);
200
+ const context = entry.context ? `[${entry.context}] ` : "";
201
+ console.log(`${level} ${context}${entry.message}`);
202
+ return;
203
+ }
204
+ // Pretty format (default)
205
+ this.writePrettyLog(entry);
206
+ }
207
+ writePrettyLog(entry) {
208
+ const colors = this.options.enableColors !== false;
209
+ const parts = [];
210
+ // Timestamp
211
+ if (this.options.enableTimestamp !== false) {
212
+ const timestamp = entry.timestamp
213
+ .toISOString()
214
+ .replace("T", " ")
215
+ .slice(0, 19);
216
+ parts.push(colors
217
+ ? `${MoroLogger.COLORS.timestamp}${timestamp}${MoroLogger.RESET}`
218
+ : timestamp);
219
+ }
220
+ // Level with color (remove icons)
221
+ const levelColor = colors ? MoroLogger.COLORS[entry.level] : "";
222
+ const levelReset = colors ? MoroLogger.RESET : "";
223
+ const levelText = entry.level.toUpperCase();
224
+ parts.push(`${levelColor}${MoroLogger.BOLD}${levelText}${levelReset}`);
225
+ // Context
226
+ if (entry.context && this.options.enableContext !== false) {
227
+ const contextColor = colors ? MoroLogger.COLORS.context : "";
228
+ parts.push(`${contextColor}[${entry.context}]${levelReset}`);
229
+ }
230
+ // Message
231
+ parts.push(entry.message);
232
+ // Performance info
233
+ if (entry.performance && this.options.enablePerformance !== false) {
234
+ const perfColor = colors ? MoroLogger.COLORS.performance : "";
235
+ const perfParts = [];
236
+ if (entry.performance.duration !== undefined) {
237
+ perfParts.push(`${entry.performance.duration}ms`);
238
+ }
239
+ if (entry.performance.memory !== undefined) {
240
+ perfParts.push(`${Math.round(entry.performance.memory)}MB`);
241
+ }
242
+ if (perfParts.length > 0) {
243
+ parts.push(`${perfColor}(${perfParts.join(", ")})${levelReset}`);
244
+ }
245
+ }
246
+ // Metadata
247
+ if (entry.metadata &&
248
+ Object.keys(entry.metadata).length > 0 &&
249
+ this.options.enableMetadata !== false) {
250
+ const metaColor = colors ? MoroLogger.COLORS.metadata : "";
251
+ const cleanMetadata = { ...entry.metadata };
252
+ delete cleanMetadata.stack; // Handle stack separately
253
+ if (Object.keys(cleanMetadata).length > 0) {
254
+ parts.push(`${metaColor}${JSON.stringify(cleanMetadata)}${levelReset}`);
255
+ }
256
+ }
257
+ // Output main log line
258
+ console.log(parts.join(" "));
259
+ // Stack trace for errors
260
+ if (entry.metadata?.stack &&
261
+ (entry.level === "error" || entry.level === "fatal")) {
262
+ const stackColor = colors ? MoroLogger.COLORS.error : "";
263
+ console.log(`${stackColor}${entry.metadata.stack}${levelReset}`);
264
+ }
265
+ }
266
+ }
267
+ exports.MoroLogger = MoroLogger;
268
+ MoroLogger.LEVELS = {
269
+ debug: 0,
270
+ info: 1,
271
+ warn: 2,
272
+ error: 3,
273
+ fatal: 4,
274
+ };
275
+ MoroLogger.COLORS = {
276
+ debug: "\x1b[36m", // Cyan
277
+ info: "\x1b[32m", // Green
278
+ warn: "\x1b[33m", // Yellow
279
+ error: "\x1b[31m", // Red
280
+ fatal: "\x1b[35m", // Magenta
281
+ timestamp: "\x1b[90m", // Gray
282
+ context: "\x1b[34m", // Blue
283
+ metadata: "\x1b[37m", // White
284
+ performance: "\x1b[36m", // Cyan
285
+ };
286
+ MoroLogger.RESET = "\x1b[0m";
287
+ MoroLogger.BOLD = "\x1b[1m";
288
+ // Global logger instance
289
+ const initialLogLevel = process.env.LOG_LEVEL ||
290
+ process.env.MORO_LOG_LEVEL ||
291
+ (process.env.NODE_ENV === "production" ? "warn" : "debug");
292
+ exports.logger = new MoroLogger({
293
+ level: initialLogLevel,
294
+ enableColors: !process.env.NO_COLOR,
295
+ format: process.env.LOG_FORMAT || "pretty",
296
+ });
297
+ /**
298
+ * Configure the global logger with new settings
299
+ * This allows runtime configuration of the logger
300
+ */
301
+ function configureGlobalLogger(options) {
302
+ if (options.level) {
303
+ exports.logger.setLevel(options.level);
304
+ }
305
+ // Additional configuration options can be added here as needed
306
+ // For now, focusing on level which is the most critical
307
+ }
308
+ /**
309
+ * Apply logging configuration from the config system and/or createApp options
310
+ */
311
+ function applyLoggingConfiguration(configLogging, appOptions) {
312
+ // First apply config system settings (from environment variables)
313
+ if (configLogging?.level) {
314
+ configureGlobalLogger({ level: configLogging.level });
315
+ }
316
+ // Then apply createApp options (these take precedence)
317
+ if (appOptions !== undefined) {
318
+ if (appOptions === false) {
319
+ // Disable logging by setting to fatal level
320
+ configureGlobalLogger({ level: "fatal" });
321
+ }
322
+ else if (typeof appOptions === "object") {
323
+ configureGlobalLogger(appOptions);
324
+ }
325
+ }
326
+ }
327
+ // Framework-specific logger
328
+ const createFrameworkLogger = (context) => {
329
+ return exports.logger.child("Moro", { framework: "moro", context });
330
+ };
331
+ exports.createFrameworkLogger = createFrameworkLogger;
332
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/core/logger/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,42 @@
1
+ import { LogEntry, LogOutput } from "../../types/logger";
2
+ export declare class FileOutput implements LogOutput {
3
+ private filePath;
4
+ private options;
5
+ name: string;
6
+ constructor(filePath: string, options?: {
7
+ format?: "json" | "pretty";
8
+ maxSize?: number;
9
+ rotate?: boolean;
10
+ });
11
+ write(entry: LogEntry): Promise<void>;
12
+ private formatPretty;
13
+ }
14
+ export declare class WebhookOutput implements LogOutput {
15
+ private url;
16
+ private options;
17
+ name: string;
18
+ constructor(url: string, options?: {
19
+ headers?: Record<string, string>;
20
+ batch?: boolean;
21
+ batchSize?: number;
22
+ timeout?: number;
23
+ });
24
+ write(entry: LogEntry): Promise<void>;
25
+ }
26
+ export declare class MemoryOutput implements LogOutput {
27
+ private maxSize;
28
+ name: string;
29
+ private buffer;
30
+ constructor(maxSize?: number);
31
+ write(entry: LogEntry): void;
32
+ getEntries(): LogEntry[];
33
+ clear(): void;
34
+ }
35
+ export declare class StreamOutput implements LogOutput {
36
+ private stream;
37
+ name: string;
38
+ format?: "pretty" | "json" | "compact";
39
+ constructor(stream: NodeJS.WritableStream, format?: "json" | "pretty");
40
+ write(entry: LogEntry): void;
41
+ private formatPretty;
42
+ }
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StreamOutput = exports.MemoryOutput = exports.WebhookOutput = exports.FileOutput = void 0;
4
+ // Advanced Logger Outputs
5
+ const promises_1 = require("fs/promises");
6
+ const path_1 = require("path");
7
+ // File output for persistent logging
8
+ class FileOutput {
9
+ constructor(filePath, options = {}) {
10
+ this.filePath = filePath;
11
+ this.options = options;
12
+ this.name = "file";
13
+ }
14
+ async write(entry) {
15
+ try {
16
+ // Ensure directory exists
17
+ await (0, promises_1.mkdir)((0, path_1.dirname)(this.filePath), { recursive: true });
18
+ const format = this.options.format || "json";
19
+ const line = format === "json"
20
+ ? JSON.stringify(entry) + "\n"
21
+ : this.formatPretty(entry) + "\n";
22
+ await (0, promises_1.appendFile)(this.filePath, line, "utf8");
23
+ // TODO: Implement log rotation if needed
24
+ }
25
+ catch (error) {
26
+ console.error("File logger error:", error);
27
+ }
28
+ }
29
+ formatPretty(entry) {
30
+ const timestamp = entry.timestamp.toISOString();
31
+ const level = entry.level.toUpperCase().padEnd(5);
32
+ const context = entry.context ? `[${entry.context}] ` : "";
33
+ const metadata = entry.metadata && Object.keys(entry.metadata).length > 0
34
+ ? ` ${JSON.stringify(entry.metadata)}`
35
+ : "";
36
+ return `${timestamp} ${level} ${context}${entry.message}${metadata}`;
37
+ }
38
+ }
39
+ exports.FileOutput = FileOutput;
40
+ // HTTP webhook output for external logging services
41
+ class WebhookOutput {
42
+ constructor(url, options = {}) {
43
+ this.url = url;
44
+ this.options = options;
45
+ this.name = "webhook";
46
+ }
47
+ async write(entry) {
48
+ try {
49
+ const response = await fetch(this.url, {
50
+ method: "POST",
51
+ headers: {
52
+ "Content-Type": "application/json",
53
+ ...this.options.headers,
54
+ },
55
+ body: JSON.stringify(entry),
56
+ signal: AbortSignal.timeout(this.options.timeout || 5000),
57
+ });
58
+ if (!response.ok) {
59
+ throw new Error(`Webhook failed: ${response.status}`);
60
+ }
61
+ }
62
+ catch (error) {
63
+ console.error("Webhook logger error:", error);
64
+ }
65
+ }
66
+ }
67
+ exports.WebhookOutput = WebhookOutput;
68
+ // Memory buffer output for testing and debugging
69
+ class MemoryOutput {
70
+ constructor(maxSize = 1000) {
71
+ this.maxSize = maxSize;
72
+ this.name = "memory";
73
+ this.buffer = [];
74
+ }
75
+ write(entry) {
76
+ this.buffer.push(entry);
77
+ if (this.buffer.length > this.maxSize) {
78
+ this.buffer.shift();
79
+ }
80
+ }
81
+ getEntries() {
82
+ return [...this.buffer];
83
+ }
84
+ clear() {
85
+ this.buffer = [];
86
+ }
87
+ }
88
+ exports.MemoryOutput = MemoryOutput;
89
+ // Stream output for custom processing
90
+ class StreamOutput {
91
+ constructor(stream, format = "json") {
92
+ this.stream = stream;
93
+ this.name = "stream";
94
+ this.format = format;
95
+ }
96
+ write(entry) {
97
+ const data = this.format === "json"
98
+ ? JSON.stringify(entry) + "\n"
99
+ : this.formatPretty(entry) + "\n";
100
+ this.stream.write(data);
101
+ }
102
+ formatPretty(entry) {
103
+ const timestamp = entry.timestamp.toISOString();
104
+ const level = entry.level.toUpperCase().padEnd(5);
105
+ const context = entry.context ? `[${entry.context}] ` : "";
106
+ return `${timestamp} ${level} ${context}${entry.message}`;
107
+ }
108
+ }
109
+ exports.StreamOutput = StreamOutput;
110
+ //# sourceMappingURL=outputs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../../src/core/logger/outputs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import { CacheAdapter } from "../../../../../types/cache";
2
+ export declare class FileCacheAdapter implements CacheAdapter {
3
+ private cacheDir;
4
+ constructor(options?: {
5
+ cacheDir?: string;
6
+ });
7
+ private ensureCacheDir;
8
+ private getFilePath;
9
+ get(key: string): Promise<any>;
10
+ set(key: string, value: any, ttl?: number): Promise<void>;
11
+ del(key: string): Promise<void>;
12
+ clear(): Promise<void>;
13
+ exists(key: string): Promise<boolean>;
14
+ ttl(key: string): Promise<number>;
15
+ }
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.FileCacheAdapter = void 0;
37
+ const logger_1 = require("../../../../logger");
38
+ const logger = (0, logger_1.createFrameworkLogger)("FileCacheAdapter");
39
+ class FileCacheAdapter {
40
+ constructor(options = {}) {
41
+ this.cacheDir = options.cacheDir || "./cache";
42
+ this.ensureCacheDir();
43
+ }
44
+ async ensureCacheDir() {
45
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
46
+ try {
47
+ await fs.mkdir(this.cacheDir, { recursive: true });
48
+ }
49
+ catch (error) {
50
+ logger.error("Failed to create cache directory", "FileCache", { error });
51
+ }
52
+ }
53
+ getFilePath(key) {
54
+ const crypto = require("crypto");
55
+ const hash = crypto.createHash("md5").update(key).digest("hex");
56
+ return `${this.cacheDir}/${hash}.json`;
57
+ }
58
+ async get(key) {
59
+ try {
60
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
61
+ const filePath = this.getFilePath(key);
62
+ const data = await fs.readFile(filePath, "utf-8");
63
+ const parsed = JSON.parse(data);
64
+ if (Date.now() > parsed.expires) {
65
+ await this.del(key);
66
+ return null;
67
+ }
68
+ return parsed.value;
69
+ }
70
+ catch (error) {
71
+ return null;
72
+ }
73
+ }
74
+ async set(key, value, ttl = 3600) {
75
+ try {
76
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
77
+ const filePath = this.getFilePath(key);
78
+ const expires = Date.now() + ttl * 1000;
79
+ const data = JSON.stringify({ value, expires });
80
+ await fs.writeFile(filePath, data);
81
+ logger.debug(`Cached item to file: ${key} (TTL: ${ttl}s)`, "FileCache");
82
+ }
83
+ catch (error) {
84
+ logger.error("File cache set error", "FileCache", { key, error });
85
+ }
86
+ }
87
+ async del(key) {
88
+ try {
89
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
90
+ const filePath = this.getFilePath(key);
91
+ await fs.unlink(filePath);
92
+ logger.debug(`Deleted file cache item: ${key}`, "FileCache");
93
+ }
94
+ catch (error) {
95
+ // File might not exist, which is okay
96
+ }
97
+ }
98
+ async clear() {
99
+ try {
100
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
101
+ const files = await fs.readdir(this.cacheDir);
102
+ await Promise.all(files.map((file) => fs.unlink(`${this.cacheDir}/${file}`)));
103
+ logger.debug("Cleared all file cache items", "FileCache");
104
+ }
105
+ catch (error) {
106
+ logger.error("File cache clear error", "FileCache", { error });
107
+ }
108
+ }
109
+ async exists(key) {
110
+ const value = await this.get(key);
111
+ return value !== null;
112
+ }
113
+ async ttl(key) {
114
+ try {
115
+ const fs = await Promise.resolve().then(() => __importStar(require("fs/promises")));
116
+ const filePath = this.getFilePath(key);
117
+ const data = await fs.readFile(filePath, "utf-8");
118
+ const parsed = JSON.parse(data);
119
+ const remaining = Math.floor((parsed.expires - Date.now()) / 1000);
120
+ return remaining > 0 ? remaining : -1;
121
+ }
122
+ catch (error) {
123
+ return -1;
124
+ }
125
+ }
126
+ }
127
+ exports.FileCacheAdapter = FileCacheAdapter;
128
+ //# sourceMappingURL=file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.js","sourceRoot":"","sources":["../../../../../../src/core/middleware/built-in/adapters/cache/file.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export { MemoryCacheAdapter } from "./memory";
2
+ export { RedisCacheAdapter } from "./redis";
3
+ export { FileCacheAdapter } from "./file";
4
+ import { CacheAdapter } from "../../../../../types/cache";
5
+ export declare function createCacheAdapter(type: string, options?: any): CacheAdapter;