@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,292 @@
1
+ // Database MongoDB Adapter
2
+ import { DatabaseAdapter, DatabaseTransaction } from "../../../types/database";
3
+ import { createFrameworkLogger } from "../../logger";
4
+
5
+ interface MongoDBConfig {
6
+ url?: string;
7
+ host?: string;
8
+ port?: number;
9
+ username?: string;
10
+ password?: string;
11
+ database?: string;
12
+ authSource?: string;
13
+ ssl?: boolean;
14
+ replicaSet?: string;
15
+ maxPoolSize?: number;
16
+ minPoolSize?: number;
17
+ }
18
+
19
+ interface MongoDocument {
20
+ _id?: any;
21
+ [key: string]: any;
22
+ }
23
+
24
+ export class MongoDBAdapter implements DatabaseAdapter {
25
+ private client: any;
26
+ private db: any;
27
+ private logger = createFrameworkLogger("MongoDB");
28
+
29
+ constructor(config: MongoDBConfig) {
30
+ try {
31
+ const { MongoClient } = require("mongodb");
32
+
33
+ const url = config.url || this.buildConnectionString(config);
34
+
35
+ this.client = new MongoClient(url, {
36
+ maxPoolSize: config.maxPoolSize || 10,
37
+ minPoolSize: config.minPoolSize || 0,
38
+ ssl: config.ssl || false,
39
+ });
40
+
41
+ this.db = this.client.db(config.database || "moro_app");
42
+
43
+ this.logger.info("MongoDB adapter initialized", "MongoDB");
44
+ } catch (error) {
45
+ throw new Error(
46
+ "mongodb package is required for MongoDB adapter. Install it with: npm install mongodb",
47
+ );
48
+ }
49
+ }
50
+
51
+ private buildConnectionString(config: MongoDBConfig): string {
52
+ const host = config.host || "localhost";
53
+ const port = config.port || 27017;
54
+ const auth =
55
+ config.username && config.password
56
+ ? `${config.username}:${config.password}@`
57
+ : "";
58
+ const authSource = config.authSource
59
+ ? `?authSource=${config.authSource}`
60
+ : "";
61
+
62
+ return `mongodb://${auth}${host}:${port}/${config.database || "moro_app"}${authSource}`;
63
+ }
64
+
65
+ async connect(): Promise<void> {
66
+ try {
67
+ await this.client.connect();
68
+ await this.client.db("admin").command({ ping: 1 });
69
+ this.logger.info("MongoDB connection established", "Connection");
70
+ } catch (error) {
71
+ this.logger.error("MongoDB connection failed", "Connection", {
72
+ error: error instanceof Error ? error.message : String(error),
73
+ });
74
+ throw error;
75
+ }
76
+ }
77
+
78
+ async disconnect(): Promise<void> {
79
+ await this.client.close();
80
+ }
81
+
82
+ // For MongoDB, we'll treat "sql" as collection name and "params" as query/pipeline
83
+ async query<T = any>(collection: string, pipeline?: any[]): Promise<T[]> {
84
+ try {
85
+ const coll = this.db.collection(collection);
86
+
87
+ if (pipeline && Array.isArray(pipeline)) {
88
+ // Aggregation pipeline
89
+ const cursor = coll.aggregate(pipeline);
90
+ return await cursor.toArray();
91
+ } else if (pipeline) {
92
+ // Find query
93
+ const cursor = coll.find(pipeline);
94
+ return await cursor.toArray();
95
+ } else {
96
+ // Find all
97
+ const cursor = coll.find({});
98
+ return await cursor.toArray();
99
+ }
100
+ } catch (error) {
101
+ this.logger.error("MongoDB query failed", "Query", {
102
+ collection,
103
+ error: error instanceof Error ? error.message : String(error),
104
+ });
105
+ throw error;
106
+ }
107
+ }
108
+
109
+ async queryOne<T = any>(collection: string, query?: any): Promise<T | null> {
110
+ try {
111
+ const coll = this.db.collection(collection);
112
+ return await coll.findOne(query || {});
113
+ } catch (error) {
114
+ this.logger.error("MongoDB queryOne failed", "Query", {
115
+ collection,
116
+ error: error instanceof Error ? error.message : String(error),
117
+ });
118
+ throw error;
119
+ }
120
+ }
121
+
122
+ async insert<T = any>(
123
+ collection: string,
124
+ data: Record<string, any>,
125
+ ): Promise<T> {
126
+ try {
127
+ const coll = this.db.collection(collection);
128
+ const result = await coll.insertOne(data);
129
+
130
+ // Return the inserted document with _id
131
+ return { ...data, _id: result.insertedId } as T;
132
+ } catch (error) {
133
+ this.logger.error("MongoDB insert failed", "Insert", {
134
+ collection,
135
+ error: error instanceof Error ? error.message : String(error),
136
+ });
137
+ throw error;
138
+ }
139
+ }
140
+
141
+ async update<T = any>(
142
+ collection: string,
143
+ data: Record<string, any>,
144
+ where: Record<string, any>,
145
+ ): Promise<T> {
146
+ try {
147
+ const coll = this.db.collection(collection);
148
+ const result = await coll.findOneAndUpdate(
149
+ where,
150
+ { $set: data },
151
+ { returnDocument: "after" },
152
+ );
153
+
154
+ return result.value as T;
155
+ } catch (error) {
156
+ this.logger.error("MongoDB update failed", "Update", {
157
+ collection,
158
+ error: error instanceof Error ? error.message : String(error),
159
+ });
160
+ throw error;
161
+ }
162
+ }
163
+
164
+ async delete(
165
+ collection: string,
166
+ where: Record<string, any>,
167
+ ): Promise<number> {
168
+ try {
169
+ const coll = this.db.collection(collection);
170
+ const result = await coll.deleteMany(where);
171
+ return result.deletedCount || 0;
172
+ } catch (error) {
173
+ this.logger.error("MongoDB delete failed", "Delete", {
174
+ collection,
175
+ error: error instanceof Error ? error.message : String(error),
176
+ });
177
+ throw error;
178
+ }
179
+ }
180
+
181
+ async transaction<T>(
182
+ callback: (tx: DatabaseTransaction) => Promise<T>,
183
+ ): Promise<T> {
184
+ const session = this.client.startSession();
185
+
186
+ try {
187
+ return await session.withTransaction(async () => {
188
+ const transaction = new MongoDBTransaction(this.db, session);
189
+ return await callback(transaction);
190
+ });
191
+ } finally {
192
+ await session.endSession();
193
+ }
194
+ }
195
+
196
+ // MongoDB-specific methods
197
+ async aggregate<T = any>(collection: string, pipeline: any[]): Promise<T[]> {
198
+ const coll = this.db.collection(collection);
199
+ const cursor = coll.aggregate(pipeline);
200
+ return await cursor.toArray();
201
+ }
202
+
203
+ async createIndex(
204
+ collection: string,
205
+ index: any,
206
+ options?: any,
207
+ ): Promise<string> {
208
+ const coll = this.db.collection(collection);
209
+ return await coll.createIndex(index, options);
210
+ }
211
+
212
+ async dropIndex(collection: string, indexName: string): Promise<any> {
213
+ const coll = this.db.collection(collection);
214
+ return await coll.dropIndex(indexName);
215
+ }
216
+
217
+ async count(collection: string, query?: any): Promise<number> {
218
+ const coll = this.db.collection(collection);
219
+ return await coll.countDocuments(query || {});
220
+ }
221
+
222
+ getCollection(name: string) {
223
+ return this.db.collection(name);
224
+ }
225
+ }
226
+
227
+ class MongoDBTransaction implements DatabaseTransaction {
228
+ constructor(
229
+ private db: any,
230
+ private session: any,
231
+ ) {}
232
+
233
+ async query<T = any>(collection: string, pipeline?: any[]): Promise<T[]> {
234
+ const coll = this.db.collection(collection);
235
+
236
+ if (pipeline && Array.isArray(pipeline)) {
237
+ const cursor = coll.aggregate(pipeline, { session: this.session });
238
+ return await cursor.toArray();
239
+ } else if (pipeline) {
240
+ const cursor = coll.find(pipeline, { session: this.session });
241
+ return await cursor.toArray();
242
+ } else {
243
+ const cursor = coll.find({}, { session: this.session });
244
+ return await cursor.toArray();
245
+ }
246
+ }
247
+
248
+ async queryOne<T = any>(collection: string, query?: any): Promise<T | null> {
249
+ const coll = this.db.collection(collection);
250
+ return await coll.findOne(query || {}, { session: this.session });
251
+ }
252
+
253
+ async insert<T = any>(
254
+ collection: string,
255
+ data: Record<string, any>,
256
+ ): Promise<T> {
257
+ const coll = this.db.collection(collection);
258
+ const result = await coll.insertOne(data, { session: this.session });
259
+ return { ...data, _id: result.insertedId } as T;
260
+ }
261
+
262
+ async update<T = any>(
263
+ collection: string,
264
+ data: Record<string, any>,
265
+ where: Record<string, any>,
266
+ ): Promise<T> {
267
+ const coll = this.db.collection(collection);
268
+ const result = await coll.findOneAndUpdate(
269
+ where,
270
+ { $set: data },
271
+ { returnDocument: "after", session: this.session },
272
+ );
273
+ return result.value as T;
274
+ }
275
+
276
+ async delete(
277
+ collection: string,
278
+ where: Record<string, any>,
279
+ ): Promise<number> {
280
+ const coll = this.db.collection(collection);
281
+ const result = await coll.deleteMany(where, { session: this.session });
282
+ return result.deletedCount || 0;
283
+ }
284
+
285
+ async commit(): Promise<void> {
286
+ await this.session.commitTransaction();
287
+ }
288
+
289
+ async rollback(): Promise<void> {
290
+ await this.session.abortTransaction();
291
+ }
292
+ }
@@ -0,0 +1,217 @@
1
+ // Database MySQL Adapter
2
+ import { DatabaseAdapter, DatabaseTransaction } from "../../../types/database";
3
+ import { createFrameworkLogger } from "../../logger";
4
+
5
+ interface MySQLConfig {
6
+ host?: string;
7
+ port?: number;
8
+ user?: string;
9
+ password?: string;
10
+ database?: string;
11
+ connectionLimit?: number;
12
+ }
13
+
14
+ export class MySQLAdapter implements DatabaseAdapter {
15
+ private pool: any;
16
+ private logger = createFrameworkLogger("MySQL");
17
+
18
+ constructor(config: MySQLConfig) {
19
+ try {
20
+ const mysql = require("mysql2/promise");
21
+ this.pool = mysql.createPool({
22
+ host: config.host || "localhost",
23
+ port: config.port || 3306,
24
+ user: config.user || "root",
25
+ password: config.password || "",
26
+ database: config.database || "moro_app",
27
+ waitForConnections: true,
28
+ connectionLimit: config.connectionLimit || 10,
29
+ queueLimit: 0,
30
+ });
31
+ } catch (error) {
32
+ throw new Error(
33
+ "mysql2 package is required for MySQL adapter. Install it with: npm install mysql2",
34
+ );
35
+ }
36
+ }
37
+
38
+ async connect(): Promise<void> {
39
+ try {
40
+ const connection = await this.pool.getConnection();
41
+ connection.release();
42
+ this.logger.info("MySQL connection established", "Connection");
43
+ } catch (error) {
44
+ this.logger.error("MySQL connection failed", "Connection", {
45
+ error: error instanceof Error ? error.message : String(error),
46
+ });
47
+ throw error;
48
+ }
49
+ }
50
+
51
+ async disconnect(): Promise<void> {
52
+ await this.pool.end();
53
+ }
54
+
55
+ async query<T = any>(sql: string, params?: any[]): Promise<T[]> {
56
+ const [rows] = await this.pool.execute(sql, params);
57
+ return rows as T[];
58
+ }
59
+
60
+ async queryOne<T = any>(sql: string, params?: any[]): Promise<T | null> {
61
+ const results = await this.query<T>(sql, params);
62
+ return results.length > 0 ? results[0] : null;
63
+ }
64
+
65
+ async insert<T = any>(table: string, data: Record<string, any>): Promise<T> {
66
+ const keys = Object.keys(data);
67
+ const values = Object.values(data);
68
+ const placeholders = keys.map(() => "?").join(", ");
69
+
70
+ const sql = `INSERT INTO ${table} (${keys.join(", ")}) VALUES (${placeholders})`;
71
+ const [result] = (await this.pool.execute(sql, values)) as any;
72
+
73
+ // Return the inserted record
74
+ const insertedRecord = await this.queryOne<T>(
75
+ `SELECT * FROM ${table} WHERE id = ?`,
76
+ [result.insertId],
77
+ );
78
+
79
+ return insertedRecord!;
80
+ }
81
+
82
+ async update<T = any>(
83
+ table: string,
84
+ data: Record<string, any>,
85
+ where: Record<string, any>,
86
+ ): Promise<T> {
87
+ const setClause = Object.keys(data)
88
+ .map((key) => `${key} = ?`)
89
+ .join(", ");
90
+ const whereClause = Object.keys(where)
91
+ .map((key) => `${key} = ?`)
92
+ .join(" AND ");
93
+
94
+ const sql = `UPDATE ${table} SET ${setClause} WHERE ${whereClause}`;
95
+ const params = [...Object.values(data), ...Object.values(where)];
96
+
97
+ await this.pool.execute(sql, params);
98
+
99
+ // Return the updated record
100
+ const updatedRecord = await this.queryOne<T>(
101
+ `SELECT * FROM ${table} WHERE ${whereClause}`,
102
+ Object.values(where),
103
+ );
104
+
105
+ return updatedRecord!;
106
+ }
107
+
108
+ async delete(table: string, where: Record<string, any>): Promise<number> {
109
+ const whereClause = Object.keys(where)
110
+ .map((key) => `${key} = ?`)
111
+ .join(" AND ");
112
+ const sql = `DELETE FROM ${table} WHERE ${whereClause}`;
113
+
114
+ const [result] = (await this.pool.execute(
115
+ sql,
116
+ Object.values(where),
117
+ )) as any;
118
+ return result.affectedRows;
119
+ }
120
+
121
+ async transaction<T>(
122
+ callback: (tx: DatabaseTransaction) => Promise<T>,
123
+ ): Promise<T> {
124
+ const connection = await this.pool.getConnection();
125
+
126
+ try {
127
+ await connection.beginTransaction();
128
+
129
+ const transaction = new MySQLTransaction(connection);
130
+ const result = await callback(transaction);
131
+
132
+ await connection.commit();
133
+ return result;
134
+ } catch (error) {
135
+ await connection.rollback();
136
+ throw error;
137
+ } finally {
138
+ connection.release();
139
+ }
140
+ }
141
+ }
142
+
143
+ class MySQLTransaction implements DatabaseTransaction {
144
+ constructor(private connection: any) {}
145
+
146
+ async query<T = any>(sql: string, params?: any[]): Promise<T[]> {
147
+ const [rows] = await this.connection.execute(sql, params);
148
+ return rows as T[];
149
+ }
150
+
151
+ async queryOne<T = any>(sql: string, params?: any[]): Promise<T | null> {
152
+ const results = await this.query<T>(sql, params);
153
+ return results.length > 0 ? results[0] : null;
154
+ }
155
+
156
+ async insert<T = any>(table: string, data: Record<string, any>): Promise<T> {
157
+ const keys = Object.keys(data);
158
+ const values = Object.values(data);
159
+ const placeholders = keys.map(() => "?").join(", ");
160
+
161
+ const sql = `INSERT INTO ${table} (${keys.join(", ")}) VALUES (${placeholders})`;
162
+ const [result] = (await this.connection.execute(sql, values)) as any;
163
+
164
+ const insertedRecord = await this.queryOne<T>(
165
+ `SELECT * FROM ${table} WHERE id = ?`,
166
+ [result.insertId],
167
+ );
168
+
169
+ return insertedRecord!;
170
+ }
171
+
172
+ async update<T = any>(
173
+ table: string,
174
+ data: Record<string, any>,
175
+ where: Record<string, any>,
176
+ ): Promise<T> {
177
+ const setClause = Object.keys(data)
178
+ .map((key) => `${key} = ?`)
179
+ .join(", ");
180
+ const whereClause = Object.keys(where)
181
+ .map((key) => `${key} = ?`)
182
+ .join(" AND ");
183
+
184
+ const sql = `UPDATE ${table} SET ${setClause} WHERE ${whereClause}`;
185
+ const params = [...Object.values(data), ...Object.values(where)];
186
+
187
+ await this.connection.execute(sql, params);
188
+
189
+ const updatedRecord = await this.queryOne<T>(
190
+ `SELECT * FROM ${table} WHERE ${whereClause}`,
191
+ Object.values(where),
192
+ );
193
+
194
+ return updatedRecord!;
195
+ }
196
+
197
+ async delete(table: string, where: Record<string, any>): Promise<number> {
198
+ const whereClause = Object.keys(where)
199
+ .map((key) => `${key} = ?`)
200
+ .join(" AND ");
201
+ const sql = `DELETE FROM ${table} WHERE ${whereClause}`;
202
+
203
+ const [result] = (await this.connection.execute(
204
+ sql,
205
+ Object.values(where),
206
+ )) as any;
207
+ return result.affectedRows;
208
+ }
209
+
210
+ async commit(): Promise<void> {
211
+ await this.connection.commit();
212
+ }
213
+
214
+ async rollback(): Promise<void> {
215
+ await this.connection.rollback();
216
+ }
217
+ }
@@ -0,0 +1,211 @@
1
+ // Database PostgreSQL Adapter
2
+ import { DatabaseAdapter, DatabaseTransaction } from "../../../types/database";
3
+ import { createFrameworkLogger } from "../../logger";
4
+
5
+ interface PostgreSQLConfig {
6
+ host?: string;
7
+ port?: number;
8
+ user?: string;
9
+ password?: string;
10
+ database?: string;
11
+ connectionLimit?: number;
12
+ ssl?: boolean;
13
+ }
14
+
15
+ export class PostgreSQLAdapter implements DatabaseAdapter {
16
+ private pool: any;
17
+ private logger = createFrameworkLogger("PostgreSQL");
18
+
19
+ constructor(config: PostgreSQLConfig) {
20
+ try {
21
+ const { Pool } = require("pg");
22
+ this.pool = new Pool({
23
+ host: config.host || "localhost",
24
+ port: config.port || 5432,
25
+ user: config.user || "postgres",
26
+ password: config.password || "",
27
+ database: config.database || "moro_app",
28
+ max: config.connectionLimit || 10,
29
+ ssl: config.ssl || false,
30
+ });
31
+
32
+ this.pool.on("error", (err: Error) => {
33
+ this.logger.error("PostgreSQL pool error", "Pool", {
34
+ error: err.message,
35
+ });
36
+ });
37
+
38
+ this.logger.info("PostgreSQL adapter initialized", "PostgreSQL");
39
+ } catch (error) {
40
+ throw new Error(
41
+ "pg package is required for PostgreSQL adapter. Install it with: npm install pg",
42
+ );
43
+ }
44
+ }
45
+
46
+ async connect(): Promise<void> {
47
+ try {
48
+ const client = await this.pool.connect();
49
+ client.release();
50
+ this.logger.info("PostgreSQL connection established", "Connection");
51
+ } catch (error) {
52
+ this.logger.error("PostgreSQL connection failed", "Connection", {
53
+ error: error instanceof Error ? error.message : String(error),
54
+ });
55
+ throw error;
56
+ }
57
+ }
58
+
59
+ async disconnect(): Promise<void> {
60
+ await this.pool.end();
61
+ }
62
+
63
+ async query<T = any>(sql: string, params?: any[]): Promise<T[]> {
64
+ const result = await this.pool.query(sql, params);
65
+ return result.rows as T[];
66
+ }
67
+
68
+ async queryOne<T = any>(sql: string, params?: any[]): Promise<T | null> {
69
+ const results = await this.query<T>(sql, params);
70
+ return results.length > 0 ? results[0] : null;
71
+ }
72
+
73
+ async insert<T = any>(table: string, data: Record<string, any>): Promise<T> {
74
+ const keys = Object.keys(data);
75
+ const values = Object.values(data);
76
+ const placeholders = keys.map((_, index) => `$${index + 1}`).join(", ");
77
+
78
+ const sql = `INSERT INTO ${table} (${keys.join(", ")}) VALUES (${placeholders}) RETURNING *`;
79
+ const result = await this.pool.query(sql, values);
80
+
81
+ return result.rows[0] as T;
82
+ }
83
+
84
+ async update<T = any>(
85
+ table: string,
86
+ data: Record<string, any>,
87
+ where: Record<string, any>,
88
+ ): Promise<T> {
89
+ const dataKeys = Object.keys(data);
90
+ const dataValues = Object.values(data);
91
+ const whereKeys = Object.keys(where);
92
+ const whereValues = Object.values(where);
93
+
94
+ const setClause = dataKeys
95
+ .map((key, index) => `${key} = $${index + 1}`)
96
+ .join(", ");
97
+ const whereClause = whereKeys
98
+ .map((key, index) => `${key} = $${dataKeys.length + index + 1}`)
99
+ .join(" AND ");
100
+
101
+ const sql = `UPDATE ${table} SET ${setClause} WHERE ${whereClause} RETURNING *`;
102
+ const params = [...dataValues, ...whereValues];
103
+
104
+ const result = await this.pool.query(sql, params);
105
+ return result.rows[0] as T;
106
+ }
107
+
108
+ async delete(table: string, where: Record<string, any>): Promise<number> {
109
+ const whereKeys = Object.keys(where);
110
+ const whereValues = Object.values(where);
111
+ const whereClause = whereKeys
112
+ .map((key, index) => `${key} = $${index + 1}`)
113
+ .join(" AND ");
114
+
115
+ const sql = `DELETE FROM ${table} WHERE ${whereClause}`;
116
+ const result = await this.pool.query(sql, whereValues);
117
+
118
+ return result.rowCount || 0;
119
+ }
120
+
121
+ async transaction<T>(
122
+ callback: (tx: DatabaseTransaction) => Promise<T>,
123
+ ): Promise<T> {
124
+ const client = await this.pool.connect();
125
+
126
+ try {
127
+ await client.query("BEGIN");
128
+
129
+ const transaction = new PostgreSQLTransaction(client);
130
+ const result = await callback(transaction);
131
+
132
+ await client.query("COMMIT");
133
+ return result;
134
+ } catch (error) {
135
+ await client.query("ROLLBACK");
136
+ throw error;
137
+ } finally {
138
+ client.release();
139
+ }
140
+ }
141
+ }
142
+
143
+ class PostgreSQLTransaction implements DatabaseTransaction {
144
+ constructor(private client: any) {}
145
+
146
+ async query<T = any>(sql: string, params?: any[]): Promise<T[]> {
147
+ const result = await this.client.query(sql, params);
148
+ return result.rows as T[];
149
+ }
150
+
151
+ async queryOne<T = any>(sql: string, params?: any[]): Promise<T | null> {
152
+ const results = await this.query<T>(sql, params);
153
+ return results.length > 0 ? results[0] : null;
154
+ }
155
+
156
+ async insert<T = any>(table: string, data: Record<string, any>): Promise<T> {
157
+ const keys = Object.keys(data);
158
+ const values = Object.values(data);
159
+ const placeholders = keys.map((_, index) => `$${index + 1}`).join(", ");
160
+
161
+ const sql = `INSERT INTO ${table} (${keys.join(", ")}) VALUES (${placeholders}) RETURNING *`;
162
+ const result = await this.client.query(sql, values);
163
+
164
+ return result.rows[0] as T;
165
+ }
166
+
167
+ async update<T = any>(
168
+ table: string,
169
+ data: Record<string, any>,
170
+ where: Record<string, any>,
171
+ ): Promise<T> {
172
+ const dataKeys = Object.keys(data);
173
+ const dataValues = Object.values(data);
174
+ const whereKeys = Object.keys(where);
175
+ const whereValues = Object.values(where);
176
+
177
+ const setClause = dataKeys
178
+ .map((key, index) => `${key} = $${index + 1}`)
179
+ .join(", ");
180
+ const whereClause = whereKeys
181
+ .map((key, index) => `${key} = $${dataKeys.length + index + 1}`)
182
+ .join(" AND ");
183
+
184
+ const sql = `UPDATE ${table} SET ${setClause} WHERE ${whereClause} RETURNING *`;
185
+ const params = [...dataValues, ...whereValues];
186
+
187
+ const result = await this.client.query(sql, params);
188
+ return result.rows[0] as T;
189
+ }
190
+
191
+ async delete(table: string, where: Record<string, any>): Promise<number> {
192
+ const whereKeys = Object.keys(where);
193
+ const whereValues = Object.values(where);
194
+ const whereClause = whereKeys
195
+ .map((key, index) => `${key} = $${index + 1}`)
196
+ .join(" AND ");
197
+
198
+ const sql = `DELETE FROM ${table} WHERE ${whereClause}`;
199
+ const result = await this.client.query(sql, whereValues);
200
+
201
+ return result.rowCount || 0;
202
+ }
203
+
204
+ async commit(): Promise<void> {
205
+ await this.client.query("COMMIT");
206
+ }
207
+
208
+ async rollback(): Promise<void> {
209
+ await this.client.query("ROLLBACK");
210
+ }
211
+ }