@adaas/a-server 0.0.21 → 0.0.23

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 (518) hide show
  1. package/.conf/tsconfig.base.json +79 -0
  2. package/.conf/tsconfig.browser.json +32 -0
  3. package/.conf/tsconfig.node.json +33 -0
  4. package/LICENSE +10 -19
  5. package/dist/browser/index.d.mts +1669 -0
  6. package/dist/browser/index.mjs +2869 -0
  7. package/dist/browser/index.mjs.map +1 -0
  8. package/dist/node/A-Request.entity-8_9MCXT2.d.ts +533 -0
  9. package/dist/node/A-Request.entity-r905O60G.d.mts +533 -0
  10. package/dist/node/A-Response.entity-BVYAc6-8.d.mts +318 -0
  11. package/dist/node/A-Response.entity-CRc-t-vr.d.ts +318 -0
  12. package/dist/node/channels/A-Http/A-Http.channel.constants.d.mts +9 -0
  13. package/dist/node/channels/A-Http/A-Http.channel.constants.d.ts +9 -0
  14. package/dist/node/channels/A-Http/A-Http.channel.constants.js +13 -0
  15. package/dist/node/channels/A-Http/A-Http.channel.constants.js.map +1 -0
  16. package/dist/node/channels/A-Http/A-Http.channel.constants.mjs +12 -0
  17. package/dist/node/channels/A-Http/A-Http.channel.constants.mjs.map +1 -0
  18. package/dist/node/channels/A-Http/A-Http.channel.d.mts +23 -0
  19. package/dist/node/channels/A-Http/A-Http.channel.d.ts +23 -0
  20. package/dist/node/channels/A-Http/A-Http.channel.error.d.mts +7 -0
  21. package/dist/node/channels/A-Http/A-Http.channel.error.d.ts +7 -0
  22. package/dist/node/channels/A-Http/A-Http.channel.error.js +11 -0
  23. package/dist/node/channels/A-Http/A-Http.channel.error.js.map +1 -0
  24. package/dist/node/channels/A-Http/A-Http.channel.error.mjs +10 -0
  25. package/dist/node/channels/A-Http/A-Http.channel.error.mjs.map +1 -0
  26. package/dist/node/channels/A-Http/A-Http.channel.js +122 -0
  27. package/dist/node/channels/A-Http/A-Http.channel.js.map +1 -0
  28. package/dist/node/channels/A-Http/A-Http.channel.mjs +110 -0
  29. package/dist/node/channels/A-Http/A-Http.channel.mjs.map +1 -0
  30. package/dist/node/channels/A-Http/A-Http.channel.types.d.mts +67 -0
  31. package/dist/node/channels/A-Http/A-Http.channel.types.d.ts +67 -0
  32. package/dist/node/channels/A-Http/A-Http.channel.types.js +4 -0
  33. package/dist/node/channels/A-Http/A-Http.channel.types.js.map +1 -0
  34. package/dist/node/channels/A-Http/A-Http.channel.types.mjs +3 -0
  35. package/dist/node/channels/A-Http/A-Http.channel.types.mjs.map +1 -0
  36. package/dist/node/channels/A-Websockets/A-Websockets.channel.d.mts +7 -0
  37. package/dist/node/channels/A-Websockets/A-Websockets.channel.d.ts +7 -0
  38. package/dist/node/channels/A-Websockets/A-Websockets.channel.js +13 -0
  39. package/dist/node/channels/A-Websockets/A-Websockets.channel.js.map +1 -0
  40. package/dist/node/channels/A-Websockets/A-Websockets.channel.mjs +12 -0
  41. package/dist/node/channels/A-Websockets/A-Websockets.channel.mjs.map +1 -0
  42. package/dist/node/chunk-EQQGB2QZ.mjs +15 -0
  43. package/dist/node/chunk-EQQGB2QZ.mjs.map +1 -0
  44. package/dist/node/constants/env.constants.d.mts +12 -0
  45. package/dist/node/constants/env.constants.d.ts +12 -0
  46. package/dist/node/constants/env.constants.js +23 -0
  47. package/dist/node/constants/env.constants.js.map +1 -0
  48. package/dist/node/constants/env.constants.mjs +22 -0
  49. package/dist/node/constants/env.constants.mjs.map +1 -0
  50. package/dist/node/controllers/A-CommandController/A-CommandController.component.d.mts +29 -0
  51. package/dist/node/controllers/A-CommandController/A-CommandController.component.d.ts +29 -0
  52. package/dist/node/controllers/A-CommandController/A-CommandController.component.js +55 -0
  53. package/dist/node/controllers/A-CommandController/A-CommandController.component.js.map +1 -0
  54. package/dist/node/controllers/A-CommandController/A-CommandController.component.mjs +43 -0
  55. package/dist/node/controllers/A-CommandController/A-CommandController.component.mjs.map +1 -0
  56. package/dist/node/controllers/A-EntityController/A-EntityController.component.d.mts +44 -0
  57. package/dist/node/controllers/A-EntityController/A-EntityController.component.d.ts +44 -0
  58. package/dist/node/controllers/A-EntityController/A-EntityController.component.js +189 -0
  59. package/dist/node/controllers/A-EntityController/A-EntityController.component.js.map +1 -0
  60. package/dist/node/controllers/A-EntityController/A-EntityController.component.mjs +177 -0
  61. package/dist/node/controllers/A-EntityController/A-EntityController.component.mjs.map +1 -0
  62. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.d.mts +2 -0
  63. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.d.ts +2 -0
  64. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.js +4 -0
  65. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.js.map +1 -0
  66. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.mjs +3 -0
  67. package/dist/node/controllers/A-EntityController/A-EntityController.component.types.mjs.map +1 -0
  68. package/dist/node/controllers/A-ListingController/A-ListingController.component.d.mts +28 -0
  69. package/dist/node/controllers/A-ListingController/A-ListingController.component.d.ts +28 -0
  70. package/dist/node/controllers/A-ListingController/A-ListingController.component.js +59 -0
  71. package/dist/node/controllers/A-ListingController/A-ListingController.component.js.map +1 -0
  72. package/dist/node/controllers/A-ListingController/A-ListingController.component.mjs +47 -0
  73. package/dist/node/controllers/A-ListingController/A-ListingController.component.mjs.map +1 -0
  74. package/dist/node/controllers/A-ListingController/A-ListingController.types.d.mts +2 -0
  75. package/dist/node/controllers/A-ListingController/A-ListingController.types.d.ts +2 -0
  76. package/dist/node/controllers/A-ListingController/A-ListingController.types.js +4 -0
  77. package/dist/node/controllers/A-ListingController/A-ListingController.types.js.map +1 -0
  78. package/dist/node/controllers/A-ListingController/A-ListingController.types.mjs +3 -0
  79. package/dist/node/controllers/A-ListingController/A-ListingController.types.mjs.map +1 -0
  80. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.d.mts +30 -0
  81. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.d.ts +30 -0
  82. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.js +46 -0
  83. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.js.map +1 -0
  84. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.mjs +34 -0
  85. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.component.mjs.map +1 -0
  86. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.d.mts +2 -0
  87. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.d.ts +2 -0
  88. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.js +4 -0
  89. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.js.map +1 -0
  90. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.mjs +3 -0
  91. package/dist/node/controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.mjs.map +1 -0
  92. package/dist/node/index.d.mts +51 -0
  93. package/dist/node/index.d.ts +51 -0
  94. package/dist/node/index.js +320 -0
  95. package/dist/node/index.js.map +1 -0
  96. package/dist/node/index.mjs +48 -0
  97. package/dist/node/index.mjs.map +1 -0
  98. package/dist/node/lib/A-Request/A-HttpRequestData.context.d.mts +12 -0
  99. package/dist/node/lib/A-Request/A-HttpRequestData.context.d.ts +12 -0
  100. package/dist/node/lib/A-Request/A-HttpRequestData.context.js +25 -0
  101. package/dist/node/lib/A-Request/A-HttpRequestData.context.js.map +1 -0
  102. package/dist/node/lib/A-Request/A-HttpRequestData.context.mjs +24 -0
  103. package/dist/node/lib/A-Request/A-HttpRequestData.context.mjs.map +1 -0
  104. package/dist/node/lib/A-Request/A-HttpServerRequest.context.d.mts +39 -0
  105. package/dist/node/lib/A-Request/A-HttpServerRequest.context.d.ts +39 -0
  106. package/dist/node/lib/A-Request/A-HttpServerRequest.context.js +56 -0
  107. package/dist/node/lib/A-Request/A-HttpServerRequest.context.js.map +1 -0
  108. package/dist/node/lib/A-Request/A-HttpServerRequest.context.mjs +55 -0
  109. package/dist/node/lib/A-Request/A-HttpServerRequest.context.mjs.map +1 -0
  110. package/dist/node/lib/A-Request/A-Request.constants.d.mts +18 -0
  111. package/dist/node/lib/A-Request/A-Request.constants.d.ts +18 -0
  112. package/dist/node/lib/A-Request/A-Request.constants.js +22 -0
  113. package/dist/node/lib/A-Request/A-Request.constants.js.map +1 -0
  114. package/dist/node/lib/A-Request/A-Request.constants.mjs +22 -0
  115. package/dist/node/lib/A-Request/A-Request.constants.mjs.map +1 -0
  116. package/dist/node/lib/A-Request/A-Request.entity.d.mts +17 -0
  117. package/dist/node/lib/A-Request/A-Request.entity.d.ts +17 -0
  118. package/dist/node/lib/A-Request/A-Request.entity.js +651 -0
  119. package/dist/node/lib/A-Request/A-Request.entity.js.map +1 -0
  120. package/dist/node/lib/A-Request/A-Request.entity.mjs +639 -0
  121. package/dist/node/lib/A-Request/A-Request.entity.mjs.map +1 -0
  122. package/dist/node/lib/A-Request/A-Request.env.d.mts +37 -0
  123. package/dist/node/lib/A-Request/A-Request.env.d.ts +37 -0
  124. package/dist/node/lib/A-Request/A-Request.env.js +39 -0
  125. package/dist/node/lib/A-Request/A-Request.env.js.map +1 -0
  126. package/dist/node/lib/A-Request/A-Request.env.mjs +38 -0
  127. package/dist/node/lib/A-Request/A-Request.env.mjs.map +1 -0
  128. package/dist/node/lib/A-Request/A-Request.error.d.mts +11 -0
  129. package/dist/node/lib/A-Request/A-Request.error.d.ts +11 -0
  130. package/dist/node/lib/A-Request/A-Request.error.js +15 -0
  131. package/dist/node/lib/A-Request/A-Request.error.js.map +1 -0
  132. package/dist/node/lib/A-Request/A-Request.error.mjs +14 -0
  133. package/dist/node/lib/A-Request/A-Request.error.mjs.map +1 -0
  134. package/dist/node/lib/A-Request/A-Request.helper.d.mts +105 -0
  135. package/dist/node/lib/A-Request/A-Request.helper.d.ts +105 -0
  136. package/dist/node/lib/A-Request/A-Request.helper.js +181 -0
  137. package/dist/node/lib/A-Request/A-Request.helper.js.map +1 -0
  138. package/dist/node/lib/A-Request/A-Request.helper.mjs +180 -0
  139. package/dist/node/lib/A-Request/A-Request.helper.mjs.map +1 -0
  140. package/dist/node/lib/A-Request/A-Request.types.d.mts +17 -0
  141. package/dist/node/lib/A-Request/A-Request.types.d.ts +17 -0
  142. package/dist/node/lib/A-Request/A-Request.types.js +14 -0
  143. package/dist/node/lib/A-Request/A-Request.types.js.map +1 -0
  144. package/dist/node/lib/A-Request/A-Request.types.mjs +14 -0
  145. package/dist/node/lib/A-Request/A-Request.types.mjs.map +1 -0
  146. package/dist/node/lib/A-Response/A-Response.constants.d.mts +24 -0
  147. package/dist/node/lib/A-Response/A-Response.constants.d.ts +24 -0
  148. package/dist/node/lib/A-Response/A-Response.constants.js +28 -0
  149. package/dist/node/lib/A-Response/A-Response.constants.js.map +1 -0
  150. package/dist/node/lib/A-Response/A-Response.constants.mjs +28 -0
  151. package/dist/node/lib/A-Response/A-Response.constants.mjs.map +1 -0
  152. package/dist/node/lib/A-Response/A-Response.entity.d.mts +20 -0
  153. package/dist/node/lib/A-Response/A-Response.entity.d.ts +20 -0
  154. package/dist/node/lib/A-Response/A-Response.entity.js +544 -0
  155. package/dist/node/lib/A-Response/A-Response.entity.js.map +1 -0
  156. package/dist/node/lib/A-Response/A-Response.entity.mjs +532 -0
  157. package/dist/node/lib/A-Response/A-Response.entity.mjs.map +1 -0
  158. package/dist/node/lib/A-Response/A-Response.env.d.mts +2 -0
  159. package/dist/node/lib/A-Response/A-Response.env.d.ts +2 -0
  160. package/dist/node/lib/A-Response/A-Response.env.js +4 -0
  161. package/dist/node/lib/A-Response/A-Response.env.js.map +1 -0
  162. package/dist/node/lib/A-Response/A-Response.env.mjs +3 -0
  163. package/dist/node/lib/A-Response/A-Response.env.mjs.map +1 -0
  164. package/dist/node/lib/A-Response/A-Response.error.d.mts +6 -0
  165. package/dist/node/lib/A-Response/A-Response.error.d.ts +6 -0
  166. package/dist/node/lib/A-Response/A-Response.error.js +10 -0
  167. package/dist/node/lib/A-Response/A-Response.error.js.map +1 -0
  168. package/dist/node/lib/A-Response/A-Response.error.mjs +9 -0
  169. package/dist/node/lib/A-Response/A-Response.error.mjs.map +1 -0
  170. package/dist/node/lib/A-Response/A-Response.types.d.mts +20 -0
  171. package/dist/node/lib/A-Response/A-Response.types.d.ts +20 -0
  172. package/dist/node/lib/A-Response/A-Response.types.js +4 -0
  173. package/dist/node/lib/A-Response/A-Response.types.js.map +1 -0
  174. package/dist/node/lib/A-Response/A-Response.types.mjs +3 -0
  175. package/dist/node/lib/A-Response/A-Response.types.mjs.map +1 -0
  176. package/dist/node/lib/A-Server/A-HttpServer.constants.d.mts +7 -0
  177. package/dist/node/lib/A-Server/A-HttpServer.constants.d.ts +7 -0
  178. package/dist/node/lib/A-Server/A-HttpServer.constants.js +11 -0
  179. package/dist/node/lib/A-Server/A-HttpServer.constants.js.map +1 -0
  180. package/dist/node/lib/A-Server/A-HttpServer.constants.mjs +11 -0
  181. package/dist/node/lib/A-Server/A-HttpServer.constants.mjs.map +1 -0
  182. package/dist/node/lib/A-Server/A-HttpServer.container.d.mts +50 -0
  183. package/dist/node/lib/A-Server/A-HttpServer.container.d.ts +50 -0
  184. package/dist/node/lib/A-Server/A-HttpServer.container.js +194 -0
  185. package/dist/node/lib/A-Server/A-HttpServer.container.js.map +1 -0
  186. package/dist/node/lib/A-Server/A-HttpServer.container.mjs +182 -0
  187. package/dist/node/lib/A-Server/A-HttpServer.container.mjs.map +1 -0
  188. package/dist/node/lib/A-Server/A-HttpServer.error.d.mts +54 -0
  189. package/dist/node/lib/A-Server/A-HttpServer.error.d.ts +54 -0
  190. package/dist/node/lib/A-Server/A-HttpServer.error.js +118 -0
  191. package/dist/node/lib/A-Server/A-HttpServer.error.js.map +1 -0
  192. package/dist/node/lib/A-Server/A-HttpServer.error.mjs +117 -0
  193. package/dist/node/lib/A-Server/A-HttpServer.error.mjs.map +1 -0
  194. package/dist/node/lib/A-Server/A-HttpServer.types.d.mts +19 -0
  195. package/dist/node/lib/A-Server/A-HttpServer.types.d.ts +19 -0
  196. package/dist/node/lib/A-Server/A-HttpServer.types.js +4 -0
  197. package/dist/node/lib/A-Server/A-HttpServer.types.js.map +1 -0
  198. package/dist/node/lib/A-Server/A-HttpServer.types.mjs +3 -0
  199. package/dist/node/lib/A-Server/A-HttpServer.types.mjs.map +1 -0
  200. package/dist/node/lib/A-Server/A-Server.context.d.mts +22 -0
  201. package/dist/node/lib/A-Server/A-Server.context.d.ts +22 -0
  202. package/dist/node/lib/A-Server/A-Server.context.js +24 -0
  203. package/dist/node/lib/A-Server/A-Server.context.js.map +1 -0
  204. package/dist/node/lib/A-Server/A-Server.context.mjs +23 -0
  205. package/dist/node/lib/A-Server/A-Server.context.mjs.map +1 -0
  206. package/dist/node/lib/A-Server/A-Server.error.d.mts +14 -0
  207. package/dist/node/lib/A-Server/A-Server.error.d.ts +14 -0
  208. package/dist/node/lib/A-Server/A-Server.error.js +26 -0
  209. package/dist/node/lib/A-Server/A-Server.error.js.map +1 -0
  210. package/dist/node/lib/A-Server/A-Server.error.mjs +25 -0
  211. package/dist/node/lib/A-Server/A-Server.error.mjs.map +1 -0
  212. package/dist/node/lib/A-Server/A-Server.types.d.mts +26 -0
  213. package/dist/node/lib/A-Server/A-Server.types.d.ts +26 -0
  214. package/dist/node/lib/A-Server/A-Server.types.js +4 -0
  215. package/dist/node/lib/A-Server/A-Server.types.js.map +1 -0
  216. package/dist/node/lib/A-Server/A-Server.types.mjs +3 -0
  217. package/dist/node/lib/A-Server/A-Server.types.mjs.map +1 -0
  218. package/dist/node/lib/A-ServerController/A-ServerController.component.d.mts +29 -0
  219. package/dist/node/lib/A-ServerController/A-ServerController.component.d.ts +29 -0
  220. package/dist/node/lib/A-ServerController/A-ServerController.component.js +49 -0
  221. package/dist/node/lib/A-ServerController/A-ServerController.component.js.map +1 -0
  222. package/dist/node/lib/A-ServerController/A-ServerController.component.mjs +37 -0
  223. package/dist/node/lib/A-ServerController/A-ServerController.component.mjs.map +1 -0
  224. package/dist/node/lib/A-ServerController/A-ServerController.types.d.mts +2 -0
  225. package/dist/node/lib/A-ServerController/A-ServerController.types.d.ts +2 -0
  226. package/dist/node/lib/A-ServerController/A-ServerController.types.js +4 -0
  227. package/dist/node/lib/A-ServerController/A-ServerController.types.js.map +1 -0
  228. package/dist/node/lib/A-ServerController/A-ServerController.types.mjs +3 -0
  229. package/dist/node/lib/A-ServerController/A-ServerController.types.mjs.map +1 -0
  230. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.d.mts +49 -0
  231. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.d.ts +49 -0
  232. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.js +91 -0
  233. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.js.map +1 -0
  234. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.mjs +90 -0
  235. package/dist/node/lib/A-ServerEntityList/A-EntityList.entity.mjs.map +1 -0
  236. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.d.mts +22 -0
  237. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.d.ts +22 -0
  238. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.js +10 -0
  239. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.js.map +1 -0
  240. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.mjs +10 -0
  241. package/dist/node/lib/A-ServerEntityList/A-EntityList.types.mjs.map +1 -0
  242. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.d.mts +13 -0
  243. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.d.ts +13 -0
  244. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.js +32 -0
  245. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.js.map +1 -0
  246. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.mjs +31 -0
  247. package/dist/node/lib/A-ServerListQuery/A-ServerListQueryFilter.context.mjs.map +1 -0
  248. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.d.mts +48 -0
  249. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.d.ts +48 -0
  250. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.js +88 -0
  251. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.js.map +1 -0
  252. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.mjs +76 -0
  253. package/dist/node/lib/A-ServerLogger/A-ServerLogger.component.mjs.map +1 -0
  254. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.d.mts +24 -0
  255. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.d.ts +24 -0
  256. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.js +33 -0
  257. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.js.map +1 -0
  258. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.mjs +33 -0
  259. package/dist/node/lib/A-ServerLogger/A-ServerLogger.constants.mjs.map +1 -0
  260. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.d.mts +12 -0
  261. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.d.ts +12 -0
  262. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.js +4 -0
  263. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.js.map +1 -0
  264. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.mjs +3 -0
  265. package/dist/node/lib/A-ServerLogger/A-ServerLogger.types.mjs.map +1 -0
  266. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.d.mts +6 -0
  267. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.d.ts +6 -0
  268. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.js +18 -0
  269. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.js.map +1 -0
  270. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.mjs +17 -0
  271. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.component.mjs.map +1 -0
  272. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.d.mts +2 -0
  273. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.d.ts +2 -0
  274. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.js +4 -0
  275. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.js.map +1 -0
  276. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.mjs +3 -0
  277. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.constants.mjs.map +1 -0
  278. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.d.mts +2 -0
  279. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.d.ts +2 -0
  280. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.js +4 -0
  281. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.js.map +1 -0
  282. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.mjs +3 -0
  283. package/dist/node/lib/A-ServerMiddleware/A-ServerMiddleware.types.mjs.map +1 -0
  284. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.d.mts +31 -0
  285. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.d.ts +31 -0
  286. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.js +90 -0
  287. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.js.map +1 -0
  288. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.mjs +78 -0
  289. package/dist/node/lib/A-ServerProxy/A-ServerProxy.component.mjs.map +1 -0
  290. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.d.mts +9 -0
  291. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.d.ts +9 -0
  292. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.js +14 -0
  293. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.js.map +1 -0
  294. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.mjs +14 -0
  295. package/dist/node/lib/A-ServerProxy/A-ServerProxy.constants.mjs.map +1 -0
  296. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.d.mts +36 -0
  297. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.d.ts +36 -0
  298. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.js +60 -0
  299. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.js.map +1 -0
  300. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.mjs +59 -0
  301. package/dist/node/lib/A-ServerProxy/A-ServerProxy.context.mjs.map +1 -0
  302. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.d.mts +23 -0
  303. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.d.ts +23 -0
  304. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.js +4 -0
  305. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.js.map +1 -0
  306. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.mjs +3 -0
  307. package/dist/node/lib/A-ServerProxy/A-ServerProxy.types.mjs.map +1 -0
  308. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.d.mts +20 -0
  309. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.d.ts +20 -0
  310. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.js +25 -0
  311. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.js.map +1 -0
  312. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.mjs +24 -0
  313. package/dist/node/lib/A-ServerRoute/A-ServerRoute.constants.mjs.map +1 -0
  314. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.d.mts +15 -0
  315. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.d.ts +15 -0
  316. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.js +24 -0
  317. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.js.map +1 -0
  318. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.mjs +23 -0
  319. package/dist/node/lib/A-ServerRoute/A-ServerRoute.entity.mjs.map +1 -0
  320. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.d.mts +6 -0
  321. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.d.ts +6 -0
  322. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.js +4 -0
  323. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.js.map +1 -0
  324. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.mjs +3 -0
  325. package/dist/node/lib/A-ServerRoute/A-ServerRoute.types.mjs.map +1 -0
  326. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.d.mts +84 -0
  327. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.d.ts +84 -0
  328. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.js +194 -0
  329. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.js.map +1 -0
  330. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.mjs +184 -0
  331. package/dist/node/lib/A-ServerRouter/A-ServerRouter.component.mjs.map +1 -0
  332. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.d.mts +6 -0
  333. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.d.ts +6 -0
  334. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.js +10 -0
  335. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.js.map +1 -0
  336. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.mjs +10 -0
  337. package/dist/node/lib/A-ServerRouter/A-ServerRouter.constants.mjs.map +1 -0
  338. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.d.mts +16 -0
  339. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.d.ts +16 -0
  340. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.js +40 -0
  341. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.js.map +1 -0
  342. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.mjs +39 -0
  343. package/dist/node/lib/A-ServerRouter/A-ServerRouter.meta.mjs.map +1 -0
  344. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.d.mts +24 -0
  345. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.d.ts +24 -0
  346. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.js +4 -0
  347. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.js.map +1 -0
  348. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.mjs +3 -0
  349. package/dist/node/lib/A-ServerRouter/A-ServerRouter.types.mjs.map +1 -0
  350. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.d.mts +16 -0
  351. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.d.ts +16 -0
  352. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.js +25 -0
  353. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.js.map +1 -0
  354. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.mjs +24 -0
  355. package/dist/node/lib/A-ServerRouter/A-ServerRouterDefine.decorator.mjs.map +1 -0
  356. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.d.mts +65 -0
  357. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.d.ts +65 -0
  358. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.js +260 -0
  359. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.js.map +1 -0
  360. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.mjs +248 -0
  361. package/dist/node/lib/A-ServerStatic/A-ServerStatic.component.mjs.map +1 -0
  362. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.d.mts +110 -0
  363. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.d.ts +110 -0
  364. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.js +180 -0
  365. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.js.map +1 -0
  366. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.mjs +179 -0
  367. package/dist/node/lib/A-ServerStatic/A-ServerStatic.context.mjs.map +1 -0
  368. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.d.mts +8 -0
  369. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.d.ts +8 -0
  370. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.js +4 -0
  371. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.js.map +1 -0
  372. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.mjs +3 -0
  373. package/dist/node/lib/A-ServerStatic/A-ServerStatic.types.mjs.map +1 -0
  374. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.d.mts +29 -0
  375. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.d.ts +29 -0
  376. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.js +62 -0
  377. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.js.map +1 -0
  378. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.mjs +50 -0
  379. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.component.mjs.map +1 -0
  380. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.d.mts +5 -0
  381. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.d.ts +5 -0
  382. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.js +14 -0
  383. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.js.map +1 -0
  384. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.mjs +14 -0
  385. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.constants.mjs.map +1 -0
  386. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.d.mts +9 -0
  387. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.d.ts +9 -0
  388. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.js +4 -0
  389. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.js.map +1 -0
  390. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.mjs +3 -0
  391. package/dist/node/middlewares/A-ServerCORS/A_ServerCORS.types.mjs.map +1 -0
  392. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.d.mts +24 -0
  393. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.d.ts +24 -0
  394. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.js +94 -0
  395. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.js.map +1 -0
  396. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.mjs +82 -0
  397. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.component.mjs.map +1 -0
  398. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.d.mts +2 -0
  399. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.d.ts +2 -0
  400. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.js +4 -0
  401. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.js.map +1 -0
  402. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.mjs +3 -0
  403. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.error.mjs.map +1 -0
  404. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.d.mts +2 -0
  405. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.d.ts +2 -0
  406. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.js +4 -0
  407. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.js.map +1 -0
  408. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.mjs +3 -0
  409. package/dist/node/repositories/A-EntityRepository/A-EntityRepository.types.mjs.map +1 -0
  410. package/examples/simple-server/commands/SignIn.command.ts +17 -1
  411. package/examples/simple-server/components/Test.controller.ts +8 -7
  412. package/examples/simple-server/components/Users.repository.ts +28 -26
  413. package/examples/simple-server/concept.ts +56 -59
  414. package/examples/simple-server/entities/User/User.entity.ts +17 -7
  415. package/jest.config.ts +24 -10
  416. package/package.json +267 -25
  417. package/src/channels/A-Http/A-Http.channel.constants.ts +6 -7
  418. package/src/channels/A-Http/A-Http.channel.error.ts +2 -2
  419. package/src/channels/A-Http/A-Http.channel.ts +76 -125
  420. package/src/channels/A-Http/A-Http.channel.types.ts +6 -3
  421. package/src/channels/A-Websockets/A-Websockets.channel.ts +1 -1
  422. package/src/{components → controllers}/A-CommandController/A-CommandController.component.ts +16 -10
  423. package/src/{components → controllers}/A-EntityController/A-EntityController.component.ts +24 -28
  424. package/src/{components → controllers}/A-ListingController/A-ListingController.component.ts +10 -12
  425. package/src/{components → controllers}/A-ServerHealthMonitor/A-ServerHealthMonitor.component.ts +11 -11
  426. package/src/index.ts +58 -63
  427. package/src/lib/A-Request/A-HttpRequestData.context.ts +30 -0
  428. package/src/lib/A-Request/A-HttpServerRequest.context.ts +103 -0
  429. package/src/lib/A-Request/A-Request.constants.ts +30 -0
  430. package/src/lib/A-Request/A-Request.entity.ts +844 -0
  431. package/src/lib/A-Request/A-Request.env.ts +50 -0
  432. package/src/lib/A-Request/A-Request.error.ts +11 -0
  433. package/src/lib/A-Request/A-Request.helper.ts +276 -0
  434. package/src/lib/A-Request/A-Request.types.ts +284 -0
  435. package/src/lib/A-Request/README.md +567 -0
  436. package/src/lib/A-Response/A-Response.constants.ts +24 -0
  437. package/src/lib/A-Response/A-Response.entity.ts +689 -0
  438. package/src/lib/A-Response/A-Response.error.ts +6 -0
  439. package/src/lib/A-Response/A-Response.types.ts +127 -0
  440. package/src/lib/A-Response/README.md +793 -0
  441. package/src/lib/A-Server/A-HttpServer.constants.ts +9 -0
  442. package/src/lib/A-Server/A-HttpServer.container.ts +251 -0
  443. package/src/lib/A-Server/A-HttpServer.error.ts +165 -0
  444. package/src/lib/A-Server/A-HttpServer.types.ts +37 -0
  445. package/src/{context/A-Server/A_Server.context.ts → lib/A-Server/A-Server.context.ts} +6 -7
  446. package/src/lib/A-Server/A-Server.error.ts +26 -0
  447. package/src/{components/A-ServerError/A-ServerError.types.ts → lib/A-Server/A-Server.types.ts} +8 -0
  448. package/src/{components/A-Controller/A-Controller.component.ts → lib/A-ServerController/A-ServerController.component.ts} +5 -5
  449. package/src/{entities/A_EntityList/A_EntityList.entity.ts → lib/A-ServerEntityList/A-EntityList.entity.ts} +2 -2
  450. package/src/{entities/A_EntityList/A_EntityList.entity.types.ts → lib/A-ServerEntityList/A-EntityList.types.ts} +2 -2
  451. package/src/{context/A-ListQueryFilter/A_ListQueryFilter.context.ts → lib/A-ServerListQuery/A-ServerListQueryFilter.context.ts} +1 -1
  452. package/src/lib/A-ServerLogger/A-ServerLogger.component.ts +121 -0
  453. package/src/lib/A-ServerLogger/A-ServerLogger.types.ts +13 -0
  454. package/src/lib/A-ServerMiddleware/A-ServerMiddleware.component.ts +17 -0
  455. package/src/{components → lib}/A-ServerProxy/A-ServerProxy.component.ts +17 -12
  456. package/src/{context/A-ProxyConfig/A_ProxyConfig.constants.ts → lib/A-ServerProxy/A-ServerProxy.constants.ts} +1 -1
  457. package/src/{context/A-ProxyConfig/A_ProxyConfig.context.ts → lib/A-ServerProxy/A-ServerProxy.context.ts} +4 -4
  458. package/src/{context/A-ProxyConfig/A_ProxyConfig.types.ts → lib/A-ServerProxy/A-ServerProxy.types.ts} +4 -4
  459. package/src/lib/A-ServerRoute/A-ServerRoute.constants.ts +20 -0
  460. package/src/lib/A-ServerRoute/A-ServerRoute.entity.ts +48 -0
  461. package/src/lib/A-ServerRoute/A-ServerRoute.types.ts +6 -0
  462. package/src/{components/A-Router/A-Router.component.ts → lib/A-ServerRouter/A-ServerRouter.component.ts} +77 -97
  463. package/src/lib/A-ServerRouter/A-ServerRouter.constants.ts +8 -0
  464. package/src/lib/A-ServerRouter/A-ServerRouter.meta.ts +48 -0
  465. package/src/lib/A-ServerRouter/A-ServerRouter.types.ts +27 -0
  466. package/src/lib/A-ServerRouter/A-ServerRouterDefine.decorator.ts +37 -0
  467. package/src/lib/A-ServerStatic/A-ServerStatic.component.ts +323 -0
  468. package/src/lib/A-ServerStatic/A-ServerStatic.context.ts +229 -0
  469. package/src/{components → middlewares}/A-ServerCORS/A_ServerCORS.component.ts +16 -13
  470. package/src/{components/A-ServerCORS/A_ServerCORS.component.defaults.ts → middlewares/A-ServerCORS/A_ServerCORS.constants.ts} +2 -2
  471. package/src/{components → repositories}/A-EntityRepository/A-EntityRepository.component.ts +39 -30
  472. package/tests/A-HttpChannel.test.ts +41 -48
  473. package/tests/A-HttpServerError.test.ts +204 -0
  474. package/tests/A-Request.test.ts +351 -0
  475. package/tsconfig.json +40 -50
  476. package/tsup.config.ts +111 -13
  477. package/dist/index.d.mts +0 -739
  478. package/dist/index.d.ts +0 -739
  479. package/dist/index.js +0 -1904
  480. package/dist/index.js.map +0 -1
  481. package/dist/index.mjs +0 -1863
  482. package/dist/index.mjs.map +0 -1
  483. package/examples/microservices-server/components/controllers/Statistics.controller.ts +0 -18
  484. package/examples/microservices-server/components/repositories/Memory.repository.ts +0 -66
  485. package/examples/microservices-server/concept.ts +0 -43
  486. package/examples/microservices-server/context/MemoryStore.context.ts +0 -31
  487. package/examples/microservices-server/entities/Order.entity.ts +0 -7
  488. package/examples/microservices-server/entities/User.entity.ts +0 -8
  489. package/src/components/A-Router/A-Router.component.types.ts +0 -38
  490. package/src/components/A-ServerError/A-ServerError.class.ts +0 -98
  491. package/src/components/A-ServerLogger/A_ServerLogger.component.ts +0 -194
  492. package/src/components/A-ServerLogger/A_ServerLogger.component.types.ts +0 -14
  493. package/src/components/A-StaticLoader/A-StaticLoader.component.ts +0 -133
  494. package/src/containers/A-Service/A-Service.container.ts +0 -202
  495. package/src/containers/A-Service/A-Service.container.types.ts +0 -46
  496. package/src/context/A-EntityFactory/A-EntityFactory.context.ts +0 -163
  497. package/src/context/A-EntityFactory/A-EntityFactory.context.types.ts +0 -11
  498. package/src/context/A-HttpChannel/A-HttpChannel.context.ts +0 -36
  499. package/src/context/A-Server/A_Server.context.types.ts +0 -9
  500. package/src/context/A-StaticConfig/A-StaticConfig.context.ts +0 -36
  501. package/src/entities/A-Request/A-Request.entity.ts +0 -163
  502. package/src/entities/A-Request/A-Request.entity.types.ts +0 -41
  503. package/src/entities/A-Response/A-Response.entity.ts +0 -194
  504. package/src/entities/A-Response/A-Response.entity.types.ts +0 -26
  505. package/src/entities/A-Route/A-Route.entity.ts +0 -117
  506. package/tests/A-Service.test.ts +0 -18
  507. /package/src/{components → controllers}/A-EntityController/A-EntityController.component.types.ts +0 -0
  508. /package/src/{components/A-Controller/A-Controller.component.types.ts → controllers/A-ListingController/A-ListingController.types.ts} +0 -0
  509. /package/src/{components/A-ServerHealthMonitor/A-ServerHealthMonitor.component.types.ts → controllers/A-ServerHealthMonitor/A-ServerHealthMonitor.types.ts} +0 -0
  510. /package/src/{components/A-EntityRepository/A-EntityRepository.error.ts → lib/A-Response/A-Response.env.ts} +0 -0
  511. /package/src/{components/A-EntityRepository/A-EntityRepository.types.ts → lib/A-ServerController/A-ServerController.types.ts} +0 -0
  512. /package/src/{components → lib}/A-ServerLogger/A-ServerLogger.constants.ts +0 -0
  513. /package/src/{components/A-ListingController/A-ListingController.component.types.ts → lib/A-ServerMiddleware/A-ServerMiddleware.constants.ts} +0 -0
  514. /package/src/{components/A-ServerError/A-ServerError.constants.ts → lib/A-ServerMiddleware/A-ServerMiddleware.types.ts} +0 -0
  515. /package/src/{components/A-StaticLoader/A-StaticLoader.component.types.ts → lib/A-ServerStatic/A-ServerStatic.types.ts} +0 -0
  516. /package/src/{components/A-ServerCORS/A_ServerCORS.component.types.ts → middlewares/A-ServerCORS/A_ServerCORS.types.ts} +0 -0
  517. /package/src/{context/A-StaticConfig/A-StaticConfig.context.types.ts → repositories/A-EntityRepository/A-EntityRepository.error.ts} +0 -0
  518. /package/src/{entities/A-Route/A-Route.entity.types.ts → repositories/A-EntityRepository/A-EntityRepository.types.ts} +0 -0
