@zyno-io/dk-server-foundation 26.216.430

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 (663) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +458 -0
  3. package/dist/devconsole/assets/index-CKF3C3kv.css +1 -0
  4. package/dist/devconsole/assets/index-CsHdomhM.js +27 -0
  5. package/dist/devconsole/index.html +13 -0
  6. package/dist/resources/proto/generated/devconsole/devconsole.d.ts +320 -0
  7. package/dist/resources/proto/generated/devconsole/devconsole.d.ts.map +1 -0
  8. package/dist/resources/proto/generated/devconsole/devconsole.js +3751 -0
  9. package/dist/resources/proto/generated/devconsole/devconsole.js.map +1 -0
  10. package/dist/src/app/base.d.ts +36 -0
  11. package/dist/src/app/base.d.ts.map +1 -0
  12. package/dist/src/app/base.js +240 -0
  13. package/dist/src/app/base.js.map +1 -0
  14. package/dist/src/app/config.d.ts +90 -0
  15. package/dist/src/app/config.d.ts.map +1 -0
  16. package/dist/src/app/config.js +33 -0
  17. package/dist/src/app/config.js.map +1 -0
  18. package/dist/src/app/config.loader.d.ts +14 -0
  19. package/dist/src/app/config.loader.d.ts.map +1 -0
  20. package/dist/src/app/config.loader.js +67 -0
  21. package/dist/src/app/config.loader.js.map +1 -0
  22. package/dist/src/app/const.d.ts +3 -0
  23. package/dist/src/app/const.d.ts.map +1 -0
  24. package/dist/src/app/const.js +6 -0
  25. package/dist/src/app/const.js.map +1 -0
  26. package/dist/src/app/dev.d.ts +7 -0
  27. package/dist/src/app/dev.d.ts.map +1 -0
  28. package/dist/src/app/dev.js +105 -0
  29. package/dist/src/app/dev.js.map +1 -0
  30. package/dist/src/app/index.d.ts +7 -0
  31. package/dist/src/app/index.d.ts.map +1 -0
  32. package/dist/src/app/index.js +12 -0
  33. package/dist/src/app/index.js.map +1 -0
  34. package/dist/src/app/openapi.d.ts +4 -0
  35. package/dist/src/app/openapi.d.ts.map +1 -0
  36. package/dist/src/app/openapi.js +6 -0
  37. package/dist/src/app/openapi.js.map +1 -0
  38. package/dist/src/app/resolver.d.ts +11 -0
  39. package/dist/src/app/resolver.d.ts.map +1 -0
  40. package/dist/src/app/resolver.js +60 -0
  41. package/dist/src/app/resolver.js.map +1 -0
  42. package/dist/src/app/shutdown.d.ts +12 -0
  43. package/dist/src/app/shutdown.d.ts.map +1 -0
  44. package/dist/src/app/shutdown.js +63 -0
  45. package/dist/src/app/shutdown.js.map +1 -0
  46. package/dist/src/app/state.d.ts +16 -0
  47. package/dist/src/app/state.d.ts.map +1 -0
  48. package/dist/src/app/state.js +12 -0
  49. package/dist/src/app/state.js.map +1 -0
  50. package/dist/src/auth/index.d.ts +3 -0
  51. package/dist/src/auth/index.d.ts.map +1 -0
  52. package/dist/src/auth/index.js +6 -0
  53. package/dist/src/auth/index.js.map +1 -0
  54. package/dist/src/auth/jwt.d.ts +76 -0
  55. package/dist/src/auth/jwt.d.ts.map +1 -0
  56. package/dist/src/auth/jwt.js +218 -0
  57. package/dist/src/auth/jwt.js.map +1 -0
  58. package/dist/src/auth/provider.d.ts +15 -0
  59. package/dist/src/auth/provider.d.ts.map +1 -0
  60. package/dist/src/auth/provider.js +50 -0
  61. package/dist/src/auth/provider.js.map +1 -0
  62. package/dist/src/cli/dksf-dev.d.ts +3 -0
  63. package/dist/src/cli/dksf-dev.d.ts.map +1 -0
  64. package/dist/src/cli/dksf-dev.js +408 -0
  65. package/dist/src/cli/dksf-dev.js.map +1 -0
  66. package/dist/src/cli/dksf-gen-proto.d.ts +3 -0
  67. package/dist/src/cli/dksf-gen-proto.d.ts.map +1 -0
  68. package/dist/src/cli/dksf-gen-proto.js +164 -0
  69. package/dist/src/cli/dksf-gen-proto.js.map +1 -0
  70. package/dist/src/cli/dksf-install.d.ts +3 -0
  71. package/dist/src/cli/dksf-install.d.ts.map +1 -0
  72. package/dist/src/cli/dksf-install.js +10 -0
  73. package/dist/src/cli/dksf-install.js.map +1 -0
  74. package/dist/src/cli/dksf-test.d.ts +3 -0
  75. package/dist/src/cli/dksf-test.d.ts.map +1 -0
  76. package/dist/src/cli/dksf-test.js +78 -0
  77. package/dist/src/cli/dksf-test.js.map +1 -0
  78. package/dist/src/cli/dksf-update.d.ts +3 -0
  79. package/dist/src/cli/dksf-update.d.ts.map +1 -0
  80. package/dist/src/cli/dksf-update.js +86 -0
  81. package/dist/src/cli/dksf-update.js.map +1 -0
  82. package/dist/src/database/common.d.ts +84 -0
  83. package/dist/src/database/common.d.ts.map +1 -0
  84. package/dist/src/database/common.js +380 -0
  85. package/dist/src/database/common.js.map +1 -0
  86. package/dist/src/database/dialect.d.ts +10 -0
  87. package/dist/src/database/dialect.d.ts.map +1 -0
  88. package/dist/src/database/dialect.js +56 -0
  89. package/dist/src/database/dialect.js.map +1 -0
  90. package/dist/src/database/entity.d.ts +62 -0
  91. package/dist/src/database/entity.d.ts.map +1 -0
  92. package/dist/src/database/entity.js +198 -0
  93. package/dist/src/database/entity.js.map +1 -0
  94. package/dist/src/database/index.d.ts +8 -0
  95. package/dist/src/database/index.d.ts.map +1 -0
  96. package/dist/src/database/index.js +15 -0
  97. package/dist/src/database/index.js.map +1 -0
  98. package/dist/src/database/migration/MigrationResetCommand.d.ts +9 -0
  99. package/dist/src/database/migration/MigrationResetCommand.d.ts.map +1 -0
  100. package/dist/src/database/migration/MigrationResetCommand.js +75 -0
  101. package/dist/src/database/migration/MigrationResetCommand.js.map +1 -0
  102. package/dist/src/database/migration/MigrationRunCommand.d.ts +11 -0
  103. package/dist/src/database/migration/MigrationRunCommand.d.ts.map +1 -0
  104. package/dist/src/database/migration/MigrationRunCommand.js +118 -0
  105. package/dist/src/database/migration/MigrationRunCommand.js.map +1 -0
  106. package/dist/src/database/migration/characters.d.ts +14 -0
  107. package/dist/src/database/migration/characters.d.ts.map +1 -0
  108. package/dist/src/database/migration/characters.js +56 -0
  109. package/dist/src/database/migration/characters.js.map +1 -0
  110. package/dist/src/database/migration/create/MigrationCreateCommand.d.ts +11 -0
  111. package/dist/src/database/migration/create/MigrationCreateCommand.d.ts.map +1 -0
  112. package/dist/src/database/migration/create/MigrationCreateCommand.js +106 -0
  113. package/dist/src/database/migration/create/MigrationCreateCommand.js.map +1 -0
  114. package/dist/src/database/migration/create/comparator.d.ts +3 -0
  115. package/dist/src/database/migration/create/comparator.d.ts.map +1 -0
  116. package/dist/src/database/migration/create/comparator.js +408 -0
  117. package/dist/src/database/migration/create/comparator.js.map +1 -0
  118. package/dist/src/database/migration/create/db-reader.d.ts +5 -0
  119. package/dist/src/database/migration/create/db-reader.d.ts.map +1 -0
  120. package/dist/src/database/migration/create/db-reader.js +473 -0
  121. package/dist/src/database/migration/create/db-reader.js.map +1 -0
  122. package/dist/src/database/migration/create/ddl-generator.d.ts +3 -0
  123. package/dist/src/database/migration/create/ddl-generator.d.ts.map +1 -0
  124. package/dist/src/database/migration/create/ddl-generator.js +725 -0
  125. package/dist/src/database/migration/create/ddl-generator.js.map +1 -0
  126. package/dist/src/database/migration/create/entity-reader.d.ts +4 -0
  127. package/dist/src/database/migration/create/entity-reader.d.ts.map +1 -0
  128. package/dist/src/database/migration/create/entity-reader.js +417 -0
  129. package/dist/src/database/migration/create/entity-reader.js.map +1 -0
  130. package/dist/src/database/migration/create/file-generator.d.ts +3 -0
  131. package/dist/src/database/migration/create/file-generator.d.ts.map +1 -0
  132. package/dist/src/database/migration/create/file-generator.js +62 -0
  133. package/dist/src/database/migration/create/file-generator.js.map +1 -0
  134. package/dist/src/database/migration/create/prompt.d.ts +4 -0
  135. package/dist/src/database/migration/create/prompt.d.ts.map +1 -0
  136. package/dist/src/database/migration/create/prompt.js +55 -0
  137. package/dist/src/database/migration/create/prompt.js.map +1 -0
  138. package/dist/src/database/migration/create/schema-model.d.ts +109 -0
  139. package/dist/src/database/migration/create/schema-model.d.ts.map +1 -0
  140. package/dist/src/database/migration/create/schema-model.js +24 -0
  141. package/dist/src/database/migration/create/schema-model.js.map +1 -0
  142. package/dist/src/database/migration/helpers.d.ts +3 -0
  143. package/dist/src/database/migration/helpers.d.ts.map +1 -0
  144. package/dist/src/database/migration/helpers.js +13 -0
  145. package/dist/src/database/migration/helpers.js.map +1 -0
  146. package/dist/src/database/migration/index.d.ts +9 -0
  147. package/dist/src/database/migration/index.d.ts.map +1 -0
  148. package/dist/src/database/migration/index.js +43 -0
  149. package/dist/src/database/migration/index.js.map +1 -0
  150. package/dist/src/database/migration/migration.entity.d.ts +8 -0
  151. package/dist/src/database/migration/migration.entity.d.ts.map +1 -0
  152. package/dist/src/database/migration/migration.entity.js +16 -0
  153. package/dist/src/database/migration/migration.entity.js.map +1 -0
  154. package/dist/src/database/mysql.d.ts +16 -0
  155. package/dist/src/database/mysql.d.ts.map +1 -0
  156. package/dist/src/database/mysql.js +140 -0
  157. package/dist/src/database/mysql.js.map +1 -0
  158. package/dist/src/database/postgres.d.ts +16 -0
  159. package/dist/src/database/postgres.d.ts.map +1 -0
  160. package/dist/src/database/postgres.js +91 -0
  161. package/dist/src/database/postgres.js.map +1 -0
  162. package/dist/src/database/types.d.ts +21 -0
  163. package/dist/src/database/types.d.ts.map +1 -0
  164. package/dist/src/database/types.js +27 -0
  165. package/dist/src/database/types.js.map +1 -0
  166. package/dist/src/devconsole/devconsole.controller.d.ts +7 -0
  167. package/dist/src/devconsole/devconsole.controller.d.ts.map +1 -0
  168. package/dist/src/devconsole/devconsole.controller.js +82 -0
  169. package/dist/src/devconsole/devconsole.controller.js.map +1 -0
  170. package/dist/src/devconsole/devconsole.middleware.d.ts +12 -0
  171. package/dist/src/devconsole/devconsole.middleware.d.ts.map +1 -0
  172. package/dist/src/devconsole/devconsole.middleware.js +28 -0
  173. package/dist/src/devconsole/devconsole.middleware.js.map +1 -0
  174. package/dist/src/devconsole/devconsole.srpc.d.ts +14 -0
  175. package/dist/src/devconsole/devconsole.srpc.d.ts.map +1 -0
  176. package/dist/src/devconsole/devconsole.srpc.js +94 -0
  177. package/dist/src/devconsole/devconsole.srpc.js.map +1 -0
  178. package/dist/src/devconsole/devconsole.store.d.ts +101 -0
  179. package/dist/src/devconsole/devconsole.store.d.ts.map +1 -0
  180. package/dist/src/devconsole/devconsole.store.js +125 -0
  181. package/dist/src/devconsole/devconsole.store.js.map +1 -0
  182. package/dist/src/devconsole/devconsole.ws.d.ts +18 -0
  183. package/dist/src/devconsole/devconsole.ws.d.ts.map +1 -0
  184. package/dist/src/devconsole/devconsole.ws.js +470 -0
  185. package/dist/src/devconsole/devconsole.ws.js.map +1 -0
  186. package/dist/src/devconsole/index.d.ts +2 -0
  187. package/dist/src/devconsole/index.d.ts.map +1 -0
  188. package/dist/src/devconsole/index.js +6 -0
  189. package/dist/src/devconsole/index.js.map +1 -0
  190. package/dist/src/devconsole/patches.d.ts +6 -0
  191. package/dist/src/devconsole/patches.d.ts.map +1 -0
  192. package/dist/src/devconsole/patches.js +397 -0
  193. package/dist/src/devconsole/patches.js.map +1 -0
  194. package/dist/src/health/health.module.d.ts +6 -0
  195. package/dist/src/health/health.module.d.ts.map +1 -0
  196. package/dist/src/health/health.module.js +32 -0
  197. package/dist/src/health/health.module.js.map +1 -0
  198. package/dist/src/health/healthcheck.controller.d.ts +10 -0
  199. package/dist/src/health/healthcheck.controller.d.ts.map +1 -0
  200. package/dist/src/health/healthcheck.controller.js +30 -0
  201. package/dist/src/health/healthcheck.controller.js.map +1 -0
  202. package/dist/src/health/healthcheck.service.d.ts +13 -0
  203. package/dist/src/health/healthcheck.service.d.ts.map +1 -0
  204. package/dist/src/health/healthcheck.service.js +33 -0
  205. package/dist/src/health/healthcheck.service.js.map +1 -0
  206. package/dist/src/health/index.d.ts +3 -0
  207. package/dist/src/health/index.d.ts.map +1 -0
  208. package/dist/src/health/index.js +6 -0
  209. package/dist/src/health/index.js.map +1 -0
  210. package/dist/src/helpers/async/context.d.ts +11 -0
  211. package/dist/src/helpers/async/context.d.ts.map +1 -0
  212. package/dist/src/helpers/async/context.js +75 -0
  213. package/dist/src/helpers/async/context.js.map +1 -0
  214. package/dist/src/helpers/async/process.d.ts +16 -0
  215. package/dist/src/helpers/async/process.d.ts.map +1 -0
  216. package/dist/src/helpers/async/process.js +44 -0
  217. package/dist/src/helpers/async/process.js.map +1 -0
  218. package/dist/src/helpers/async/promise.d.ts +5 -0
  219. package/dist/src/helpers/async/promise.d.ts.map +1 -0
  220. package/dist/src/helpers/async/promise.js +27 -0
  221. package/dist/src/helpers/async/promise.js.map +1 -0
  222. package/dist/src/helpers/data/array.d.ts +3 -0
  223. package/dist/src/helpers/data/array.d.ts.map +1 -0
  224. package/dist/src/helpers/data/array.js +17 -0
  225. package/dist/src/helpers/data/array.js.map +1 -0
  226. package/dist/src/helpers/data/objects.d.ts +12 -0
  227. package/dist/src/helpers/data/objects.d.ts.map +1 -0
  228. package/dist/src/helpers/data/objects.js +75 -0
  229. package/dist/src/helpers/data/objects.js.map +1 -0
  230. package/dist/src/helpers/data/serialization.d.ts +4 -0
  231. package/dist/src/helpers/data/serialization.d.ts.map +1 -0
  232. package/dist/src/helpers/data/serialization.js +15 -0
  233. package/dist/src/helpers/data/serialization.js.map +1 -0
  234. package/dist/src/helpers/data/transformer.d.ts +13 -0
  235. package/dist/src/helpers/data/transformer.d.ts.map +1 -0
  236. package/dist/src/helpers/data/transformer.js +55 -0
  237. package/dist/src/helpers/data/transformer.js.map +1 -0
  238. package/dist/src/helpers/framework/decorators.d.ts +5 -0
  239. package/dist/src/helpers/framework/decorators.d.ts.map +1 -0
  240. package/dist/src/helpers/framework/decorators.js +39 -0
  241. package/dist/src/helpers/framework/decorators.js.map +1 -0
  242. package/dist/src/helpers/framework/event.d.ts +3 -0
  243. package/dist/src/helpers/framework/event.d.ts.map +1 -0
  244. package/dist/src/helpers/framework/event.js +20 -0
  245. package/dist/src/helpers/framework/event.js.map +1 -0
  246. package/dist/src/helpers/framework/injection.d.ts +7 -0
  247. package/dist/src/helpers/framework/injection.d.ts.map +1 -0
  248. package/dist/src/helpers/framework/injection.js +52 -0
  249. package/dist/src/helpers/framework/injection.js.map +1 -0
  250. package/dist/src/helpers/index.d.ts +22 -0
  251. package/dist/src/helpers/index.d.ts.map +1 -0
  252. package/dist/src/helpers/index.js +32 -0
  253. package/dist/src/helpers/index.js.map +1 -0
  254. package/dist/src/helpers/io/package.d.ts +5 -0
  255. package/dist/src/helpers/io/package.d.ts.map +1 -0
  256. package/dist/src/helpers/io/package.js +31 -0
  257. package/dist/src/helpers/io/package.js.map +1 -0
  258. package/dist/src/helpers/io/stream.d.ts +18 -0
  259. package/dist/src/helpers/io/stream.d.ts.map +1 -0
  260. package/dist/src/helpers/io/stream.js +91 -0
  261. package/dist/src/helpers/io/stream.js.map +1 -0
  262. package/dist/src/helpers/redis/broadcast.d.ts +13 -0
  263. package/dist/src/helpers/redis/broadcast.d.ts.map +1 -0
  264. package/dist/src/helpers/redis/broadcast.js +100 -0
  265. package/dist/src/helpers/redis/broadcast.js.map +1 -0
  266. package/dist/src/helpers/redis/cache.d.ts +7 -0
  267. package/dist/src/helpers/redis/cache.d.ts.map +1 -0
  268. package/dist/src/helpers/redis/cache.js +28 -0
  269. package/dist/src/helpers/redis/cache.js.map +1 -0
  270. package/dist/src/helpers/redis/mutex.d.ts +24 -0
  271. package/dist/src/helpers/redis/mutex.d.ts.map +1 -0
  272. package/dist/src/helpers/redis/mutex.js +240 -0
  273. package/dist/src/helpers/redis/mutex.js.map +1 -0
  274. package/dist/src/helpers/redis/redis.d.ts +11 -0
  275. package/dist/src/helpers/redis/redis.d.ts.map +1 -0
  276. package/dist/src/helpers/redis/redis.js +59 -0
  277. package/dist/src/helpers/redis/redis.js.map +1 -0
  278. package/dist/src/helpers/security/crypto.d.ts +26 -0
  279. package/dist/src/helpers/security/crypto.d.ts.map +1 -0
  280. package/dist/src/helpers/security/crypto.js +121 -0
  281. package/dist/src/helpers/security/crypto.js.map +1 -0
  282. package/dist/src/helpers/security/validation.d.ts +4 -0
  283. package/dist/src/helpers/security/validation.d.ts.map +1 -0
  284. package/dist/src/helpers/security/validation.js +25 -0
  285. package/dist/src/helpers/security/validation.js.map +1 -0
  286. package/dist/src/helpers/utils/date.d.ts +4 -0
  287. package/dist/src/helpers/utils/date.d.ts.map +1 -0
  288. package/dist/src/helpers/utils/date.js +23 -0
  289. package/dist/src/helpers/utils/date.js.map +1 -0
  290. package/dist/src/helpers/utils/error.d.ts +24 -0
  291. package/dist/src/helpers/utils/error.d.ts.map +1 -0
  292. package/dist/src/helpers/utils/error.js +168 -0
  293. package/dist/src/helpers/utils/error.js.map +1 -0
  294. package/dist/src/helpers/utils/jsx.d.ts +3 -0
  295. package/dist/src/helpers/utils/jsx.d.ts.map +1 -0
  296. package/dist/src/helpers/utils/jsx.js +13 -0
  297. package/dist/src/helpers/utils/jsx.js.map +1 -0
  298. package/dist/src/helpers/utils/uuid.d.ts +3 -0
  299. package/dist/src/helpers/utils/uuid.d.ts.map +1 -0
  300. package/dist/src/helpers/utils/uuid.js +14 -0
  301. package/dist/src/helpers/utils/uuid.js.map +1 -0
  302. package/dist/src/http/auth.d.ts +46 -0
  303. package/dist/src/http/auth.d.ts.map +1 -0
  304. package/dist/src/http/auth.js +162 -0
  305. package/dist/src/http/auth.js.map +1 -0
  306. package/dist/src/http/context.d.ts +5 -0
  307. package/dist/src/http/context.d.ts.map +1 -0
  308. package/dist/src/http/context.js +22 -0
  309. package/dist/src/http/context.js.map +1 -0
  310. package/dist/src/http/cors.d.ts +36 -0
  311. package/dist/src/http/cors.d.ts.map +1 -0
  312. package/dist/src/http/cors.js +171 -0
  313. package/dist/src/http/cors.js.map +1 -0
  314. package/dist/src/http/errors.d.ts +3 -0
  315. package/dist/src/http/errors.d.ts.map +1 -0
  316. package/dist/src/http/errors.js +10 -0
  317. package/dist/src/http/errors.js.map +1 -0
  318. package/dist/src/http/index.d.ts +24 -0
  319. package/dist/src/http/index.d.ts.map +1 -0
  320. package/dist/src/http/index.js +25 -0
  321. package/dist/src/http/index.js.map +1 -0
  322. package/dist/src/http/kernel.d.ts +17 -0
  323. package/dist/src/http/kernel.d.ts.map +1 -0
  324. package/dist/src/http/kernel.js +133 -0
  325. package/dist/src/http/kernel.js.map +1 -0
  326. package/dist/src/http/middleware.d.ts +12 -0
  327. package/dist/src/http/middleware.d.ts.map +1 -0
  328. package/dist/src/http/middleware.js +61 -0
  329. package/dist/src/http/middleware.js.map +1 -0
  330. package/dist/src/http/overrides.d.ts +2 -0
  331. package/dist/src/http/overrides.d.ts.map +1 -0
  332. package/dist/src/http/overrides.js +19 -0
  333. package/dist/src/http/overrides.js.map +1 -0
  334. package/dist/src/http/store.d.ts +33 -0
  335. package/dist/src/http/store.d.ts.map +1 -0
  336. package/dist/src/http/store.js +102 -0
  337. package/dist/src/http/store.js.map +1 -0
  338. package/dist/src/http/uploads.d.ts +7 -0
  339. package/dist/src/http/uploads.d.ts.map +1 -0
  340. package/dist/src/http/uploads.js +8 -0
  341. package/dist/src/http/uploads.js.map +1 -0
  342. package/dist/src/http/workflow.d.ts +18 -0
  343. package/dist/src/http/workflow.d.ts.map +1 -0
  344. package/dist/src/http/workflow.js +181 -0
  345. package/dist/src/http/workflow.js.map +1 -0
  346. package/dist/src/index.d.ts +13 -0
  347. package/dist/src/index.d.ts.map +1 -0
  348. package/dist/src/index.js +25 -0
  349. package/dist/src/index.js.map +1 -0
  350. package/dist/src/services/cli/invoke.d.ts +5 -0
  351. package/dist/src/services/cli/invoke.d.ts.map +1 -0
  352. package/dist/src/services/cli/invoke.js +45 -0
  353. package/dist/src/services/cli/invoke.js.map +1 -0
  354. package/dist/src/services/cli/repl-context.d.ts +13 -0
  355. package/dist/src/services/cli/repl-context.d.ts.map +1 -0
  356. package/dist/src/services/cli/repl-context.js +60 -0
  357. package/dist/src/services/cli/repl-context.js.map +1 -0
  358. package/dist/src/services/cli/repl.d.ts +5 -0
  359. package/dist/src/services/cli/repl.d.ts.map +1 -0
  360. package/dist/src/services/cli/repl.js +32 -0
  361. package/dist/src/services/cli/repl.js.map +1 -0
  362. package/dist/src/services/cli.d.ts +12 -0
  363. package/dist/src/services/cli.d.ts.map +1 -0
  364. package/dist/src/services/cli.js +76 -0
  365. package/dist/src/services/cli.js.map +1 -0
  366. package/dist/src/services/index.d.ts +7 -0
  367. package/dist/src/services/index.d.ts.map +1 -0
  368. package/dist/src/services/index.js +10 -0
  369. package/dist/src/services/index.js.map +1 -0
  370. package/dist/src/services/leader.d.ts +32 -0
  371. package/dist/src/services/leader.d.ts.map +1 -0
  372. package/dist/src/services/leader.js +174 -0
  373. package/dist/src/services/leader.js.map +1 -0
  374. package/dist/src/services/logger.d.ts +35 -0
  375. package/dist/src/services/logger.d.ts.map +1 -0
  376. package/dist/src/services/logger.js +245 -0
  377. package/dist/src/services/logger.js.map +1 -0
  378. package/dist/src/services/mail/index.d.ts +61 -0
  379. package/dist/src/services/mail/index.d.ts.map +1 -0
  380. package/dist/src/services/mail/index.js +90 -0
  381. package/dist/src/services/mail/index.js.map +1 -0
  382. package/dist/src/services/mail/postmark.d.ts +11 -0
  383. package/dist/src/services/mail/postmark.d.ts.map +1 -0
  384. package/dist/src/services/mail/postmark.js +42 -0
  385. package/dist/src/services/mail/postmark.js.map +1 -0
  386. package/dist/src/services/mail/smtp.d.ts +11 -0
  387. package/dist/src/services/mail/smtp.d.ts.map +1 -0
  388. package/dist/src/services/mail/smtp.js +61 -0
  389. package/dist/src/services/mail/smtp.js.map +1 -0
  390. package/dist/src/services/mesh.d.ts +65 -0
  391. package/dist/src/services/mesh.d.ts.map +1 -0
  392. package/dist/src/services/mesh.js +422 -0
  393. package/dist/src/services/mesh.js.map +1 -0
  394. package/dist/src/services/worker/bootstrap.d.ts +3 -0
  395. package/dist/src/services/worker/bootstrap.d.ts.map +1 -0
  396. package/dist/src/services/worker/bootstrap.js +64 -0
  397. package/dist/src/services/worker/bootstrap.js.map +1 -0
  398. package/dist/src/services/worker/cli.d.ts +11 -0
  399. package/dist/src/services/worker/cli.d.ts.map +1 -0
  400. package/dist/src/services/worker/cli.js +43 -0
  401. package/dist/src/services/worker/cli.js.map +1 -0
  402. package/dist/src/services/worker/entity.d.ts +18 -0
  403. package/dist/src/services/worker/entity.d.ts.map +1 -0
  404. package/dist/src/services/worker/entity.js +16 -0
  405. package/dist/src/services/worker/entity.js.map +1 -0
  406. package/dist/src/services/worker/index.d.ts +9 -0
  407. package/dist/src/services/worker/index.d.ts.map +1 -0
  408. package/dist/src/services/worker/index.js +40 -0
  409. package/dist/src/services/worker/index.js.map +1 -0
  410. package/dist/src/services/worker/queue.d.ts +8 -0
  411. package/dist/src/services/worker/queue.d.ts.map +1 -0
  412. package/dist/src/services/worker/queue.js +32 -0
  413. package/dist/src/services/worker/queue.js.map +1 -0
  414. package/dist/src/services/worker/recorder.d.ts +16 -0
  415. package/dist/src/services/worker/recorder.d.ts.map +1 -0
  416. package/dist/src/services/worker/recorder.js +168 -0
  417. package/dist/src/services/worker/recorder.js.map +1 -0
  418. package/dist/src/services/worker/runner.d.ts +21 -0
  419. package/dist/src/services/worker/runner.d.ts.map +1 -0
  420. package/dist/src/services/worker/runner.js +156 -0
  421. package/dist/src/services/worker/runner.js.map +1 -0
  422. package/dist/src/services/worker/types.d.ts +26 -0
  423. package/dist/src/services/worker/types.d.ts.map +1 -0
  424. package/dist/src/services/worker/types.js +29 -0
  425. package/dist/src/services/worker/types.js.map +1 -0
  426. package/dist/src/srpc/SrpcByteStream.d.ts +67 -0
  427. package/dist/src/srpc/SrpcByteStream.d.ts.map +1 -0
  428. package/dist/src/srpc/SrpcByteStream.js +319 -0
  429. package/dist/src/srpc/SrpcByteStream.js.map +1 -0
  430. package/dist/src/srpc/SrpcClient.d.ts +75 -0
  431. package/dist/src/srpc/SrpcClient.d.ts.map +1 -0
  432. package/dist/src/srpc/SrpcClient.js +445 -0
  433. package/dist/src/srpc/SrpcClient.js.map +1 -0
  434. package/dist/src/srpc/SrpcServer.d.ts +80 -0
  435. package/dist/src/srpc/SrpcServer.d.ts.map +1 -0
  436. package/dist/src/srpc/SrpcServer.js +561 -0
  437. package/dist/src/srpc/SrpcServer.js.map +1 -0
  438. package/dist/src/srpc/index.d.ts +7 -0
  439. package/dist/src/srpc/index.d.ts.map +1 -0
  440. package/dist/src/srpc/index.js +12 -0
  441. package/dist/src/srpc/index.js.map +1 -0
  442. package/dist/src/srpc/types.d.ts +131 -0
  443. package/dist/src/srpc/types.d.ts.map +1 -0
  444. package/dist/src/srpc/types.js +65 -0
  445. package/dist/src/srpc/types.js.map +1 -0
  446. package/dist/src/telemetry/index.d.ts +2 -0
  447. package/dist/src/telemetry/index.d.ts.map +1 -0
  448. package/dist/src/telemetry/index.js +5 -0
  449. package/dist/src/telemetry/index.js.map +1 -0
  450. package/dist/src/telemetry/otel/MariaDBInstrumentation.d.ts +22 -0
  451. package/dist/src/telemetry/otel/MariaDBInstrumentation.d.ts.map +1 -0
  452. package/dist/src/telemetry/otel/MariaDBInstrumentation.js +248 -0
  453. package/dist/src/telemetry/otel/MariaDBInstrumentation.js.map +1 -0
  454. package/dist/src/telemetry/otel/helpers.d.ts +27 -0
  455. package/dist/src/telemetry/otel/helpers.d.ts.map +1 -0
  456. package/dist/src/telemetry/otel/helpers.js +126 -0
  457. package/dist/src/telemetry/otel/helpers.js.map +1 -0
  458. package/dist/src/telemetry/otel/index.d.ts +14 -0
  459. package/dist/src/telemetry/otel/index.d.ts.map +1 -0
  460. package/dist/src/telemetry/otel/index.js +132 -0
  461. package/dist/src/telemetry/otel/index.js.map +1 -0
  462. package/dist/src/telemetry/otel/metrics.controller.d.ts +6 -0
  463. package/dist/src/telemetry/otel/metrics.controller.d.ts.map +1 -0
  464. package/dist/src/telemetry/otel/metrics.controller.js +63 -0
  465. package/dist/src/telemetry/otel/metrics.controller.js.map +1 -0
  466. package/dist/src/telemetry/sentry.d.ts +9 -0
  467. package/dist/src/telemetry/sentry.d.ts.map +1 -0
  468. package/dist/src/telemetry/sentry.js +62 -0
  469. package/dist/src/telemetry/sentry.js.map +1 -0
  470. package/dist/src/testing/expect.d.ts +25 -0
  471. package/dist/src/testing/expect.d.ts.map +1 -0
  472. package/dist/src/testing/expect.js +151 -0
  473. package/dist/src/testing/expect.js.map +1 -0
  474. package/dist/src/testing/fixtures.d.ts +19 -0
  475. package/dist/src/testing/fixtures.d.ts.map +1 -0
  476. package/dist/src/testing/fixtures.js +69 -0
  477. package/dist/src/testing/fixtures.js.map +1 -0
  478. package/dist/src/testing/index.d.ts +260 -0
  479. package/dist/src/testing/index.d.ts.map +1 -0
  480. package/dist/src/testing/index.js +345 -0
  481. package/dist/src/testing/index.js.map +1 -0
  482. package/dist/src/testing/requests.d.ts +10 -0
  483. package/dist/src/testing/requests.d.ts.map +1 -0
  484. package/dist/src/testing/requests.js +56 -0
  485. package/dist/src/testing/requests.js.map +1 -0
  486. package/dist/src/testing/sql.d.ts +11 -0
  487. package/dist/src/testing/sql.d.ts.map +1 -0
  488. package/dist/src/testing/sql.js +55 -0
  489. package/dist/src/testing/sql.js.map +1 -0
  490. package/dist/src/types/index.d.ts +57 -0
  491. package/dist/src/types/index.d.ts.map +1 -0
  492. package/dist/src/types/index.js +73 -0
  493. package/dist/src/types/index.js.map +1 -0
  494. package/dist/src/types/phone.d.ts +11 -0
  495. package/dist/src/types/phone.d.ts.map +1 -0
  496. package/dist/src/types/phone.js +73 -0
  497. package/dist/src/types/phone.js.map +1 -0
  498. package/docs/.vitepress/config.mts +79 -0
  499. package/docs/.yarnrc.yml +1 -0
  500. package/docs/content/CONTRIBUTING.md +140 -0
  501. package/docs/content/README-DEV.md +142 -0
  502. package/docs/content/README.md +39 -0
  503. package/docs/content/authentication.md +215 -0
  504. package/docs/content/cli.md +335 -0
  505. package/docs/content/configuration.md +175 -0
  506. package/docs/content/database.md +422 -0
  507. package/docs/content/devconsole.md +123 -0
  508. package/docs/content/getting-started.md +154 -0
  509. package/docs/content/guides/test-migration-guide.md +351 -0
  510. package/docs/content/health.md +54 -0
  511. package/docs/content/helpers.md +322 -0
  512. package/docs/content/http.md +253 -0
  513. package/docs/content/index.md +147 -0
  514. package/docs/content/leader-service.md +98 -0
  515. package/docs/content/logging.md +150 -0
  516. package/docs/content/mail.md +161 -0
  517. package/docs/content/mesh-service.md +204 -0
  518. package/docs/content/public/images/devconsole/01-dashboard.png +0 -0
  519. package/docs/content/public/images/devconsole/02-routes.png +0 -0
  520. package/docs/content/public/images/devconsole/03-openapi.png +0 -0
  521. package/docs/content/public/images/devconsole/04-requests.png +0 -0
  522. package/docs/content/public/images/devconsole/05-srpc.png +0 -0
  523. package/docs/content/public/images/devconsole/06-database.png +0 -0
  524. package/docs/content/public/images/devconsole/07-health.png +0 -0
  525. package/docs/content/public/images/devconsole/08-mutex.png +0 -0
  526. package/docs/content/public/images/devconsole/09-repl.png +0 -0
  527. package/docs/content/public/images/devconsole/10-workers.png +0 -0
  528. package/docs/content/redis.md +168 -0
  529. package/docs/content/srpc.md +261 -0
  530. package/docs/content/telemetry.md +166 -0
  531. package/docs/content/testing.md +222 -0
  532. package/docs/content/types.md +215 -0
  533. package/docs/content/worker.md +177 -0
  534. package/docs/package.json +16 -0
  535. package/docs/scripts/README-SCREENSHOTS.md +145 -0
  536. package/docs/scripts/capture-devconsole-screenshots.js +184 -0
  537. package/docs/yarn.lock +2408 -0
  538. package/package.json +144 -0
  539. package/patches/@deepkit+type+1.0.19.patch +38 -0
  540. package/patches/deepkit-openapi-core+0.0.9.patch +62 -0
  541. package/src/app/base.ts +253 -0
  542. package/src/app/config.loader.ts +66 -0
  543. package/src/app/config.ts +119 -0
  544. package/src/app/const.ts +4 -0
  545. package/src/app/dev.ts +92 -0
  546. package/src/app/index.ts +6 -0
  547. package/src/app/openapi.ts +3 -0
  548. package/src/app/resolver.ts +49 -0
  549. package/src/app/shutdown.ts +55 -0
  550. package/src/app/state.ts +19 -0
  551. package/src/auth/index.ts +2 -0
  552. package/src/auth/jwt.ts +275 -0
  553. package/src/auth/provider.ts +57 -0
  554. package/src/cli/dksf-dev.ts +416 -0
  555. package/src/cli/dksf-gen-proto.ts +176 -0
  556. package/src/cli/dksf-install.ts +11 -0
  557. package/src/cli/dksf-test.ts +84 -0
  558. package/src/cli/dksf-update.ts +101 -0
  559. package/src/database/common.ts +385 -0
  560. package/src/database/dialect.ts +43 -0
  561. package/src/database/entity.ts +285 -0
  562. package/src/database/index.ts +7 -0
  563. package/src/database/migration/MigrationResetCommand.ts +72 -0
  564. package/src/database/migration/MigrationRunCommand.ts +118 -0
  565. package/src/database/migration/characters.ts +53 -0
  566. package/src/database/migration/create/MigrationCreateCommand.ts +96 -0
  567. package/src/database/migration/create/comparator.ts +467 -0
  568. package/src/database/migration/create/db-reader.ts +510 -0
  569. package/src/database/migration/create/ddl-generator.ts +755 -0
  570. package/src/database/migration/create/entity-reader.ts +471 -0
  571. package/src/database/migration/create/file-generator.ts +57 -0
  572. package/src/database/migration/create/prompt.ts +49 -0
  573. package/src/database/migration/create/schema-model.ts +102 -0
  574. package/src/database/migration/helpers.ts +7 -0
  575. package/src/database/migration/index.ts +35 -0
  576. package/src/database/migration/migration.entity.ts +10 -0
  577. package/src/database/mysql.ts +140 -0
  578. package/src/database/postgres.ts +97 -0
  579. package/src/database/types.ts +18 -0
  580. package/src/devconsole/devconsole.controller.ts +59 -0
  581. package/src/devconsole/devconsole.middleware.ts +23 -0
  582. package/src/devconsole/devconsole.srpc.ts +94 -0
  583. package/src/devconsole/devconsole.store.ts +190 -0
  584. package/src/devconsole/devconsole.ws.ts +491 -0
  585. package/src/devconsole/index.ts +1 -0
  586. package/src/devconsole/patches.ts +428 -0
  587. package/src/health/health.module.ts +30 -0
  588. package/src/health/healthcheck.controller.ts +17 -0
  589. package/src/health/healthcheck.service.ts +28 -0
  590. package/src/health/index.ts +2 -0
  591. package/src/helpers/async/context.ts +67 -0
  592. package/src/helpers/async/process.ts +49 -0
  593. package/src/helpers/async/promise.ts +16 -0
  594. package/src/helpers/data/array.ts +11 -0
  595. package/src/helpers/data/objects.ts +64 -0
  596. package/src/helpers/data/serialization.ts +11 -0
  597. package/src/helpers/data/transformer.ts +54 -0
  598. package/src/helpers/framework/decorators.ts +27 -0
  599. package/src/helpers/framework/event.ts +11 -0
  600. package/src/helpers/framework/injection.ts +47 -0
  601. package/src/helpers/index.ts +34 -0
  602. package/src/helpers/io/package.ts +26 -0
  603. package/src/helpers/io/stream.ts +79 -0
  604. package/src/helpers/redis/broadcast.ts +96 -0
  605. package/src/helpers/redis/cache.ts +28 -0
  606. package/src/helpers/redis/mutex.ts +260 -0
  607. package/src/helpers/redis/redis.ts +60 -0
  608. package/src/helpers/security/crypto.ts +133 -0
  609. package/src/helpers/security/validation.ts +16 -0
  610. package/src/helpers/utils/date.ts +13 -0
  611. package/src/helpers/utils/error.ts +155 -0
  612. package/src/helpers/utils/jsx.ts +8 -0
  613. package/src/helpers/utils/uuid.ts +8 -0
  614. package/src/http/auth.ts +156 -0
  615. package/src/http/context.ts +15 -0
  616. package/src/http/cors.ts +159 -0
  617. package/src/http/errors.ts +9 -0
  618. package/src/http/index.ts +19 -0
  619. package/src/http/kernel.ts +138 -0
  620. package/src/http/middleware.ts +59 -0
  621. package/src/http/overrides.ts +20 -0
  622. package/src/http/store.ts +86 -0
  623. package/src/http/uploads.ts +6 -0
  624. package/src/http/workflow.ts +167 -0
  625. package/src/index.ts +19 -0
  626. package/src/services/cli/invoke.ts +39 -0
  627. package/src/services/cli/repl-context.ts +63 -0
  628. package/src/services/cli/repl.ts +22 -0
  629. package/src/services/cli.ts +74 -0
  630. package/src/services/index.ts +6 -0
  631. package/src/services/leader.ts +201 -0
  632. package/src/services/logger.ts +258 -0
  633. package/src/services/mail/index.ts +117 -0
  634. package/src/services/mail/postmark.ts +37 -0
  635. package/src/services/mail/smtp.ts +46 -0
  636. package/src/services/mesh.ts +508 -0
  637. package/src/services/worker/bootstrap.ts +53 -0
  638. package/src/services/worker/cli.ts +32 -0
  639. package/src/services/worker/entity.ts +22 -0
  640. package/src/services/worker/index.ts +30 -0
  641. package/src/services/worker/queue.ts +35 -0
  642. package/src/services/worker/recorder.ts +172 -0
  643. package/src/services/worker/runner.ts +179 -0
  644. package/src/services/worker/types.ts +32 -0
  645. package/src/srpc/SrpcByteStream.ts +382 -0
  646. package/src/srpc/SrpcClient.ts +512 -0
  647. package/src/srpc/SrpcServer.ts +681 -0
  648. package/src/srpc/index.ts +15 -0
  649. package/src/srpc/types.ts +146 -0
  650. package/src/telemetry/index.ts +1 -0
  651. package/src/telemetry/otel/MariaDBInstrumentation.ts +297 -0
  652. package/src/telemetry/otel/helpers.ts +117 -0
  653. package/src/telemetry/otel/index.ts +150 -0
  654. package/src/telemetry/otel/metrics.controller.ts +50 -0
  655. package/src/telemetry/sentry.ts +58 -0
  656. package/src/testing/expect.ts +148 -0
  657. package/src/testing/fixtures.ts +62 -0
  658. package/src/testing/index.ts +355 -0
  659. package/src/testing/requests.ts +68 -0
  660. package/src/testing/sql.ts +50 -0
  661. package/src/types/index.ts +64 -0
  662. package/src/types/phone.ts +64 -0
  663. package/types.d.ts +20 -0