package/dist/index.js DELETED
@@ -1,1904 +0,0 @@
1
- 'use strict';
2
-
3
- var aConcept = require('@adaas/a-concept');
4
- var aUtils = require('@adaas/a-utils');
5
- var crypto = require('crypto');
6
- var fs = require('fs');
7
- var path = require('path');
8
- var url = require('url');
9
- var AEntity_constants = require('@adaas/a-concept/dist/src/global/A-Entity/A-Entity.constants');
10
-
11
- function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
-
13
- var crypto__default = /*#__PURE__*/_interopDefault(crypto);
14
- var fs__default = /*#__PURE__*/_interopDefault(fs);
15
- var path__default = /*#__PURE__*/_interopDefault(path);
16
-
17
- var __defProp = Object.defineProperty;
18
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
19
- var __decorateClass = (decorators, target, key, kind) => {
20
- var result = __getOwnPropDesc(target, key) ;
21
- for (var i = decorators.length - 1, decorator; i >= 0; i--)
22
- if (decorator = decorators[i])
23
- result = (decorator(target, key, result) ) || result;
24
- if (result) __defProp(target, key, result);
25
- return result;
26
- };
27
- var __decorateParam = (index, decorator) => (target, key) => decorator(target, key, index);
28
-
29
- // src/containers/A-Service/A-Service.container.types.ts
30
- var A_SERVER_TYPES__ServerFeature = /* @__PURE__ */ ((A_SERVER_TYPES__ServerFeature2) => {
31
- A_SERVER_TYPES__ServerFeature2["beforeStart"] = "beforeStart";
32
- A_SERVER_TYPES__ServerFeature2["afterStart"] = "afterStart";
33
- A_SERVER_TYPES__ServerFeature2["beforeStop"] = "beforeStop";
34
- A_SERVER_TYPES__ServerFeature2["afterStop"] = "afterStop";
35
- A_SERVER_TYPES__ServerFeature2["beforeRequest"] = "beforeRequest";
36
- A_SERVER_TYPES__ServerFeature2["onRequest"] = "onRequest";
37
- A_SERVER_TYPES__ServerFeature2["afterRequest"] = "afterRequest";
38
- return A_SERVER_TYPES__ServerFeature2;
39
- })(A_SERVER_TYPES__ServerFeature || {});
40
- var A_SERVER_TYPES__ServerMethod = /* @__PURE__ */ ((A_SERVER_TYPES__ServerMethod2) => {
41
- A_SERVER_TYPES__ServerMethod2["GET"] = "GET";
42
- A_SERVER_TYPES__ServerMethod2["POST"] = "POST";
43
- A_SERVER_TYPES__ServerMethod2["PUT"] = "PUT";
44
- A_SERVER_TYPES__ServerMethod2["DELETE"] = "DELETE";
45
- A_SERVER_TYPES__ServerMethod2["PATCH"] = "PATCH";
46
- A_SERVER_TYPES__ServerMethod2["OPTIONS"] = "OPTIONS";
47
- A_SERVER_TYPES__ServerMethod2["HEAD"] = "HEAD";
48
- A_SERVER_TYPES__ServerMethod2["CONNECT"] = "CONNECT";
49
- A_SERVER_TYPES__ServerMethod2["TRACE"] = "TRACE";
50
- A_SERVER_TYPES__ServerMethod2["DEFAULT"] = "DEFAULT";
51
- return A_SERVER_TYPES__ServerMethod2;
52
- })(A_SERVER_TYPES__ServerMethod || {});
53
- var A_HTTPChannel_RequestContext = class extends aConcept.A_Fragment {
54
- constructor(params) {
55
- super();
56
- const {
57
- method,
58
- url,
59
- data,
60
- config
61
- } = params;
62
- this.url = url;
63
- this.method = method;
64
- this.data = data;
65
- this.config = config;
66
- }
67
- };
68
-
69
- // src/channels/A-Http/A-Http.channel.constants.ts
70
- var A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle = /* @__PURE__ */ ((A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle2) => {
71
- A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle2["onAfterRequest"] = "onAfterHttpChannelRequest";
72
- A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle2["onError"] = "onHttpChannelError";
73
- A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle2["onBeforeRequest"] = "onBeforeHttpChannelRequest";
74
- return A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle2;
75
- })(A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle || {});
76
- var A_ServerError = class extends aConcept.A_Error {
77
- constructor() {
78
- super(...arguments);
79
- this.status = 500;
80
- }
81
- // constructor(
82
- // /**
83
- // * A_Error Constructor params
84
- // */
85
- // params: A_SERVER_TYPES__ServerError_Init
86
- // )
87
- // constructor(
88
- // /**
89
- // * HTTP Status Code of the error
90
- // */
91
- // status: number,
92
- // /**
93
- // * Error message
94
- // */
95
- // message: string
96
- // )
97
- // constructor(
98
- // /**
99
- // * Original JS Error
100
- // */
101
- // error: Error
102
- // )
103
- // constructor(
104
- // /**
105
- // * HTTP Status Code of the error
106
- // */
107
- // status: number,
108
- // /**
109
- // * Error message
110
- // */
111
- // title: string,
112
- // /**
113
- // * Detailed description of the error
114
- // */
115
- // description: string
116
- // )
117
- // constructor(
118
- // param1: A_SERVER_TYPES__ServerError_Init | Error | string | A_Error | number,
119
- // param2?: string | A_Error,
120
- // param3?: string
121
- // ) {
122
- // switch (true) {
123
- // case typeof param1 === 'number':
124
- // if (typeof param2 === 'string' && param3) {
125
- // super({
126
- // title: param2,
127
- // description: param3
128
- // });
129
- // }
130
- // else if (param2 instanceof A_Error) {
131
- // super(param2);
132
- // }
133
- // else {
134
- // super();
135
- // }
136
- // this.status = param1;
137
- // break;
138
- // case param1 instanceof A_Error:
139
- // super (param1);
140
- // break;
141
- // case param1 instanceof Error:
142
- // super (param1);
143
- // break;
144
- // default:
145
- // break;
146
- // }
147
- // }
148
- fromConstructor(params) {
149
- super.fromConstructor(params);
150
- if (params.status) {
151
- this.status = params.status;
152
- }
153
- }
154
- toJSON() {
155
- return {
156
- ...super.toJSON(),
157
- status: this.status
158
- };
159
- }
160
- };
161
- var A_HTTPChannelError = class extends aConcept.A_Error {
162
- };
163
- A_HTTPChannelError.HttpRequestError = "HTTP Channel Request Error";
164
-
165
- // src/channels/A-Http/A-Http.channel.ts
166
- var A_HTTPChannel = class extends aUtils.A_Channel {
167
- async connect() {
168
- return;
169
- }
170
- /**
171
- * Allows to send an HTTP request without expecting a response
172
- *
173
- * @param params
174
- */
175
- async send(params) {
176
- this.request(params);
177
- }
178
- /**
179
- * Makes an HTTP request
180
- *
181
- * @param params
182
- * @returns
183
- */
184
- async request(params) {
185
- const { method, url, data, config } = params;
186
- await this.initialize;
187
- this._processing = true;
188
- const fullUrl = this.buildURL(url, config?.params);
189
- const requestScope = new aConcept.A_Scope({ name: `a-http-channel-request-scope-${method}-${url}-${Date.now()}` });
190
- const context = new A_HTTPChannel_RequestContext({
191
- method,
192
- url,
193
- data,
194
- config
195
- });
196
- requestScope.inherit(aConcept.A_Context.scope(this));
197
- requestScope.register(context);
198
- try {
199
- await this.call("onBeforeHttpChannelRequest" /* onBeforeRequest */, requestScope);
200
- const headers = {
201
- "Content-Type": "application/json",
202
- ...config?.headers
203
- };
204
- const options = {
205
- method,
206
- headers
207
- };
208
- if (data && method !== "GET" /* GET */) {
209
- options.body = JSON.stringify(data);
210
- }
211
- const response = await fetch(fullUrl, options);
212
- if (!response.ok) {
213
- throw new A_ServerError({
214
- status: response.status,
215
- title: response.statusText,
216
- description: `HTTP request to ${fullUrl} failed with status ${response.status}`
217
- });
218
- }
219
- context.result = config?.params?.responseType === "text" ? await response.text() : config?.params?.responseType === "blob" ? await response.blob() : await response.json();
220
- await this.call("onAfterHttpChannelRequest" /* onAfterRequest */, requestScope);
221
- this._processing = false;
222
- return context;
223
- } catch (error) {
224
- this._processing = false;
225
- context.error = error;
226
- await this.call("onHttpChannelError" /* onError */, requestScope);
227
- if (config?.throwOnError === false)
228
- return context;
229
- else
230
- throw error;
231
- }
232
- }
233
- async post(url, body, config) {
234
- return this.request(
235
- {
236
- method: "POST" /* POST */,
237
- url,
238
- data: body,
239
- config
240
- }
241
- );
242
- }
243
- async get(url, params, config) {
244
- return this.request(
245
- {
246
- method: "GET" /* GET */,
247
- url,
248
- config: {
249
- ...config,
250
- params
251
- }
252
- }
253
- );
254
- }
255
- async put(url, body, config) {
256
- return this.request({
257
- method: "PUT" /* PUT */,
258
- url,
259
- data: body,
260
- config
261
- });
262
- }
263
- async delete(url, params, config) {
264
- return this.request({
265
- method: "DELETE" /* DELETE */,
266
- url,
267
- data: params,
268
- config
269
- });
270
- }
271
- buildURL(path2 = "", params = {}) {
272
- if (!this.baseUrl)
273
- throw new A_HTTPChannelError(
274
- A_HTTPChannelError.HttpRequestError,
275
- "Base URL is not set for HTTP Channel"
276
- );
277
- const url = new URL(`${this.baseUrl}${path2.startsWith("/") ? path2 : `/${path2}`}`);
278
- Object.keys(params).forEach((key) => {
279
- if (params[key] !== void 0 && params[key] !== null) {
280
- url.searchParams.append(key, params[key]);
281
- }
282
- });
283
- return url.toString();
284
- }
285
- };
286
-
287
- // src/constants/env.constants.ts
288
- var A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES = {
289
- // ----------------------------------------------------------
290
- // A-Server Environment Variables
291
- // ----------------------------------------------------------
292
- // These environment variables are used by A-Server to configure the application
293
- // ----------------------------------------------------------
294
- /**
295
- * Port for the server to listen on
296
- * [!] Default is 3000
297
- * @default 3000
298
- */
299
- A_SERVER_PORT: "A_SERVER_PORT"
300
- };
301
- var A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY = [
302
- A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES.A_SERVER_PORT
303
- ];
304
- var A_Server = class extends aConcept.A_Fragment {
305
- constructor(params) {
306
- super(params);
307
- this._routes = [];
308
- this.port = params.port;
309
- this.name = params.name;
310
- this.version = params.version || "v1";
311
- this._routes = params.routes || this._routes;
312
- }
313
- /**
314
- * A list of routes that the server will listen to
315
- */
316
- get routes() {
317
- return this._routes;
318
- }
319
- };
320
-
321
- // src/entities/A-Request/A-Request.entity.types.ts
322
- var A_SERVER_TYPES__RequestEvent = /* @__PURE__ */ ((A_SERVER_TYPES__RequestEvent2) => {
323
- A_SERVER_TYPES__RequestEvent2["Error"] = "error";
324
- A_SERVER_TYPES__RequestEvent2["Finish"] = "finish";
325
- A_SERVER_TYPES__RequestEvent2["Data"] = "data";
326
- A_SERVER_TYPES__RequestEvent2["End"] = "end";
327
- A_SERVER_TYPES__RequestEvent2["Close"] = "close";
328
- return A_SERVER_TYPES__RequestEvent2;
329
- })(A_SERVER_TYPES__RequestEvent || {});
330
-
331
- // src/entities/A-Route/A-Route.entity.ts
332
- var A_Route = class {
333
- constructor(param1, param2) {
334
- this.url = param1 instanceof RegExp ? param1.source : param1;
335
- this.method = param2 || "GET";
336
- }
337
- /**
338
- * returns path only without query and hash
339
- */
340
- get path() {
341
- const p = this.url.split("?")[0].split("#")[0];
342
- return p.endsWith("/") ? p.slice(0, -1) : p;
343
- }
344
- get params() {
345
- return this.path.match(/:([^\/]+)/g)?.map((param) => param.slice(1)) || [];
346
- }
347
- extractParams(url) {
348
- const cleanUrl = url.split("?")[0];
349
- const urlSegments = cleanUrl.split("/").filter(Boolean);
350
- const maskSegments = this.path.split("/").filter(Boolean);
351
- const params = {};
352
- for (let i = 0; i < maskSegments.length; i++) {
353
- const maskSegment = maskSegments[i];
354
- const urlSegment = urlSegments[i];
355
- if (maskSegment.startsWith(":")) {
356
- const paramName = maskSegment.slice(1);
357
- params[paramName] = urlSegment;
358
- } else if (maskSegment !== urlSegment) {
359
- return {};
360
- }
361
- }
362
- return params;
363
- }
364
- extractQuery(url) {
365
- const query = {};
366
- const queryString = url.split("?")[1];
367
- if (!queryString) return query;
368
- const cleanQuery = queryString.split("#")[0];
369
- for (const pair of cleanQuery.split("&")) {
370
- if (!pair) continue;
371
- const [key, value = ""] = pair.split("=");
372
- query[decodeURIComponent(key)] = decodeURIComponent(value);
373
- }
374
- return query;
375
- }
376
- toString() {
377
- return `${this.method}::${this.path}`;
378
- }
379
- toRegExp() {
380
- return new RegExp(`^${this.method}::${this.path.replace(/\/:([^\/]+)/g, "/([^/]+)")}$`);
381
- }
382
- toAFeatureExtension(extensionScope = []) {
383
- return new RegExp(`^${extensionScope.length ? `(${extensionScope.join("|")})` : ".*"}\\.${this.method}::${this.path.replace(/\/:([^\/]+)/g, "/([^/]+)")}$`);
384
- }
385
- };
386
-
387
- // src/entities/A-Request/A-Request.entity.ts
388
- var A_Request = class extends aConcept.A_Entity {
389
- constructor() {
390
- super(...arguments);
391
- this.body = {};
392
- this.params = {};
393
- this.query = {};
394
- /**
395
- * Duration of the request in milliseconds
396
- */
397
- this.duration = 0;
398
- }
399
- static get namespace() {
400
- return "a-server";
401
- }
402
- fromNew(newEntity) {
403
- this.req = newEntity.request;
404
- this.aseid = new aConcept.ASEID({
405
- concept: aConcept.A_Context.root.name,
406
- scope: newEntity.scope,
407
- entity: this.constructor.entity,
408
- id: newEntity.id
409
- });
410
- }
411
- get startedAt() {
412
- const timeId = aConcept.A_IdentityHelper.parseTimeId(this.aseid.id.split("-")[0]);
413
- return timeId ? new Date(timeId.timestamp) : void 0;
414
- }
415
- // Getter for request URL
416
- get url() {
417
- return this.req.url;
418
- }
419
- // Getter for request method
420
- get method() {
421
- return String(this.req.method).toUpperCase() || "DEFAULT";
422
- }
423
- get headers() {
424
- return this.req.headers;
425
- }
426
- get route() {
427
- return new A_Route(this.url, this.method);
428
- }
429
- pipe(destination, options) {
430
- return this.req.pipe(destination, options);
431
- }
432
- async init() {
433
- this.req.on("error", async (err) => {
434
- this.error = new A_ServerError(err);
435
- await this.call("error" /* Error */);
436
- });
437
- this.params = this.extractParams(this.url);
438
- this.query = this.extractQuery(this.url);
439
- }
440
- extractParams(url) {
441
- const cleanUrl = url.split("?")[0];
442
- const urlSegments = cleanUrl.split("/").filter(Boolean);
443
- const maskSegments = this.url.split("/").filter(Boolean);
444
- const params = {};
445
- for (let i = 0; i < maskSegments.length; i++) {
446
- const maskSegment = maskSegments[i];
447
- const urlSegment = urlSegments[i];
448
- if (maskSegment.startsWith(":")) {
449
- const paramName = maskSegment.slice(1);
450
- params[paramName] = urlSegment;
451
- } else if (maskSegment !== urlSegment) {
452
- return {};
453
- }
454
- }
455
- return params;
456
- }
457
- extractQuery(url) {
458
- const query = {};
459
- const queryString = url.split("?")[1];
460
- if (!queryString) return query;
461
- const cleanQuery = queryString.split("#")[0];
462
- for (const pair of cleanQuery.split("&")) {
463
- if (!pair) continue;
464
- const [key, value = ""] = pair.split("=");
465
- query[decodeURIComponent(key)] = decodeURIComponent(value);
466
- }
467
- return query;
468
- }
469
- parseBody() {
470
- return new Promise((resolve, reject) => {
471
- let body = "";
472
- this.req.on("data", (chunk) => body += chunk);
473
- this.req.on("end", () => {
474
- try {
475
- resolve(JSON.parse(body));
476
- } catch (err) {
477
- reject(err);
478
- }
479
- });
480
- this.req.on("error", reject);
481
- });
482
- }
483
- };
484
-
485
- // src/entities/A-Response/A-Response.entity.types.ts
486
- var A_SERVER_TYPES__ResponseEvent = /* @__PURE__ */ ((A_SERVER_TYPES__ResponseEvent2) => {
487
- A_SERVER_TYPES__ResponseEvent2["Error"] = "error";
488
- A_SERVER_TYPES__ResponseEvent2["Finish"] = "finish";
489
- A_SERVER_TYPES__ResponseEvent2["Data"] = "data";
490
- A_SERVER_TYPES__ResponseEvent2["End"] = "end";
491
- A_SERVER_TYPES__ResponseEvent2["Close"] = "close";
492
- return A_SERVER_TYPES__ResponseEvent2;
493
- })(A_SERVER_TYPES__ResponseEvent || {});
494
- var A_Response = class extends aConcept.A_Entity {
495
- constructor() {
496
- super(...arguments);
497
- /**
498
- * Duration of the request in milliseconds
499
- */
500
- this.duration = 0;
501
- this.data = /* @__PURE__ */ new Map();
502
- }
503
- fromNew(newEntity) {
504
- this.res = newEntity.response;
505
- this.aseid = new aConcept.ASEID({
506
- concept: aConcept.A_Context.root.name,
507
- scope: newEntity.scope,
508
- entity: this.constructor.entity,
509
- id: newEntity.id
510
- });
511
- }
512
- get headersSent() {
513
- return this.res.headersSent;
514
- }
515
- get original() {
516
- return this.res;
517
- }
518
- get statusCode() {
519
- return this.res.statusCode;
520
- }
521
- async init() {
522
- const startTime = process.hrtime();
523
- this.res.on("finish", async () => {
524
- const elapsedTime = process.hrtime(startTime);
525
- const elapsedMilliseconds = elapsedTime[0] * 1e3 + elapsedTime[1] / 1e6;
526
- this.duration = elapsedMilliseconds;
527
- await this.call("finish" /* Finish */);
528
- });
529
- this.res.on("close", async () => {
530
- await this.call("close" /* Close */);
531
- });
532
- }
533
- failed(error) {
534
- switch (true) {
535
- case error instanceof A_ServerError:
536
- this.error = error;
537
- break;
538
- case error instanceof aConcept.A_Error:
539
- this.error = new A_ServerError(error);
540
- break;
541
- default:
542
- this.error = new A_ServerError(error);
543
- break;
544
- }
545
- return this.status(this.error.status).json(this.error);
546
- }
547
- // Send a plain text or JSON response
548
- send(data = this.toResponse()) {
549
- const logger = aConcept.A_Context.scope(this).resolve(aUtils.A_Logger);
550
- if (this.headersSent) {
551
- logger.warning("Response headers already sent, cannot send response again.");
552
- return;
553
- }
554
- try {
555
- switch (true) {
556
- case (!!data && typeof data === "object"):
557
- return this.json(data);
558
- case (!!data && typeof data === "string"):
559
- this.res.setHeader("Content-Type", "text/plain");
560
- this.res.writeHead(this.statusCode);
561
- this.res.end(data);
562
- return;
563
- default:
564
- this.res.writeHead(this.statusCode);
565
- this.res.end(data);
566
- return;
567
- }
568
- } catch (error) {
569
- logger.warning("Response send error:", error);
570
- }
571
- }
572
- destroy(error, scope) {
573
- this.res.end();
574
- return super.destroy(scope);
575
- }
576
- // Explicit JSON response
577
- json(data = this.toResponse()) {
578
- const logger = aConcept.A_Context.scope(this).resolve(aUtils.A_Logger);
579
- if (this.headersSent) {
580
- logger.warning("Response headers already sent, cannot send response again.");
581
- return;
582
- }
583
- this.res.setHeader("Content-Type", "application/json");
584
- this.res.writeHead(this.statusCode);
585
- this.res.end(JSON.stringify(data));
586
- }
587
- // Set HTTP status code
588
- status(code) {
589
- this.res.statusCode = code;
590
- return this;
591
- }
592
- writeHead(statusCode, headers) {
593
- this.res.writeHead(statusCode, headers);
594
- }
595
- setHeader(key, value) {
596
- this.res.setHeader(key, value);
597
- }
598
- getHeader(key) {
599
- return this.res.getHeader(key);
600
- }
601
- add(key, data) {
602
- this.data.set(key, data);
603
- }
604
- toResponse() {
605
- return Array.from(this.data.entries()).reduce((acc, [key, value]) => {
606
- if (value instanceof aConcept.A_Entity)
607
- acc[key] = value.toJSON();
608
- else
609
- acc[key] = value;
610
- return acc;
611
- }, {});
612
- }
613
- };
614
- var A_Service = class extends aConcept.A_Container {
615
- async load(polyfill) {
616
- let config;
617
- if (!this.scope.has(aUtils.A_Config)) {
618
- const config2 = new aUtils.A_Config({
619
- variables: [...Array.from(A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY)],
620
- defaults: {
621
- A_SERVER_PORT: 3e3
622
- }
623
- });
624
- this.scope.register(config2);
625
- }
626
- config = this.scope.resolve(aUtils.A_Config);
627
- if (!this.scope.has(A_Server)) {
628
- new A_Server({
629
- port: config.get("A_SERVER_PORT"),
630
- name: this.name,
631
- version: "v1"
632
- });
633
- }
634
- this.port = config.get("A_SERVER_PORT");
635
- const http = await polyfill.http();
636
- this.server = http.createServer(this.onRequest.bind(this));
637
- }
638
- listen() {
639
- return new Promise((resolve, reject) => {
640
- this.server.listen(this.port, () => {
641
- resolve();
642
- });
643
- });
644
- }
645
- close() {
646
- return new Promise((resolve, reject) => {
647
- this.server.close(() => {
648
- resolve();
649
- });
650
- });
651
- }
652
- /**
653
- * Start the server
654
- */
655
- async start() {
656
- await this.beforeStart();
657
- await this.listen();
658
- await this.afterStart();
659
- }
660
- async beforeStart() {
661
- }
662
- async afterStart() {
663
- }
664
- /**
665
- * Stop service
666
- */
667
- async stop() {
668
- await this.call("beforeStop" /* beforeStop */);
669
- await this.server.close();
670
- await this.call("afterStop" /* afterStop */);
671
- }
672
- async beforeRequest(scope) {
673
- }
674
- async afterRequest(scope) {
675
- }
676
- async onRequest(request, response) {
677
- const scope = new aConcept.A_Scope({
678
- name: `a-server-request::${Date.now()}`
679
- });
680
- const { req, res } = await this.convertToAServer(request, response);
681
- try {
682
- scope.register(req);
683
- scope.register(res);
684
- scope.inherit(this.scope);
685
- await this.beforeRequest(scope);
686
- await this.call("onRequest" /* onRequest */, scope);
687
- await this.afterRequest(scope);
688
- await res.status(200).send();
689
- } catch (error) {
690
- const logger = this.scope.resolve(aUtils.A_Logger);
691
- logger.error(error);
692
- return res.failed(error);
693
- }
694
- }
695
- async convertToAServer(request, response) {
696
- if (!request.method || !request.url)
697
- throw new Error("Request method or url is missing");
698
- const id = this.generateRequestId(request.method, request.url);
699
- const req = new A_Request({ id, request, scope: this.scope.name });
700
- const res = new A_Response({ id, response, scope: this.scope.name });
701
- await req.init();
702
- await res.init();
703
- return { req, res };
704
- }
705
- generateRequestId(method, url) {
706
- const hash = crypto__default.default.createHash("sha256");
707
- const timeId = aConcept.A_IdentityHelper.generateTimeId();
708
- const randomValue = Math.random().toString();
709
- hash.update(`${timeId}-${method}-${url}-${randomValue}`);
710
- return `${timeId}-${hash.digest("hex")}`;
711
- }
712
- async beforeStop() {
713
- }
714
- async afterStop() {
715
- }
716
- };
717
- __decorateClass([
718
- aConcept.A_Concept.Load(),
719
- __decorateParam(0, aConcept.A_Inject(aUtils.A_Polyfill))
720
- ], A_Service.prototype, "load");
721
- __decorateClass([
722
- aConcept.A_Concept.Start()
723
- ], A_Service.prototype, "start");
724
- __decorateClass([
725
- aConcept.A_Feature.Define({ invoke: true })
726
- ], A_Service.prototype, "beforeStart");
727
- __decorateClass([
728
- aConcept.A_Feature.Define({ invoke: true })
729
- ], A_Service.prototype, "afterStart");
730
- __decorateClass([
731
- aConcept.A_Concept.Stop()
732
- ], A_Service.prototype, "stop");
733
- __decorateClass([
734
- aConcept.A_Feature.Define({
735
- name: "beforeRequest" /* beforeRequest */,
736
- invoke: true
737
- })
738
- ], A_Service.prototype, "beforeRequest");
739
- __decorateClass([
740
- aConcept.A_Feature.Define({
741
- name: "beforeRequest" /* beforeRequest */,
742
- invoke: true
743
- })
744
- ], A_Service.prototype, "afterRequest");
745
- __decorateClass([
746
- aConcept.A_Feature.Define({
747
- name: "onRequest" /* onRequest */,
748
- invoke: false
749
- })
750
- ], A_Service.prototype, "onRequest");
751
- __decorateClass([
752
- aConcept.A_Feature.Define({ invoke: true })
753
- ], A_Service.prototype, "beforeStop");
754
- __decorateClass([
755
- aConcept.A_Feature.Define({ invoke: true })
756
- ], A_Service.prototype, "afterStop");
757
-
758
- // src/context/A-ProxyConfig/A_ProxyConfig.constants.ts
759
- var PROXY_CONFIG_DEFAULTS = {
760
- path: "/",
761
- hostname: "localhost",
762
- port: 80,
763
- method: "GET",
764
- headers: {},
765
- protocol: "http"
766
- };
767
-
768
- // src/context/A-ProxyConfig/A_ProxyConfig.context.ts
769
- var A_ProxyConfig = class extends aConcept.A_Fragment {
770
- constructor(configs = {}) {
771
- super();
772
- this._configs = Object.entries(configs).map(([path2, config]) => {
773
- const targetUrl = new URL(typeof config === "string" ? config : config.hostname || "");
774
- const port = targetUrl.port || (targetUrl.protocol === "https:" ? "443" : "80");
775
- const prepared = {
776
- ...PROXY_CONFIG_DEFAULTS,
777
- ...typeof config === "string" ? {
778
- path: path2,
779
- port: parseInt(port),
780
- protocol: targetUrl.protocol,
781
- hostname: targetUrl.hostname
782
- } : config
783
- };
784
- return {
785
- route: new A_Route(prepared.path, prepared.method),
786
- hostname: prepared.hostname,
787
- port: prepared.port,
788
- headers: prepared.headers,
789
- protocol: prepared.protocol
790
- };
791
- });
792
- }
793
- /**
794
- * Returns all configured proxy configs
795
- *
796
- */
797
- get configs() {
798
- return this._configs;
799
- }
800
- /**
801
- * Checks if a given path is configured in the proxy
802
- *
803
- * @param path
804
- * @returns
805
- */
806
- has(path2) {
807
- return this._configs.some((route) => route.route.toRegExp().test(path2));
808
- }
809
- /**
810
- * Returns the proxy configuration for a given path, if exists
811
- *
812
- * @param path
813
- * @returns
814
- */
815
- config(path2) {
816
- return this._configs.find((route) => route.route.toRegExp().test(path2));
817
- }
818
- };
819
- var A_StaticConfig = class extends aConcept.A_Fragment {
820
- constructor(directories = []) {
821
- super();
822
- this.directories = directories;
823
- }
824
- /**
825
- * Checks if a given path is configured in the proxy
826
- *
827
- * @param path
828
- * @returns
829
- */
830
- has(path2) {
831
- const found = this.directories.find((dir) => {
832
- return new RegExp(`^/${dir.startsWith("/") ? dir.slice(1) : dir}/?.*`).test(path2);
833
- });
834
- return !!found && found;
835
- }
836
- };
837
- var A_ListQueryFilter = class extends aConcept.A_Fragment {
838
- constructor(_query = {}, defaults = {}) {
839
- super();
840
- this._query = _query;
841
- this.defaults = defaults;
842
- this.parsedQuery = this.parseQueryString(_query);
843
- }
844
- get query() {
845
- return this._query;
846
- }
847
- get(property, defaultValue = "") {
848
- return this.parsedQuery[property] || this.defaults[property] || defaultValue;
849
- }
850
- parseQueryString(value = {}) {
851
- if (typeof value === "string") {
852
- return value.split("&").reduce((acc, part) => {
853
- const [key, val] = part.split("=");
854
- acc[decodeURIComponent(key)] = decodeURIComponent(val || "");
855
- return acc;
856
- }, {});
857
- }
858
- return value;
859
- }
860
- };
861
- var A_EntityFactory = class extends aConcept.A_Fragment {
862
- constructor(param1, param2) {
863
- super();
864
- this._entities = /* @__PURE__ */ new Map();
865
- this._setEntities(param1);
866
- this._setEntities(param2);
867
- }
868
- _setEntities(entities = []) {
869
- if (Array.isArray(entities)) {
870
- entities.forEach((entity) => {
871
- this._entities.set(entity.entity, entity);
872
- });
873
- } else {
874
- Object.keys(entities).forEach((key) => {
875
- this._entities.set(key, entities[key]);
876
- });
877
- }
878
- }
879
- add(param1, param2) {
880
- switch (true) {
881
- case (typeof param1 === "string" && !!param2):
882
- this._entities.set(param1, param2);
883
- break;
884
- case typeof param1 !== "string":
885
- this._entities.set(param1.entity, param1);
886
- break;
887
- }
888
- }
889
- has(param1) {
890
- let name;
891
- switch (true) {
892
- case param1 instanceof aConcept.ASEID:
893
- name = param1.entity;
894
- break;
895
- case (!(param1 instanceof aConcept.ASEID) && aConcept.ASEID.isASEID(param1)):
896
- name = new aConcept.ASEID(param1).entity;
897
- break;
898
- default:
899
- name = param1;
900
- break;
901
- }
902
- return this._entities.has(name);
903
- }
904
- resolve(param1) {
905
- let name;
906
- switch (true) {
907
- case param1 instanceof aConcept.ASEID:
908
- name = param1.entity;
909
- break;
910
- case (typeof param1 === "string" && aConcept.ASEID.isASEID(param1)):
911
- name = new aConcept.ASEID(param1).entity;
912
- break;
913
- default:
914
- name = param1;
915
- break;
916
- }
917
- return this._entities.get(name);
918
- }
919
- resolveByName(name) {
920
- return this._entities.get(name);
921
- }
922
- };
923
- var A_EntityList = class extends aConcept.A_Entity {
924
- constructor() {
925
- super(...arguments);
926
- this._items = [];
927
- this._pagination = {
928
- total: 0,
929
- page: 1,
930
- pageSize: 10
931
- };
932
- }
933
- static get scope() {
934
- return "a-server";
935
- }
936
- /**
937
- * Returns the entity constructor used for the list
938
- */
939
- get entityConstructor() {
940
- return this._entityConstructor;
941
- }
942
- /**
943
- * Returns the list of items contained in the entity list
944
- */
945
- get items() {
946
- return this._items;
947
- }
948
- /**
949
- * Returns pagination information about the entity list
950
- */
951
- get pagination() {
952
- return this._pagination;
953
- }
954
- /**
955
- * Creates a new instance of A_EntityList
956
- *
957
- * @param newEntity
958
- */
959
- fromNew(newEntity) {
960
- this.aseid = new aConcept.ASEID({
961
- concept: aConcept.A_Context.root.name,
962
- scope: "default",
963
- entity: "a-list" + (newEntity.name ? `.${newEntity.name}` : ""),
964
- id: (/* @__PURE__ */ new Date()).getTime().toString()
965
- });
966
- this._entityConstructor = newEntity.constructor;
967
- }
968
- /**
969
- * Allows to convert Repository Response data to EntityList instance
970
- *
971
- * [!] This method does not load the data from the repository, it only converts the data to the EntityList instance
972
- *
973
- * @param items
974
- * @param pagination
975
- */
976
- fromList(items, pagination) {
977
- this._items = items.map((item) => {
978
- if (item instanceof aConcept.A_Entity) {
979
- return item;
980
- } else {
981
- const entity = new this._entityConstructor(item);
982
- return entity;
983
- }
984
- });
985
- if (pagination) {
986
- this._pagination = {
987
- total: pagination.total,
988
- page: pagination.page,
989
- pageSize: pagination.pageSize
990
- };
991
- }
992
- }
993
- /**
994
- * Serializes the EntityList to a JSON object
995
- *
996
- * @returns
997
- */
998
- toJSON() {
999
- return {
1000
- ...super.toJSON(),
1001
- items: this._items.map((i) => i.toJSON()),
1002
- pagination: this._pagination
1003
- };
1004
- }
1005
- };
1006
- var A_ServerLogger = class extends aUtils.A_Logger {
1007
- async onRequestEnd(request, response) {
1008
- this.route({
1009
- method: request.method,
1010
- url: request.url,
1011
- status: response.statusCode,
1012
- responseTime: response.duration
1013
- });
1014
- }
1015
- async onRequestError(request) {
1016
- }
1017
- logStart(container) {
1018
- this.serverReady({
1019
- port: container.port,
1020
- app: {
1021
- name: container.name
1022
- }
1023
- });
1024
- }
1025
- logStop(server) {
1026
- this.log("red", `Server ${server.name} stopped`);
1027
- }
1028
- metrics() {
1029
- }
1030
- routes(routes) {
1031
- const time = this.getTime();
1032
- console.log(`\x1B[36m[${this.scope.name}] |${time}| Exposed Routes:
1033
- ${" ".repeat(this.scopeLength + 3)}|-------------------------------
1034
- ${routes.map((route) => `${" ".repeat(this.scopeLength + 3)}| [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.path}`).join("\n")}
1035
- ${" ".repeat(this.scopeLength + 3)}|-------------------------------\x1B[0m`);
1036
- }
1037
- /**
1038
- * Logs the route information based on status code
1039
- *
1040
- * @param route
1041
- */
1042
- route(route) {
1043
- switch (route.status) {
1044
- case 200:
1045
- this.log200(route);
1046
- break;
1047
- case 404:
1048
- this.log404(route);
1049
- break;
1050
- case 500:
1051
- this.log500(route);
1052
- break;
1053
- case 400:
1054
- this.log400(route);
1055
- break;
1056
- default:
1057
- this.logDefault(route);
1058
- break;
1059
- }
1060
- }
1061
- log200(route) {
1062
- if (this.config.get("SERVER_IGNORE_LOG_200"))
1063
- return;
1064
- console.log(`\x1B[32m[${this.scope.name}] |${this.getTime()}| ${route.status} | [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.url} | ${route.responseTime}ms\x1B[0m`);
1065
- }
1066
- log404(route) {
1067
- if (this.config.get("SERVER_IGNORE_LOG_404"))
1068
- return;
1069
- console.log(`\x1B[33m[${this.scope.name}] |${this.getTime()}| ${route.status} | [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.url} | ${route.responseTime}ms\x1B[0m`);
1070
- }
1071
- log500(route) {
1072
- if (this.config.get("SERVER_IGNORE_LOG_500"))
1073
- return;
1074
- console.log(`\x1B[31m[${this.scope.name}] |${this.getTime()}| ${route.status} | [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.url} | ${route.responseTime}ms\x1B[0m`);
1075
- }
1076
- log400(route) {
1077
- if (this.config.get("SERVER_IGNORE_LOG_400"))
1078
- return;
1079
- console.log(`\x1B[33m[${this.scope.name}] |${this.getTime()}| ${route.status} | [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.url} | ${route.responseTime}ms\x1B[0m`);
1080
- }
1081
- logDefault(route) {
1082
- if (this.config.get("SERVER_IGNORE_LOG_DEFAULT"))
1083
- return;
1084
- console.log(`\x1B[36m[${this.scope.name}] |${this.getTime()}| ${route.status} | [${route.method.toUpperCase()}]${" ".repeat(7 - route.method.length)} ${route.url} | ${route.responseTime}ms\x1B[0m`);
1085
- }
1086
- serverReady(params) {
1087
- const processId = process.pid;
1088
- console.log(`\x1B[36m[${this.scope.name}] |${this.getTime()}| Server Ready:
1089
- ${" ".repeat(this.scopeLength + 3)}|-------------------------------
1090
- ${" ".repeat(this.scopeLength + 3)}| ${params.app.name} v${params.app.version || "0.0.1"} is running on port ${params.port}
1091
- ${" ".repeat(this.scopeLength + 3)}| Process ID: ${processId}
1092
- ${" ".repeat(this.scopeLength + 3)}|-------------------------------
1093
- ${" ".repeat(this.scopeLength + 3)}| ==============================
1094
- ${" ".repeat(this.scopeLength + 3)}| LISTENING...
1095
- ${" ".repeat(this.scopeLength + 3)}| ==============================
1096
- \x1B[0m`);
1097
- }
1098
- /**
1099
- * Displays a proxy routes
1100
- *
1101
- * @param params
1102
- */
1103
- proxy(params) {
1104
- console.log(`\x1B[35m[${this.scope.name}] |${this.getTime()}| Proxy:
1105
- ${" ".repeat(this.scopeLength + 3)}| ${params.original} -> ${params.destination}
1106
- ${" ".repeat(this.scopeLength + 3)}|-------------------------------\x1B[0m`);
1107
- }
1108
- };
1109
- __decorateClass([
1110
- aConcept.A_Feature.Extend({
1111
- name: "finish" /* Finish */,
1112
- scope: [A_Response]
1113
- }),
1114
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1115
- __decorateParam(1, aConcept.A_Inject(A_Response))
1116
- ], A_ServerLogger.prototype, "onRequestEnd");
1117
- __decorateClass([
1118
- aConcept.A_Feature.Extend({
1119
- name: "error" /* Error */
1120
- }),
1121
- __decorateParam(0, aConcept.A_Inject(A_Request))
1122
- ], A_ServerLogger.prototype, "onRequestError");
1123
- __decorateClass([
1124
- aConcept.A_Feature.Extend({
1125
- name: "afterStart" /* afterStart */,
1126
- scope: [A_Service]
1127
- }),
1128
- __decorateParam(0, aConcept.A_Inject(A_Service))
1129
- ], A_ServerLogger.prototype, "logStart");
1130
- __decorateClass([
1131
- aConcept.A_Feature.Extend({
1132
- name: "afterStop" /* afterStop */,
1133
- scope: [A_Service]
1134
- }),
1135
- __decorateParam(0, aConcept.A_Inject(A_Server))
1136
- ], A_ServerLogger.prototype, "logStop");
1137
-
1138
- // src/components/A-Router/A-Router.component.types.ts
1139
- var A_SERVER_TYPES__RouterMethod = /* @__PURE__ */ ((A_SERVER_TYPES__RouterMethod2) => {
1140
- A_SERVER_TYPES__RouterMethod2["POST"] = "POST";
1141
- A_SERVER_TYPES__RouterMethod2["GET"] = "GET";
1142
- A_SERVER_TYPES__RouterMethod2["PUT"] = "PUT";
1143
- A_SERVER_TYPES__RouterMethod2["DELETE"] = "DELETE";
1144
- A_SERVER_TYPES__RouterMethod2["PATCH"] = "PATCH";
1145
- A_SERVER_TYPES__RouterMethod2["DEFAULT"] = "DEFAULT";
1146
- return A_SERVER_TYPES__RouterMethod2;
1147
- })(A_SERVER_TYPES__RouterMethod || {});
1148
- var A_SERVER_TYPES__ARouterComponentMetaKey = /* @__PURE__ */ ((A_SERVER_TYPES__ARouterComponentMetaKey2) => {
1149
- A_SERVER_TYPES__ARouterComponentMetaKey2["ROUTES"] = "ROUTES";
1150
- return A_SERVER_TYPES__ARouterComponentMetaKey2;
1151
- })(A_SERVER_TYPES__ARouterComponentMetaKey || {});
1152
- var _A_Router = class _A_Router extends aConcept.A_Component {
1153
- // =======================================================
1154
- // ================ Method Definition=====================
1155
- // =======================================================
1156
- /**
1157
- * Allows to define a custom route for POST requests
1158
- *
1159
- * @param path
1160
- * @returns
1161
- */
1162
- static Post(path2) {
1163
- return this.defineRoute({
1164
- method: "POST" /* POST */,
1165
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1166
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1167
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1168
- });
1169
- }
1170
- /**
1171
- * Allows to define a custom route for GET requests
1172
- *
1173
- * @param path
1174
- * @returns
1175
- */
1176
- static Get(path2) {
1177
- return this.defineRoute({
1178
- method: "GET" /* GET */,
1179
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1180
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1181
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1182
- });
1183
- }
1184
- /**
1185
- * Allows to define a custom route for PUT requests
1186
- *
1187
- * @param path
1188
- * @returns
1189
- */
1190
- static Put(path2) {
1191
- return this.defineRoute({
1192
- method: "PUT" /* PUT */,
1193
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1194
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1195
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1196
- });
1197
- }
1198
- /**
1199
- * Allows to define a custom route for DELETE requests
1200
- *
1201
- * @param path
1202
- * @returns
1203
- */
1204
- static Delete(path2) {
1205
- return this.defineRoute({
1206
- method: "DELETE" /* DELETE */,
1207
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1208
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1209
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1210
- });
1211
- }
1212
- /**
1213
- * Allows to define a custom route for PATCH requests
1214
- *
1215
- * @param path
1216
- * @returns
1217
- */
1218
- static Patch(path2) {
1219
- return this.defineRoute({
1220
- method: "PATCH" /* PATCH */,
1221
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1222
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1223
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1224
- });
1225
- }
1226
- /**
1227
- * Allows to define a custom route for DEFAULT requests
1228
- *
1229
- * @param path
1230
- * @returns
1231
- */
1232
- static Default(path2) {
1233
- return this.defineRoute({
1234
- method: "DEFAULT" /* DEFAULT */,
1235
- path: typeof path2 === "object" && "path" in path2 ? path2.path : path2,
1236
- version: typeof path2 === "object" && "version" in path2 && path2.version ? path2.version : "v1",
1237
- prefix: typeof path2 === "object" && "prefix" in path2 && path2.prefix ? path2.prefix : "api"
1238
- });
1239
- }
1240
- /**
1241
- * Private method to have the same signature for all route methods
1242
- *
1243
- * @param method
1244
- * @param path
1245
- * @returns
1246
- */
1247
- static defineRoute(config) {
1248
- const route = typeof config.path === "string" || config.path instanceof RegExp ? new A_Route(
1249
- `/${config.prefix}/${config.version}${config.path instanceof RegExp ? config.path.source : config.path.startsWith("/") ? config.path : `/${config.path}`}`,
1250
- config.method
1251
- ) : config.path;
1252
- this.routes.push(route);
1253
- return function decorator(target, propertyKey, descriptor) {
1254
- const meta = aConcept.A_Context.meta(target);
1255
- const routes = meta.get("ROUTES" /* ROUTES */) || /* @__PURE__ */ new Map();
1256
- const searchKey = route.toAFeatureExtension(["A_Router", "A_Service"]);
1257
- routes.set(searchKey.source, {
1258
- component: target,
1259
- handler: propertyKey,
1260
- route
1261
- });
1262
- meta.set("ROUTES" /* ROUTES */, routes);
1263
- aConcept.A_Feature_Define({
1264
- name: searchKey.source,
1265
- invoke: false
1266
- })(target, propertyKey, descriptor);
1267
- return aConcept.A_Feature_Extend(searchKey)(target, propertyKey, descriptor);
1268
- };
1269
- }
1270
- async load(logger) {
1271
- logger.routes(_A_Router.routes);
1272
- }
1273
- async identifyRoute(request, response, scope, config, logger) {
1274
- const route = request.route;
1275
- if (config.get("A_CONCEPT_ENVIRONMENT") === "development") {
1276
- logger.log(`Incoming request: ${request.method} ${request.url}`);
1277
- logger.log(`Identified route: ${route.toString()}`);
1278
- }
1279
- const feature = new aConcept.A_Feature({
1280
- name: route.toString(),
1281
- component: this
1282
- });
1283
- for (const stage of feature) {
1284
- if (aConcept.A_TypeGuards.isComponentConstructor(stage.definition.component)) {
1285
- const meta = aConcept.A_Context.meta(stage.definition.component);
1286
- const routes = meta.get("ROUTES" /* ROUTES */);
1287
- if (routes) {
1288
- const currentRoute = routes.get(stage.definition.name || "");
1289
- if (currentRoute) {
1290
- request.params = {
1291
- ...request.params,
1292
- ...currentRoute.route.extractParams(request.url)
1293
- };
1294
- }
1295
- }
1296
- }
1297
- const stageScope = new aConcept.A_Scope({
1298
- name: `a-route--${aConcept.A_IdentityHelper.generateTimeId()}`,
1299
- entities: [request]
1300
- }, {
1301
- parent: scope
1302
- });
1303
- await stage.process(stageScope);
1304
- }
1305
- console.log("Finished processing route for request:", request.method, request.url);
1306
- }
1307
- };
1308
- _A_Router.routes = [];
1309
- __decorateClass([
1310
- aConcept.A_Concept.Load(),
1311
- __decorateParam(0, aConcept.A_Inject(A_ServerLogger))
1312
- ], _A_Router.prototype, "load");
1313
- __decorateClass([
1314
- aConcept.A_Feature.Extend({
1315
- name: "onRequest" /* onRequest */,
1316
- scope: [A_Service]
1317
- }),
1318
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1319
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1320
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope)),
1321
- __decorateParam(3, aConcept.A_Inject(aUtils.A_Config)),
1322
- __decorateParam(4, aConcept.A_Inject(aUtils.A_Logger))
1323
- ], _A_Router.prototype, "identifyRoute");
1324
- var A_Router = _A_Router;
1325
- var A_EntityController = class extends aConcept.A_Component {
1326
- async list(request, response, factory, scope, config) {
1327
- const constructor = factory.resolveByName(request.params.type);
1328
- if (constructor) {
1329
- const entityList = new A_EntityList({
1330
- name: request.params.type,
1331
- scope: scope.name,
1332
- constructor
1333
- });
1334
- scope.register(entityList);
1335
- const queryFilter = new A_ListQueryFilter(request.query, {
1336
- itemsPerPage: String(config.get("A_LIST_ITEMS_PER_PAGE") || "10"),
1337
- page: String(config.get("A_LIST_PAGE") || "1")
1338
- });
1339
- const queryScope = new aConcept.A_Scope({
1340
- fragments: [queryFilter]
1341
- }).inherit(scope);
1342
- await entityList.load(queryScope);
1343
- response.add("items", entityList.items);
1344
- response.add("pagination", entityList.pagination);
1345
- }
1346
- }
1347
- async load(request, response, scope) {
1348
- if (!aConcept.ASEID.isASEID(request.params.aseid)) {
1349
- response.add("A_EntityController.load", "Invalid ASEID");
1350
- return;
1351
- }
1352
- const aseid = new aConcept.ASEID(request.params.aseid);
1353
- const constructor = scope.resolveConstructor(aseid.entity);
1354
- if (constructor) {
1355
- const entity = new constructor(request.params.aseid);
1356
- scope.register(entity);
1357
- await entity.load();
1358
- return response.status(200).json(entity.toJSON());
1359
- } else
1360
- throw new A_ServerError({
1361
- title: "Entity Not Found",
1362
- description: `Entity constructor for ASEID ${request.params.aseid} not found`,
1363
- status: 404
1364
- });
1365
- }
1366
- async create(request, factory, scope) {
1367
- const constructor = factory.resolve(request.params.aseid);
1368
- if (constructor) {
1369
- const entity = new constructor(request.body);
1370
- scope.register(entity);
1371
- await entity.save();
1372
- }
1373
- }
1374
- async update(request, response, factory, scope) {
1375
- if (!aConcept.ASEID.isASEID(request.params.aseid)) {
1376
- response.add("A_EntityController.update", "Invalid ASEID");
1377
- return;
1378
- }
1379
- const constructor = factory.resolve(request.params.aseid);
1380
- if (constructor) {
1381
- const entity = new constructor(request.body);
1382
- scope.register(entity);
1383
- await entity.save();
1384
- }
1385
- }
1386
- async delete(request, response, factory, scope) {
1387
- if (!aConcept.ASEID.isASEID(request.params.aseid)) {
1388
- response.add("A_EntityController.delete", "Invalid ASEID");
1389
- return;
1390
- }
1391
- const constructor = factory.resolve(request.params.aseid);
1392
- if (constructor) {
1393
- const entity = new constructor(request.params.aseid);
1394
- scope.register(entity);
1395
- await entity.destroy();
1396
- }
1397
- }
1398
- async callEntity(request, response, factory, scope) {
1399
- if (!aConcept.ASEID.isASEID(request.params.aseid)) {
1400
- response.add("A_EntityController.callEntity", "Invalid ASEID");
1401
- return;
1402
- }
1403
- const constructor = factory.resolve(request.params.aseid);
1404
- if (!constructor) {
1405
- response.add("A_EntityController.callEntity", "Entity not found");
1406
- return;
1407
- }
1408
- const meta = aConcept.A_Context.meta(constructor);
1409
- const targetFeature = meta.features().find((f) => f.name === `${constructor.name}.${request.params.action}`);
1410
- if (!targetFeature) {
1411
- response.add("A_EntityController.callEntity", "Feature not found");
1412
- return;
1413
- }
1414
- const entity = new constructor(request.params.aseid);
1415
- scope.register(entity);
1416
- await entity.load(scope);
1417
- await entity[targetFeature.handler](scope);
1418
- response.add("result", scope.toJSON());
1419
- response.add("entity", entity);
1420
- response.add("type", entity.aseid.entity);
1421
- }
1422
- };
1423
- __decorateClass([
1424
- A_Router.Get({
1425
- path: "/:type",
1426
- version: "v1",
1427
- prefix: "a-list"
1428
- }),
1429
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1430
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1431
- __decorateParam(2, aConcept.A_Inject(A_EntityFactory)),
1432
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Scope)),
1433
- __decorateParam(4, aConcept.A_Inject(aUtils.A_Config))
1434
- ], A_EntityController.prototype, "list");
1435
- __decorateClass([
1436
- aConcept.A_Feature.Define({
1437
- name: "getEntity",
1438
- invoke: false
1439
- }),
1440
- A_Router.Get({
1441
- path: "/:aseid",
1442
- version: "v1",
1443
- prefix: "a-entity"
1444
- }),
1445
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1446
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1447
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1448
- ], A_EntityController.prototype, "load");
1449
- __decorateClass([
1450
- A_Router.Post({
1451
- path: "/",
1452
- version: "v1",
1453
- prefix: "a-entity"
1454
- }),
1455
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1456
- __decorateParam(1, aConcept.A_Inject(A_EntityFactory)),
1457
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1458
- ], A_EntityController.prototype, "create");
1459
- __decorateClass([
1460
- A_Router.Put({
1461
- path: "/:aseid",
1462
- version: "v1",
1463
- prefix: "a-entity"
1464
- }),
1465
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1466
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1467
- __decorateParam(2, aConcept.A_Inject(A_EntityFactory)),
1468
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Scope))
1469
- ], A_EntityController.prototype, "update");
1470
- __decorateClass([
1471
- A_Router.Delete({
1472
- path: "/:aseid",
1473
- version: "v1",
1474
- prefix: "a-entity"
1475
- }),
1476
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1477
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1478
- __decorateParam(2, aConcept.A_Inject(A_EntityFactory)),
1479
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Scope))
1480
- ], A_EntityController.prototype, "delete");
1481
- __decorateClass([
1482
- A_Router.Post({
1483
- path: "/:aseid/:action",
1484
- version: "v1",
1485
- prefix: "a-entity"
1486
- }),
1487
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1488
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1489
- __decorateParam(2, aConcept.A_Inject(A_EntityFactory)),
1490
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Scope))
1491
- ], A_EntityController.prototype, "callEntity");
1492
- var A_ServerHealthMonitor = class extends aConcept.A_Component {
1493
- async get(config, request, response, logger) {
1494
- logger.log("Health check requested", config.get("A_CONCEPT_ROOT_FOLDER"));
1495
- const packageJSON = await import(`${config.get("A_CONCEPT_ROOT_FOLDER")}/package.json`);
1496
- const exposedProperties = config.get("EXPOSED_PROPERTIES")?.split(",") || [
1497
- "name",
1498
- "version",
1499
- "description"
1500
- ];
1501
- exposedProperties.forEach((prop) => response.add(prop, packageJSON[prop]));
1502
- console.log(`Health check accessed: ${request.method} ${request.url}`);
1503
- }
1504
- };
1505
- __decorateClass([
1506
- A_Router.Get({
1507
- path: "/",
1508
- prefix: "health",
1509
- version: "v1"
1510
- }),
1511
- __decorateParam(0, aConcept.A_Inject(aUtils.A_Config)),
1512
- __decorateParam(1, aConcept.A_Inject(A_Request)),
1513
- __decorateParam(2, aConcept.A_Inject(A_Response)),
1514
- __decorateParam(3, aConcept.A_Inject(aUtils.A_Logger))
1515
- ], A_ServerHealthMonitor.prototype, "get");
1516
- var A_ServerProxy = class extends aConcept.A_Component {
1517
- async load(logger, config) {
1518
- logger.log(
1519
- "pink",
1520
- `Proxy routes configured:`,
1521
- config.configs.map((c) => c.route).join("\n")
1522
- );
1523
- }
1524
- async onRequest(req, res, proxyConfig, logger, polyfill) {
1525
- return new Promise(async (resolve, reject) => {
1526
- const { method, url } = req;
1527
- const route = new A_Route(url, method);
1528
- const config = proxyConfig.config(route.toString());
1529
- if (!config) {
1530
- return resolve();
1531
- }
1532
- logger.log(
1533
- "yellow",
1534
- `Proxying request ${method} ${url} to ${config.hostname}`,
1535
- config
1536
- );
1537
- const client = await (config.protocol === "https:" ? polyfill.https() : polyfill.http());
1538
- const proxyReq = client.request(
1539
- {
1540
- method: config.route.method,
1541
- hostname: config.hostname,
1542
- port: config.port,
1543
- headers: config.headers,
1544
- path: route.path
1545
- },
1546
- (proxyRes) => {
1547
- if (!res.headersSent) {
1548
- res.writeHead(proxyRes.statusCode || 200, proxyRes.headers);
1549
- }
1550
- proxyRes.on("end", () => {
1551
- logger.log("green", `Proxy request to ${config?.hostname} completed`);
1552
- resolve();
1553
- });
1554
- proxyRes.pipe(res.original);
1555
- }
1556
- );
1557
- proxyReq.on("error", (err) => reject(err));
1558
- req.pipe(proxyReq);
1559
- });
1560
- }
1561
- };
1562
- __decorateClass([
1563
- aConcept.A_Concept.Load(),
1564
- __decorateParam(0, aConcept.A_Inject(aUtils.A_Logger)),
1565
- __decorateParam(1, aConcept.A_Inject(A_ProxyConfig))
1566
- ], A_ServerProxy.prototype, "load");
1567
- __decorateClass([
1568
- aConcept.A_Feature.Extend({
1569
- name: "onRequest" /* onRequest */
1570
- }),
1571
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1572
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1573
- __decorateParam(2, aConcept.A_Inject(A_ProxyConfig)),
1574
- __decorateParam(3, aConcept.A_Inject(aUtils.A_Logger)),
1575
- __decorateParam(4, aConcept.A_Inject(aUtils.A_Polyfill))
1576
- ], A_ServerProxy.prototype, "onRequest");
1577
-
1578
- // src/components/A-ServerCORS/A_ServerCORS.component.defaults.ts
1579
- var A_SERVER_DEFAULTS__CorsConfig = {
1580
- origin: "*",
1581
- // Default to allow all origins
1582
- methods: ["GET", "POST", "PUT", "DELETE", "OPTIONS"],
1583
- headers: ["Content-Type"],
1584
- credentials: false,
1585
- maxAge: 0
1586
- };
1587
- var A_ServerCORS = class extends aConcept.A_Component {
1588
- async init(config) {
1589
- this.config = {
1590
- origin: config.get("ORIGIN") || A_SERVER_DEFAULTS__CorsConfig.origin,
1591
- methods: config.get("METHODS") || A_SERVER_DEFAULTS__CorsConfig.methods,
1592
- headers: config.get("HEADERS") || A_SERVER_DEFAULTS__CorsConfig.headers,
1593
- credentials: config.get("CREDENTIALS") || A_SERVER_DEFAULTS__CorsConfig.credentials,
1594
- maxAge: config.get("MAX_AGE") || A_SERVER_DEFAULTS__CorsConfig.maxAge
1595
- };
1596
- }
1597
- apply(aReq, aRes) {
1598
- aRes.setHeader("Access-Control-Allow-Origin", this.config.origin);
1599
- aRes.setHeader("Access-Control-Allow-Methods", this.config.methods.join(", "));
1600
- aRes.setHeader("Access-Control-Allow-Headers", this.config.headers.join(", "));
1601
- if (this.config.credentials) {
1602
- aRes.setHeader("Access-Control-Allow-Credentials", "true");
1603
- }
1604
- if (this.config.maxAge) {
1605
- aRes.setHeader("Access-Control-Max-Age", this.config.maxAge.toString());
1606
- }
1607
- if (aReq.req.method === "OPTIONS") {
1608
- aRes.status(204).send();
1609
- }
1610
- }
1611
- };
1612
- __decorateClass([
1613
- aConcept.A_Feature.Extend({
1614
- name: "beforeStart" /* beforeStart */
1615
- }),
1616
- __decorateParam(0, aConcept.A_Inject(aUtils.A_Config))
1617
- ], A_ServerCORS.prototype, "init");
1618
- __decorateClass([
1619
- aConcept.A_Feature.Extend({
1620
- name: "beforeRequest" /* beforeRequest */
1621
- }),
1622
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1623
- __decorateParam(1, aConcept.A_Inject(A_Response))
1624
- ], A_ServerCORS.prototype, "apply");
1625
- var A_StaticLoader = class extends aConcept.A_Component {
1626
- async load(logger, config) {
1627
- logger.log(
1628
- "pink",
1629
- `Static directories configured:`,
1630
- config.directories.join("\n")
1631
- );
1632
- }
1633
- async onRequest(req, res, logger, config) {
1634
- if (req.method !== "GET" && req.method !== "HEAD") {
1635
- return;
1636
- }
1637
- const { method, url } = req;
1638
- const route = new A_Route(url, method);
1639
- const staticDirConfig = config.has(route.path);
1640
- if (!staticDirConfig) {
1641
- return;
1642
- }
1643
- const staticDir = path__default.default.resolve(process.cwd(), staticDirConfig);
1644
- if (!fs__default.default.existsSync(staticDir) || !fs__default.default.statSync(staticDir).isDirectory()) {
1645
- logger.log("red", `Static directory ${staticDir} does not exist or is not a directory.`);
1646
- return;
1647
- }
1648
- await this.serveFile(route.path.startsWith("/") ? route.path.slice(1) : route.path, res);
1649
- }
1650
- getMimeType(ext) {
1651
- const mimeTypes = {
1652
- ".html": "text/html",
1653
- ".js": "application/javascript",
1654
- ".css": "text/css",
1655
- ".json": "application/json",
1656
- ".png": "image/png",
1657
- ".jpg": "image/jpeg",
1658
- ".jpeg": "image/jpeg",
1659
- ".gif": "image/gif",
1660
- ".svg": "image/svg+xml",
1661
- ".ico": "image/x-icon",
1662
- ".txt": "text/plain"
1663
- };
1664
- return mimeTypes[ext.toLowerCase()] || "application/octet-stream";
1665
- }
1666
- safeFilePath(staticDir, reqUrl, host) {
1667
- const parsedUrl = new url.URL(reqUrl || "/", `http://${host || "localhost"}`);
1668
- let pathname = decodeURIComponent(parsedUrl.pathname);
1669
- pathname = pathname.replace(/\.\.[\/\\]/g, "");
1670
- let filePath = path__default.default.join(staticDir, pathname);
1671
- if (!fs__default.default.existsSync(filePath))
1672
- throw new Error(`File not found: ${filePath}`);
1673
- return filePath;
1674
- }
1675
- serveFile(filePath, res) {
1676
- return new Promise((resolve, reject) => {
1677
- if (fs__default.default.existsSync(filePath)) {
1678
- const ext = path__default.default.extname(filePath);
1679
- const contentType = this.getMimeType(ext);
1680
- res.writeHead(200, { "Content-Type": contentType });
1681
- const stream = fs__default.default.createReadStream(filePath);
1682
- stream.pipe(res.original);
1683
- stream.on("end", () => {
1684
- resolve();
1685
- });
1686
- stream.on("error", (err) => {
1687
- reject(new Error(`File stream error: ${err.message}`));
1688
- });
1689
- } else {
1690
- reject(new Error(`File not found: ${filePath}`));
1691
- }
1692
- resolve();
1693
- });
1694
- }
1695
- };
1696
- __decorateClass([
1697
- aConcept.A_Concept.Load(),
1698
- __decorateParam(0, aConcept.A_Inject(aUtils.A_Logger)),
1699
- __decorateParam(1, aConcept.A_Inject(A_StaticConfig))
1700
- ], A_StaticLoader.prototype, "load");
1701
- __decorateClass([
1702
- aConcept.A_Feature.Extend({
1703
- name: "onRequest" /* onRequest */
1704
- }),
1705
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1706
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1707
- __decorateParam(2, aConcept.A_Inject(aUtils.A_Logger)),
1708
- __decorateParam(3, aConcept.A_Inject(A_StaticConfig))
1709
- ], A_StaticLoader.prototype, "onRequest");
1710
- var A_Controller = class extends aConcept.A_Component {
1711
- async callEntityMethod(request, response, scope) {
1712
- if (!scope.has(request.params.component))
1713
- return;
1714
- if (!request.params.operation || typeof request.params.operation !== "string")
1715
- return;
1716
- const possibleComponent = scope.resolve(request.params.component);
1717
- if (!possibleComponent || ![aConcept.A_Component, aConcept.A_Container].some((c) => possibleComponent instanceof c))
1718
- return;
1719
- const component = possibleComponent;
1720
- const meta = aConcept.A_Context.meta(component);
1721
- const targetFeature = meta.features().find((f) => f.name === `${component.constructor.name}.${request.params.operation}`);
1722
- if (!targetFeature)
1723
- return;
1724
- await component.call(request.params.operation, scope);
1725
- }
1726
- };
1727
- __decorateClass([
1728
- A_Router.Post({
1729
- path: "/:component/:operation",
1730
- version: "v1",
1731
- prefix: "a-component"
1732
- }),
1733
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1734
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1735
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1736
- ], A_Controller.prototype, "callEntityMethod");
1737
- var A_ListingController = class extends aConcept.A_Component {
1738
- async list(request, response, factory, scope, config) {
1739
- const constructor = factory.resolveByName(request.params.type);
1740
- if (constructor) {
1741
- const entityList = new A_EntityList({
1742
- name: request.params.type,
1743
- scope: scope.name,
1744
- constructor
1745
- });
1746
- scope.register(entityList);
1747
- const queryFilter = new A_ListQueryFilter(request.query, {
1748
- itemsPerPage: String(config.get("A_LIST_ITEMS_PER_PAGE") || "10"),
1749
- page: String(config.get("A_LIST_PAGE") || "1")
1750
- });
1751
- const queryScope = new aConcept.A_Scope({
1752
- fragments: [queryFilter]
1753
- }).inherit(scope);
1754
- await entityList.load(queryScope);
1755
- response.add("items", entityList.items);
1756
- response.add("pagination", entityList.pagination);
1757
- }
1758
- }
1759
- };
1760
- __decorateClass([
1761
- A_Router.Get({
1762
- path: "/:type",
1763
- version: "v1",
1764
- prefix: "a-list"
1765
- }),
1766
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1767
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1768
- __decorateParam(2, aConcept.A_Inject(A_EntityFactory)),
1769
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Scope)),
1770
- __decorateParam(4, aConcept.A_Inject(aUtils.A_Config))
1771
- ], A_ListingController.prototype, "list");
1772
- var A_CommandController = class extends aConcept.A_Component {
1773
- async handleCommand(req, res, scope, container) {
1774
- const commandName = req.params.command;
1775
- const CommandConstructor = scope.resolveConstructor(commandName);
1776
- if (!CommandConstructor) {
1777
- res.status(404);
1778
- throw new Error(`Command ${commandName} not found`);
1779
- }
1780
- const command = new CommandConstructor(req.body);
1781
- container.scope.register(command);
1782
- await command.execute();
1783
- const serialized = command.toJSON();
1784
- return res.status(200).json(serialized);
1785
- }
1786
- };
1787
- __decorateClass([
1788
- A_Router.Get({
1789
- path: "/:command/execute",
1790
- version: "v1",
1791
- prefix: "a-command"
1792
- }),
1793
- __decorateParam(0, aConcept.A_Inject(A_Request)),
1794
- __decorateParam(1, aConcept.A_Inject(A_Response)),
1795
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope)),
1796
- __decorateParam(3, aConcept.A_Inject(aConcept.A_Container))
1797
- ], A_CommandController.prototype, "handleCommand");
1798
- var A_EntityRepository = class extends aConcept.A_Component {
1799
- async list(channel, entity, scope) {
1800
- if (scope.has(aUtils.A_Manifest) && !scope.resolve(aUtils.A_Manifest).isAllowed(entity.constructor, "load").for(entity.constructor))
1801
- return;
1802
- const response = await channel.get(`/a-list/${entity.aseid.entity}`);
1803
- entity.fromJSON(response.data);
1804
- }
1805
- async load(channel, entity, scope) {
1806
- if (scope.has(aUtils.A_Manifest) && !scope.resolve(aUtils.A_Manifest).isAllowed(entity.constructor, "load").for(entity.constructor))
1807
- return;
1808
- const response = await channel.get(`/a-entity/${entity.aseid.toString()}`);
1809
- entity.fromJSON(response.data);
1810
- }
1811
- async save(channel, entity, scope) {
1812
- if (scope.has(aUtils.A_Manifest) && !scope.resolve(aUtils.A_Manifest).isAllowed(entity.constructor, "save").for(entity.constructor))
1813
- return;
1814
- const response = await channel.post(`/a-entity/${entity.aseid.toString()}`, entity.toJSON());
1815
- entity.fromJSON(response.data);
1816
- }
1817
- async destroy(channel, entity, scope) {
1818
- if (scope.has(aUtils.A_Manifest) && !scope.resolve(aUtils.A_Manifest).isAllowed(entity.constructor, "destroy").for(entity.constructor))
1819
- return;
1820
- const response = await channel.delete(`/a-entity/${entity.aseid.toString()}`);
1821
- entity.fromJSON(response.data);
1822
- }
1823
- };
1824
- __decorateClass([
1825
- aConcept.A_Feature.Extend({
1826
- name: AEntity_constants.A_TYPES__EntityFeatures.LOAD,
1827
- scope: {
1828
- include: [A_EntityList]
1829
- }
1830
- }),
1831
- __decorateParam(0, aConcept.A_Inject(A_HTTPChannel)),
1832
- __decorateParam(1, aConcept.A_Inject(aConcept.A_Caller)),
1833
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1834
- ], A_EntityRepository.prototype, "list");
1835
- __decorateClass([
1836
- aConcept.A_Feature.Extend({
1837
- name: AEntity_constants.A_TYPES__EntityFeatures.LOAD,
1838
- scope: {
1839
- exclude: [A_EntityList]
1840
- }
1841
- }),
1842
- __decorateParam(0, aConcept.A_Inject(A_HTTPChannel)),
1843
- __decorateParam(1, aConcept.A_Inject(aConcept.A_Caller)),
1844
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1845
- ], A_EntityRepository.prototype, "load");
1846
- __decorateClass([
1847
- aConcept.A_Feature.Extend({
1848
- name: AEntity_constants.A_TYPES__EntityFeatures.SAVE,
1849
- scope: {
1850
- exclude: [A_EntityList]
1851
- }
1852
- }),
1853
- __decorateParam(0, aConcept.A_Inject(A_HTTPChannel)),
1854
- __decorateParam(1, aConcept.A_Inject(aConcept.A_Caller)),
1855
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1856
- ], A_EntityRepository.prototype, "save");
1857
- __decorateClass([
1858
- aConcept.A_Feature.Extend({
1859
- name: AEntity_constants.A_TYPES__EntityFeatures.DESTROY,
1860
- scope: {
1861
- exclude: [A_EntityList]
1862
- }
1863
- }),
1864
- __decorateParam(0, aConcept.A_Inject(A_HTTPChannel)),
1865
- __decorateParam(1, aConcept.A_Inject(aConcept.A_Caller)),
1866
- __decorateParam(2, aConcept.A_Inject(aConcept.A_Scope))
1867
- ], A_EntityRepository.prototype, "destroy");
1868
-
1869
- exports.A_CommandController = A_CommandController;
1870
- exports.A_Controller = A_Controller;
1871
- exports.A_EntityController = A_EntityController;
1872
- exports.A_EntityFactory = A_EntityFactory;
1873
- exports.A_EntityList = A_EntityList;
1874
- exports.A_EntityRepository = A_EntityRepository;
1875
- exports.A_HTTPChannel = A_HTTPChannel;
1876
- exports.A_HTTPChannelError = A_HTTPChannelError;
1877
- exports.A_HTTPChannel_RequestContext = A_HTTPChannel_RequestContext;
1878
- exports.A_ListQueryFilter = A_ListQueryFilter;
1879
- exports.A_ListingController = A_ListingController;
1880
- exports.A_ProxyConfig = A_ProxyConfig;
1881
- exports.A_Request = A_Request;
1882
- exports.A_Response = A_Response;
1883
- exports.A_Route = A_Route;
1884
- exports.A_Router = A_Router;
1885
- exports.A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle = A_SERVER_CONSTANTS__A_HttpChannel_Lifecycle;
1886
- exports.A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES = A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES;
1887
- exports.A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY = A_SERVER_CONSTANTS__DEFAULT_ENV_VARIABLES_ARRAY;
1888
- exports.A_SERVER_TYPES__ARouterComponentMetaKey = A_SERVER_TYPES__ARouterComponentMetaKey;
1889
- exports.A_SERVER_TYPES__RequestEvent = A_SERVER_TYPES__RequestEvent;
1890
- exports.A_SERVER_TYPES__ResponseEvent = A_SERVER_TYPES__ResponseEvent;
1891
- exports.A_SERVER_TYPES__RouterMethod = A_SERVER_TYPES__RouterMethod;
1892
- exports.A_SERVER_TYPES__ServerFeature = A_SERVER_TYPES__ServerFeature;
1893
- exports.A_SERVER_TYPES__ServerMethod = A_SERVER_TYPES__ServerMethod;
1894
- exports.A_Server = A_Server;
1895
- exports.A_ServerCORS = A_ServerCORS;
1896
- exports.A_ServerError = A_ServerError;
1897
- exports.A_ServerHealthMonitor = A_ServerHealthMonitor;
1898
- exports.A_ServerLogger = A_ServerLogger;
1899
- exports.A_ServerProxy = A_ServerProxy;
1900
- exports.A_Service = A_Service;
1901
- exports.A_StaticConfig = A_StaticConfig;
1902
- exports.A_StaticLoader = A_StaticLoader;
1903
- //# sourceMappingURL=index.js.map
1904
- //# sourceMappingURL=index.js.map