@@ -0,0 +1,76 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CliServiceCommand = void 0;
4
+ function __assignType(fn, args) {
5
+ fn.__type = args;
6
+ return fn;
7
+ }
8
+ const event_1 = require("@deepkit/event");
9
+ const framework_1 = require("@deepkit/framework");
10
+ const http_1 = require("@deepkit/http");
11
+ const resolver_1 = require("../app/resolver");
12
+ const state_1 = require("../app/state");
13
+ const healthcheck_controller_1 = require("../health/healthcheck.controller");
14
+ const metrics_controller_1 = require("../telemetry/otel/metrics.controller");
15
+ class CliServiceCommand {
16
+ constructor() {
17
+ this.eventDispatcher = (0, resolver_1.r)(event_1.EventDispatcher);
18
+ this.appServer = (0, resolver_1.r)(framework_1.ApplicationServer);
19
+ this.routerRegistry = (0, resolver_1.r)(http_1.HttpRouterRegistry);
20
+ this.shouldRun = true;
21
+ this.stop = () => { };
22
+ }
23
+ async execute() {
24
+ // note that we're a CLI service to prevent non-CLI side effects
25
+ state_1.globalState.isCliService = true;
26
+ // disable workers
27
+ this.appServer.config.workers = 0;
28
+ // remove all controllers except health-related ones
29
+ const routes = this.routerRegistry.getRoutes();
30
+ for (let i = 0; i < routes.length; i++) {
31
+ const route = routes[i];
32
+ if (route.action.type === 'controller') {
33
+ if (route.action.controller === healthcheck_controller_1.HealthcheckController || route.action.controller === metrics_controller_1.MetricsController) {
34
+ continue;
35
+ }
36
+ }
37
+ routes.splice(i, 1);
38
+ i--;
39
+ }
40
+ // start the application server. tell it to wait for signals, but don't want for it to return,
41
+ // as when listening to stop signals, it won't return until the server shuts down. instead, we
42
+ // can listen to the onServerMainBootstrapDone event to actually wait for the server to start
43
+ const onServerMainBootstrapDonePromise = (Promise.Ω = [['$']], new Promise(__assignType(resolve => {
44
+ this.eventDispatcher.listen(framework_1.onServerMainBootstrapDone, () => resolve());
45
+ }, ['resolve', '', 'P"2!"/"'])));
46
+ this.appServer.start(true);
47
+ await onServerMainBootstrapDonePromise;
48
+ // prepare stop
49
+ const hasRunService = this.runService !== CliServiceCommand.prototype.runService;
50
+ const stopPromise = (Promise.Ω = [['$']], new Promise(__assignType(resolve => {
51
+ const handleStop = () => {
52
+ this.shouldRun = false;
53
+ resolve();
54
+ };
55
+ this.eventDispatcher.listen(framework_1.onServerShutdown, handleStop);
56
+ this.stop = handleStop;
57
+ }, ['resolve', '', 'P"2!"/"'])));
58
+ // start our CLI service
59
+ await this.startService();
60
+ // wait for stop signal
61
+ if (hasRunService) {
62
+ await this.runService();
63
+ }
64
+ else {
65
+ await stopPromise;
66
+ }
67
+ // process shutdown
68
+ await this.shutdownService();
69
+ }
70
+ async startService() { }
71
+ async runService() { }
72
+ async shutdownService() { }
73
+ }
74
+ exports.CliServiceCommand = CliServiceCommand;
75
+ CliServiceCommand.__type = ['eventDispatcher', function () { return (0, resolver_1.r)(event_1.EventDispatcher); }, 'appServer', function () { return (0, resolver_1.r)(framework_1.ApplicationServer); }, 'routerRegistry', function () { return (0, resolver_1.r)(http_1.HttpRouterRegistry); }, 'shouldRun', function () { return true; }, '', 'stop', function () { return () => { }; }, 'execute', 'startService', 'runService', 'shutdownService', 'CliServiceCommand', '!3!;>"!3#;>$!3%;>&)3\'<>(P$/)3*>+P"0,P$`0-<P$`0.<P$`0/<5w0'];
76
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../src/services/cli.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export * from './cli';
2
+ export * from './leader';
3
+ export * from './logger';
4
+ export * from './mail';
5
+ export * from './mesh';
6
+ export * from './worker';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAC;AACtB,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,UAAU,CAAC"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./cli"), exports);
5
+ tslib_1.__exportStar(require("./leader"), exports);
6
+ tslib_1.__exportStar(require("./logger"), exports);
7
+ tslib_1.__exportStar(require("./mail"), exports);
8
+ tslib_1.__exportStar(require("./mesh"), exports);
9
+ tslib_1.__exportStar(require("./worker"), exports);
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/index.ts"],"names":[],"mappings":";;;AAAA,gDAAsB;AACtB,mDAAyB;AACzB,mDAAyB;AACzB,iDAAuB;AACvB,iDAAuB;AACvB,mDAAyB"}
@@ -0,0 +1,32 @@
1
+ type LeaderCallback = () => void | Promise<void>;
2
+ export interface LeaderServiceOptions {
3
+ ttlMs?: number;
4
+ renewalIntervalMs?: number;
5
+ retryDelayMs?: number;
6
+ }
7
+ export declare class LeaderService {
8
+ private lockId;
9
+ private key;
10
+ private _isLeader;
11
+ private running;
12
+ private renewTimer;
13
+ private retryTimer;
14
+ private becameLeaderCallback;
15
+ private lostLeaderCallback;
16
+ private ttlMs;
17
+ private renewalIntervalMs;
18
+ private retryDelayMs;
19
+ private logger;
20
+ constructor(key: string, options?: LeaderServiceOptions);
21
+ get isLeader(): boolean;
22
+ setBecameLeaderCallback(callback: LeaderCallback): void;
23
+ setLostLeaderCallback(callback: LeaderCallback): void;
24
+ start(): void;
25
+ stop(): Promise<void>;
26
+ private tryAcquire;
27
+ private startRenewal;
28
+ private handleLostLeadership;
29
+ }
30
+ export {};
31
+ export declare type __ΩLeaderServiceOptions = any[];
32
+ //# sourceMappingURL=leader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"leader.d.ts","sourceRoot":"","sources":["../../../src/services/leader.ts"],"names":[],"mappings":"AA8CA,KAAK,cAAc,GAAG,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAEjD,MAAM,WAAW,oBAAoB;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,qBAAa,aAAa;IACtB,OAAO,CAAC,MAAM,CAAU;IACxB,OAAO,CAAC,GAAG,CAAS;IACpB,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,UAAU,CAA+C;IACjE,OAAO,CAAC,UAAU,CAA8C;IAEhE,OAAO,CAAC,oBAAoB,CAA+B;IAC3D,OAAO,CAAC,kBAAkB,CAA+B;IAEzD,OAAO,CAAC,KAAK,CAAS;IACtB,OAAO,CAAC,iBAAiB,CAAS;IAClC,OAAO,CAAC,YAAY,CAAS;IAE7B,OAAO,CAAC,MAAM,CAAsB;gBAExB,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,oBAAoB;IASvD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,uBAAuB,CAAC,QAAQ,EAAE,cAAc,GAAG,IAAI;IAIvD,qBAAqB,CAAC,QAAQ,EAAE,cAAc,GAAG,IAAI;IAIrD,KAAK,IAAI,IAAI;IAUP,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;YAuBb,UAAU;IAoCxB,OAAO,CAAC,YAAY;IAgBpB,OAAO,CAAC,oBAAoB;CAuB/B"}
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LeaderService = exports.__ΩLeaderServiceOptions = void 0;
4
+ const __ΩReturnType = ['T', 'args', '', 'ReturnType', 'l>e"!R"RPde#!P"@2"h"!/#qk#\'QRb!Pde"!p)w$y'];
5
+ function __assignType(fn, args) {
6
+ fn.__type = args;
7
+ return fn;
8
+ }
9
+ const type_1 = require("@deepkit/type");
10
+ const lodash_1 = require("lodash");
11
+ const resolver_1 = require("../app/resolver");
12
+ const package_1 = require("../helpers/io/package");
13
+ const redis_1 = require("../helpers/redis/redis");
14
+ const logger_1 = require("./logger");
15
+ const ACQUIRE_SCRIPT = `
16
+ if redis.call("exists", KEYS[1]) == 1 then
17
+ return 0
18
+ end
19
+ redis.call("set", KEYS[1], ARGV[1], "px", ARGV[2])
20
+ return 1
21
+ `;
22
+ const RENEW_SCRIPT = `
23
+ if redis.call("get", KEYS[1]) ~= ARGV[1] then
24
+ return 0
25
+ end
26
+ redis.call("pexpire", KEYS[1], ARGV[2])
27
+ return 1
28
+ `;
29
+ const RELEASE_SCRIPT = `
30
+ if redis.call("get", KEYS[1]) ~= ARGV[1] then
31
+ return 0
32
+ end
33
+ redis.call("del", KEYS[1])
34
+ return 1
35
+ `;
36
+ const __ΩLeaderRedisClient = [() => __ΩReturnType, () => redis_1.createRedis, "client", 'key', 'value', 'ttl', '', 'ACQUIRE', 'RENEW', 'RELEASE', 'LeaderRedisClient', 'Pi"o!".#fPP&2$&2%\'2&\'`/\'4(P&2$&2%\'2&\'`/\'4)P&2$&2%\'`/\'4*MKw+y'];
37
+ const getRedisClient = (0, lodash_1.memoize)(__assignType(() => {
38
+ const { client } = (0, redis_1.createRedis)('MUTEX');
39
+ client.defineCommand('ACQUIRE', { lua: ACQUIRE_SCRIPT, numberOfKeys: 1 });
40
+ client.defineCommand('RENEW', { lua: RENEW_SCRIPT, numberOfKeys: 1 });
41
+ client.defineCommand('RELEASE', { lua: RELEASE_SCRIPT, numberOfKeys: 1 });
42
+ return client;
43
+ }, [() => __ΩLeaderRedisClient, '', 'Pn!/"']));
44
+ const __ΩLeaderCallback = ['', 'LeaderCallback', 'PP$$`J/!w"y'];
45
+ const __ΩLeaderServiceOptions = ['ttlMs', 'renewalIntervalMs', 'retryDelayMs', 'LeaderServiceOptions', 'P\'4!8\'4"8\'4#8Mw$y'];
46
+ exports.__ΩLeaderServiceOptions = __ΩLeaderServiceOptions;
47
+ class LeaderService {
48
+ constructor(key, options) {
49
+ this.lockId = (0, type_1.uuid)();
50
+ this._isLeader = false;
51
+ this.running = false;
52
+ this.renewTimer = null;
53
+ this.retryTimer = null;
54
+ this.becameLeaderCallback = null;
55
+ this.lostLeaderCallback = null;
56
+ this.logger = (0, logger_1.createLogger)(this);
57
+ const config = (0, resolver_1.getAppConfig)();
58
+ const prefix = config.MUTEX_REDIS_PREFIX ?? config.REDIS_PREFIX ?? (0, package_1.getPackageName)() ?? 'app';
59
+ this.key = `${prefix}:leader:${key}`;
60
+ this.ttlMs = options?.ttlMs ?? 30000;
61
+ this.renewalIntervalMs = options?.renewalIntervalMs ?? 10000;
62
+ this.retryDelayMs = options?.retryDelayMs ?? 5000;
63
+ }
64
+ get isLeader() {
65
+ return this._isLeader;
66
+ }
67
+ setBecameLeaderCallback(callback) {
68
+ this.becameLeaderCallback = callback;
69
+ }
70
+ setLostLeaderCallback(callback) {
71
+ this.lostLeaderCallback = callback;
72
+ }
73
+ start() {
74
+ if (this.running) {
75
+ throw new Error('LeaderService is already running');
76
+ }
77
+ this.running = true;
78
+ this.logger.info('starting leader election', { key: this.key });
79
+ this.tryAcquire();
80
+ }
81
+ async stop() {
82
+ this.running = false;
83
+ if (this.renewTimer) {
84
+ clearInterval(this.renewTimer);
85
+ this.renewTimer = null;
86
+ }
87
+ if (this.retryTimer) {
88
+ clearTimeout(this.retryTimer);
89
+ this.retryTimer = null;
90
+ }
91
+ if (this._isLeader) {
92
+ try {
93
+ await getRedisClient().RELEASE(this.key, this.lockId);
94
+ }
95
+ catch (err) {
96
+ this.logger.warn('failed to release leader lock during stop', { err });
97
+ }
98
+ this._isLeader = false;
99
+ }
100
+ }
101
+ async tryAcquire() {
102
+ if (!this.running)
103
+ return;
104
+ try {
105
+ const result = await getRedisClient().ACQUIRE(this.key, this.lockId, this.ttlMs);
106
+ if (result === 1) {
107
+ // If stop() was called while ACQUIRE was in-flight, release immediately
108
+ if (!this.running) {
109
+ try {
110
+ await getRedisClient().RELEASE(this.key, this.lockId);
111
+ }
112
+ catch {
113
+ // ignore — lock will expire via TTL
114
+ }
115
+ return;
116
+ }
117
+ this._isLeader = true;
118
+ this.logger.info('became leader', { key: this.key });
119
+ this.startRenewal();
120
+ try {
121
+ await this.becameLeaderCallback?.();
122
+ }
123
+ catch (err) {
124
+ this.logger.warn('becameLeader callback error', { err });
125
+ }
126
+ return;
127
+ }
128
+ }
129
+ catch (err) {
130
+ this.logger.warn('error during leader acquisition', { err });
131
+ }
132
+ if (this.running) {
133
+ this.retryTimer = setTimeout(() => this.tryAcquire(), this.retryDelayMs);
134
+ }
135
+ }
136
+ startRenewal() {
137
+ this.renewTimer = setInterval(async () => {
138
+ if (!this.running)
139
+ return;
140
+ try {
141
+ const result = await getRedisClient().RENEW(this.key, this.lockId, this.ttlMs);
142
+ if (result === 0) {
143
+ this.handleLostLeadership();
144
+ }
145
+ }
146
+ catch (err) {
147
+ this.logger.warn('error during leader renewal', { err });
148
+ this.handleLostLeadership();
149
+ }
150
+ }, this.renewalIntervalMs);
151
+ }
152
+ handleLostLeadership() {
153
+ if (!this._isLeader)
154
+ return;
155
+ this._isLeader = false;
156
+ this.logger.info('lost leadership', { key: this.key });
157
+ if (this.renewTimer) {
158
+ clearInterval(this.renewTimer);
159
+ this.renewTimer = null;
160
+ }
161
+ Promise.resolve()
162
+ .then(() => this.lostLeaderCallback?.())
163
+ .catch(__assignType(err => {
164
+ this.logger.warn('lostLeader callback error', { err });
165
+ }, ['err', '', 'P"2!"/"']));
166
+ this.lockId = (0, type_1.uuid)();
167
+ if (this.running) {
168
+ this.retryTimer = setTimeout(() => this.tryAcquire(), this.retryDelayMs);
169
+ }
170
+ }
171
+ }
172
+ exports.LeaderService = LeaderService;
173
+ LeaderService.__type = ['lockId', function () { return (0, type_1.uuid)(); }, 'key', '_isLeader', function () { return false; }, 'running', function () { return false; }, () => __ΩReturnType, () => setInterval, 'renewTimer', function () { return null; }, () => __ΩReturnType, () => setTimeout, 'retryTimer', function () { return null; }, () => __ΩLeaderCallback, 'becameLeaderCallback', function () { return null; }, () => __ΩLeaderCallback, 'lostLeaderCallback', function () { return null; }, 'ttlMs', 'renewalIntervalMs', 'retryDelayMs', 'logger', function () { return (0, logger_1.createLogger)(this); }, () => __ΩLeaderServiceOptions, 'options', 'constructor', () => __ΩLeaderCallback, 'callback', 'setBecameLeaderCallback', () => __ΩLeaderCallback, 'setLostLeaderCallback', 'start', 'stop', 'tryAcquire', 'startRenewal', 'handleLostLeadership', 'LeaderService', '!3!;>"&3#;)3$;>%)3&;>\'Pi)o(",J3*;>+Pi-o,",J3.;>/Pn0,J31;>2Pn3,J34;>5\'36;\'37;\'38;!39;>:P&2#n;2<8"0=!Pn>2?$0@PnA2?$0BP$0CP$`0DP$`0E;P$0F;P$0G;5wH'];
174
+ //# sourceMappingURL=leader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"leader.js","sourceRoot":"","sources":["../../../src/services/leader.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ import { ClassType } from '@deepkit/core';
2
+ import { LogData, Logger, LoggerFormatter, LoggerLevel } from '@deepkit/logger';
3
+ export declare const shouldUsePinoPretty: boolean;
4
+ export declare const shouldUseSingleLine: boolean;
5
+ export declare const LoggerContextProps: string[];
6
+ export declare const LoggerContextSymbol: unique symbol;
7
+ declare const PinoSeverityMap: {
8
+ readonly 0: "DEFAULT";
9
+ readonly 1: "ALERT";
10
+ readonly 2: "ERROR";
11
+ readonly 3: "WARNING";
12
+ readonly 4: "NOTICE";
13
+ readonly 5: "INFO";
14
+ readonly 6: "DEBUG";
15
+ readonly 7: "DEBUG";
16
+ };
17
+ type Severity = (typeof PinoSeverityMap)[keyof typeof PinoSeverityMap];
18
+ export declare const pinoLogger: import("pino").Logger<Severity, true>;
19
+ export declare class ExtendedLogger extends Logger {
20
+ protected scopeData?: LogData;
21
+ addFormatter(formatter: LoggerFormatter): void;
22
+ scoped(shortName: string, data?: LogData): ExtendedLogger;
23
+ protected send(messages: any[], level: LoggerLevel, data?: LogData): void;
24
+ debug(...message: any[]): void;
25
+ getContextProps(): {
26
+ [k: string]: any;
27
+ } | undefined;
28
+ stripColors(message: string): string;
29
+ setScopeData(data?: LogData): this;
30
+ handleError(level: LoggerLevel, message: string | undefined, err: Error | undefined, data: LogData | undefined): void;
31
+ }
32
+ export declare function createLogger(subject: string | InstanceType<ClassType>, defaultData?: LogData): ExtendedLogger;
33
+ export declare function withLoggerContext<T>(data: LogData, fn: () => Promise<T>): Promise<T>;
34
+ export {};
35
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/services/logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAoB,OAAO,EAAE,MAAM,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAWlG,eAAO,MAAM,mBAAmB,SAAsD,CAAC;AACvF,eAAO,MAAM,mBAAmB,SAA2D,CAAC;AAC5F,eAAO,MAAM,kBAAkB,EAAE,MAAM,EAAoB,CAAC;AAC5D,eAAO,MAAM,mBAAmB,eAA0B,CAAC;AAE3D,QAAA,MAAM,eAAe;;;;;;;;;CASX,CAAC;AACX,KAAK,QAAQ,GAAG,CAAC,OAAO,eAAe,CAAC,CAAC,MAAM,OAAO,eAAe,CAAC,CAAC;AAiCvE,eAAO,MAAM,UAAU,uCAatB,CAAC;AAEF,qBAAa,cAAe,SAAQ,MAAM;IACtC,SAAS,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC;IAE9B,YAAY,CAAC,SAAS,EAAE,eAAe,GAAG,IAAI;IAa9C,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,GAAG,cAAc;IA8BzD,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,EAAE,OAAO;IAmDlE,KAAK,CAAC,GAAG,OAAO,EAAE,GAAG,EAAE,GAAG,IAAI;IAK9B,eAAe;;;IAqBf,WAAW,CAAC,OAAO,EAAE,MAAM;IAI3B,YAAY,CAAC,IAAI,CAAC,EAAE,OAAO;IAK3B,WAAW,CAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,GAAG,SAAS,EAAE,GAAG,EAAE,KAAK,GAAG,SAAS,EAAE,IAAI,EAAE,OAAO,GAAG,SAAS,GAAG,IAAI;CAUxH;AAED,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,YAAY,CAAC,SAAS,CAAC,EAAE,WAAW,CAAC,EAAE,OAAO,kBAM5F;AAED,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAWpF"}
@@ -0,0 +1,245 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ExtendedLogger = exports.pinoLogger = exports.LoggerContextSymbol = exports.LoggerContextProps = exports.shouldUseSingleLine = exports.shouldUsePinoPretty = void 0;
4
+ exports.createLogger = createLogger;
5
+ exports.withLoggerContext = withLoggerContext;
6
+ const tslib_1 = require("tslib");
7
+ const __ΩError = ['name', 'message', 'stack', 'Error', 'P&4!&4"&4#8Mw$y'];
8
+ const __ΩInstanceType = ['T', 'args', 'new', 'InstanceType', 'l>e"!R"RPde#!P"@2"h"!/#qk#\'QRb!Pde"!p)w$y'];
9
+ function __assignType(fn, args) {
10
+ fn.__type = args;
11
+ return fn;
12
+ }
13
+ /*@ts-ignore*/
14
+ var { __ΩClassType } = require('@deepkit/core');
15
+ /*@ts-ignore*/
16
+ var { __ΩLogData, __ΩLoggerFormatter, __ΩLoggerLevel } = require('@deepkit/logger');
17
+ const logger_1 = require("@deepkit/logger");
18
+ const orm_1 = require("@deepkit/orm");
19
+ const axios_1 = require("axios");
20
+ const debug_1 = tslib_1.__importDefault(require("debug"));
21
+ const pino_1 = require("pino");
22
+ const config_1 = require("../app/config");
23
+ const const_1 = require("../app/const");
24
+ const helpers_1 = require("../helpers");
25
+ const resolver_1 = require("../app/resolver");
26
+ exports.shouldUsePinoPretty = (0, config_1.isDevFeatureEnabled)(process.env.ENABLE_PINO_PRETTY);
27
+ exports.shouldUseSingleLine = (0, config_1.isDevFeatureEnabled)(process.env.ENABLE_PINO_SINGLE_LINE);
28
+ exports.LoggerContextProps = ['http', 'job'];
29
+ exports.LoggerContextSymbol = Symbol('LoggerContext');
30
+ const PinoSeverityMap = {
31
+ [logger_1.LoggerLevel.none]: 'DEFAULT',
32
+ [logger_1.LoggerLevel.alert]: 'ALERT',
33
+ [logger_1.LoggerLevel.error]: 'ERROR',
34
+ [logger_1.LoggerLevel.warning]: 'WARNING',
35
+ [logger_1.LoggerLevel.log]: 'NOTICE',
36
+ [logger_1.LoggerLevel.info]: 'INFO',
37
+ [logger_1.LoggerLevel.debug]: 'DEBUG',
38
+ [logger_1.LoggerLevel.debug2]: 'DEBUG'
39
+ };
40
+ const __ΩSeverity = [() => PinoSeverityMap, () => PinoSeverityMap, 'Severity', 'i!i"gfw#y'];
41
+ const InvertedPinoSeverityMap = {
42
+ DEFAULT: logger_1.LoggerLevel.none,
43
+ ALERT: logger_1.LoggerLevel.alert,
44
+ ERROR: logger_1.LoggerLevel.error,
45
+ WARNING: logger_1.LoggerLevel.warning,
46
+ NOTICE: logger_1.LoggerLevel.log,
47
+ INFO: logger_1.LoggerLevel.info,
48
+ DEBUG: logger_1.LoggerLevel.debug
49
+ };
50
+ const logStream = exports.shouldUsePinoPretty
51
+ ? (() => {
52
+ // eslint-disable-next-line @typescript-eslint/no-require-imports
53
+ const PinoPretty = require('pino-pretty');
54
+ return PinoPretty.default({
55
+ colorize: true,
56
+ singleLine: exports.shouldUseSingleLine,
57
+ messageFormat: '\x1b[35m{scope} \x1b[36m{message}',
58
+ ignore: 'scope',
59
+ level: process.env.LOG_LEVEL || (process.env.NODE_ENV === 'production' ? 'info' : 'debug'),
60
+ levelFirst: true,
61
+ levelKey: 'severity',
62
+ customLevels: Object.entries(InvertedPinoSeverityMap)
63
+ .map(__assignType(([severity, level]) => `${severity}:${level}`, ['param0', '', 'P"2!"/"']))
64
+ .join(','),
65
+ messageKey: 'message',
66
+ customColors: 'alert:bgRed,error:red,warning:yellow,notice:green,info:blue,debug:gray,default:white',
67
+ sync: const_1.isTest
68
+ });
69
+ })()
70
+ : undefined;
71
+ exports.pinoLogger = (0, pino_1.pino)({
72
+ formatters: {
73
+ level: __assignType(label => ({ severity: label }), ['label', '', 'P"2!"/"']),
74
+ bindings: const_1.isDevelopment ? () => ({ pid: process.pid }) : () => ({})
75
+ },
76
+ timestamp: pino_1.stdTimeFunctions.isoTime,
77
+ messageKey: 'message',
78
+ customLevels: InvertedPinoSeverityMap,
79
+ useOnlyCustomLevels: true,
80
+ level: 'DEFAULT'
81
+ }, logStream);
82
+ class ExtendedLogger extends logger_1.Logger {
83
+ addFormatter(formatter) {
84
+ // - the server:start command injects DefaultFormatter after logger is instantiated
85
+ // - the message that's transformed by DefaultFormatter is not used by the default JSON transport
86
+ // - the color remover only removes colors from the prop the JSON transport *isn't* using
87
+ // so don't allow the default formatter to be added, then use our custom JSON formatter
88
+ // to read the original message prop after the color has been stripped
89
+ if (formatter instanceof logger_1.DefaultFormatter) {
90
+ return;
91
+ }
92
+ super.addFormatter(formatter);
93
+ }
94
+ scoped(shortName, data) {
95
+ const name = this.scope.length ? `${this.scope}:${shortName}` : shortName;
96
+ // If data is provided, always create a new instance to avoid sharing scopeData
97
+ // between different callers (e.g., different SIP dialogs with different callIds)
98
+ if (data) {
99
+ const scoped = new ExtendedLogger(this.transporter, this.formatter, name);
100
+ scoped.level = this.level;
101
+ // Inherit parent's scopeData and merge with provided data
102
+ scoped.scopeData = { ...this.scopeData, ...data };
103
+ return scoped;
104
+ }
105
+ // For bare scoped loggers (no data), use caching
106
+ if (!this.scopes[name]) {
107
+ const scoped = new ExtendedLogger(this.transporter, this.formatter, name);
108
+ scoped.level = this.level;
109
+ if (this.scopeData) {
110
+ scoped.scopeData = { ...this.scopeData };
111
+ }
112
+ this.scopes[name] = scoped;
113
+ }
114
+ return this.scopes[name];
115
+ }
116
+ // the first parameter can be a string or an object
117
+ // if the first parameter is a string, the second can be an object
118
+ // any funkier configurations than that, and we start stuffing indexed args onto the data object
119
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
120
+ send(messages, level, data) {
121
+ let err = (0, helpers_1.isError)(messages[0]) ? messages.shift() : (0, helpers_1.isError)(messages[1]) ? messages.splice(1, 1).shift() : undefined;
122
+ const message = typeof messages[0] === 'string' ? messages.shift() : '';
123
+ if (messages.length === 1 && typeof messages[0] === 'object') {
124
+ data = Object.assign(data ?? {}, messages[0]);
125
+ }
126
+ else if (messages.length) {
127
+ data = data || {};
128
+ messages.forEach(__assignType((msg, idx) => {
129
+ data[`arg${idx}`] = msg;
130
+ }, ['msg', 'idx', '', 'P"2!"2""/#']));
131
+ }
132
+ else {
133
+ data = undefined;
134
+ }
135
+ if (!err && data && 'err' in data) {
136
+ err = data.err;
137
+ delete data.err;
138
+ }
139
+ if (this.scopeData) {
140
+ data = Object.assign(data ?? {}, this.scopeData);
141
+ }
142
+ const strippedMessage = this.stripColors(message);
143
+ // clean up errors that are too large and don't provide value to us
144
+ if (err instanceof orm_1.DatabaseError) {
145
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
146
+ delete err.entity;
147
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
148
+ delete err.classSchema;
149
+ }
150
+ else if ((0, axios_1.isAxiosError)(err)) {
151
+ err = transformAxiosError(err);
152
+ }
153
+ exports.pinoLogger[PinoSeverityMap[level]]({
154
+ ...(err && { err }),
155
+ ...(this.scope && { scope: this.scope }),
156
+ ...data,
157
+ ...this.getContextProps()
158
+ }, strippedMessage);
159
+ if (err || level === logger_1.LoggerLevel.alert || level === logger_1.LoggerLevel.error) {
160
+ this.handleError(level, strippedMessage, err, data);
161
+ }
162
+ }
163
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
164
+ debug(...message) {
165
+ if (!(0, debug_1.default)(this.scope).enabled)
166
+ return;
167
+ this.send(message, logger_1.LoggerLevel.debug);
168
+ }
169
+ getContextProps() {
170
+ const context = (0, helpers_1.getContext)();
171
+ if (!context)
172
+ return;
173
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
174
+ const entries = [];
175
+ for (const prop of exports.LoggerContextProps) {
176
+ if (context[prop]) {
177
+ entries.push([prop, context[prop]]);
178
+ }
179
+ }
180
+ if (context[exports.LoggerContextSymbol]) {
181
+ for (const [key, value] of Object.entries(context[exports.LoggerContextSymbol])) {
182
+ entries.push([key, value]);
183
+ }
184
+ }
185
+ if (!entries.length)
186
+ return;
187
+ return Object.fromEntries(entries);
188
+ }
189
+ stripColors(message) {
190
+ return message.includes('<') ? message.replace(/<(\/)?([a-zA-Z]+)>/g, '') : message;
191
+ }
192
+ setScopeData(data) {
193
+ this.scopeData = data;
194
+ return this;
195
+ }
196
+ handleError(level, message, err, data) {
197
+ const resolvedErr = message && message !== 'Controller error' ? new Error(message) : (err ?? new Error('Unknown error'));
198
+ resolvedErr.cause = resolvedErr !== err ? err : undefined;
199
+ (0, helpers_1.reportError)(level, resolvedErr, {
200
+ data,
201
+ scope: this.scope || undefined,
202
+ scopeData: this.scopeData,
203
+ ...this.getContextProps()
204
+ });
205
+ }
206
+ }
207
+ exports.ExtendedLogger = ExtendedLogger;
208
+ ExtendedLogger.__type = [() => logger_1.Logger, () => __ΩLogData, 'scopeData', () => __ΩLoggerFormatter, 'formatter', 'addFormatter', 'shortName', () => __ΩLogData, 'data', () => ExtendedLogger, 'scoped', 'messages', () => __ΩLoggerLevel, 'level', () => __ΩLogData, 'send', 'message', 'debug', 'getContextProps', 'stripColors', () => __ΩLogData, 'setScopeData', () => __ΩLoggerLevel, () => __ΩError, 'err', () => __ΩLogData, 'handleError', 'ExtendedLogger', 'P7!n"3#8<Pn$2%$0&P&2\'n(2)8P7*0+P"F2,n-2.n/2)8"00<P"@21$02P"03P&21"04Pn52)8"06Pn72.P&-J21Pn8-J29Pn:-J2)$0;5w<'];
209
+ function createLogger(subject, defaultData) {
210
+ const name = typeof subject === 'string' ? subject : subject.constructor.name;
211
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
212
+ return (resolver_1.r.Ω = [[() => ExtendedLogger, 'P7!']], (0, resolver_1.r)(logger_1.Logger)).scoped(name)
213
+ .setScopeData(defaultData);
214
+ }
215
+ createLogger.__type = [() => __ΩInstanceType, () => __ΩClassType, 'subject', () => __ΩLogData, 'defaultData', 'createLogger', 'PP&n"o!"J2#n$2%8"/&'];
216
+ function withLoggerContext(data, fn) {
217
+ const existingContext = (0, helpers_1.getContext)();
218
+ return (0, helpers_1.withContextData)({
219
+ [exports.LoggerContextSymbol]: {
220
+ ...existingContext?.[exports.LoggerContextSymbol],
221
+ ...data
222
+ }
223
+ }, fn);
224
+ }
225
+ withLoggerContext.__type = [() => __ΩLogData, 'data', '', 'fn', 'withLoggerContext', 'Pn!2"P"`/#2$"`/%'];
226
+ function transformAxiosError(err) {
227
+ return {
228
+ code: err.code,
229
+ message: err.message,
230
+ stack: err.stack,
231
+ request: {
232
+ url: err.config?.url,
233
+ method: err.config?.method,
234
+ headers: err.config?.headers,
235
+ data: err.config?.data
236
+ },
237
+ response: {
238
+ status: err.response?.status,
239
+ headers: err.response?.headers,
240
+ data: err.response?.data
241
+ }
242
+ };
243
+ }
244
+ transformAxiosError.__type = [() => axios_1.AxiosError, 'err', 'transformAxiosError', 'PP7!2""/#'];
245
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/services/logger.ts"],"names":[],"mappings":"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"}