@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,681 @@
1
+ import { ApplicationServer } from '@deepkit/framework';
2
+ import { ScopedLogger } from '@deepkit/logger';
3
+ import { createHmac, timingSafeEqual } from 'crypto';
4
+ import { IncomingMessage } from 'http';
5
+ import WebSocket from 'ws';
6
+
7
+ import { getAppConfig, r } from '../app/resolver';
8
+ import { uuid7 } from '../helpers';
9
+ import { withLoggerContext } from '../services';
10
+ import { getTraceContext, withRemoteSpan, withSpan } from '../telemetry';
11
+ import { SrpcByteStream } from './SrpcByteStream';
12
+ import {
13
+ BaseMessage,
14
+ HandlerRequestData,
15
+ InvokePrefixes,
16
+ IQueuedRequest,
17
+ ISrpcMessageHandler,
18
+ ISrpcServerOptions,
19
+ isSrpcMessageHandlerClass,
20
+ RequestData,
21
+ RequestKeys,
22
+ ResponseData,
23
+ SrpcDisconnectCause,
24
+ SrpcError,
25
+ SrpcMessageFns,
26
+ SrpcMeta,
27
+ SrpcStream,
28
+ TSrpcMessageHandlerFnOrClass
29
+ } from './types';
30
+ import { uuid } from '@deepkit/type';
31
+
32
+ const StreamInfoSymbol = Symbol('srpc-info');
33
+ const UpgradeClaimedSymbol = Symbol('srpc-upgrade-claimed');
34
+ const _patchedServers = new WeakSet<import('http').Server>();
35
+
36
+ /**
37
+ * Monkey-patches `httpServer.emit` so that once an upgrade listener claims
38
+ * a socket (by setting UpgradeClaimedSymbol), no further listeners are
39
+ * invoked. This prevents consumer @AutoStart services from destroying
40
+ * sockets that an SrpcServer is already handling.
41
+ *
42
+ * Also installs a low-priority fallback that destroys any socket not
43
+ * claimed by any handler (via setImmediate, after all sync work).
44
+ */
45
+ export function installUpgradeClaimHandling(httpServer: import('http').Server) {
46
+ if (_patchedServers.has(httpServer)) return;
47
+ _patchedServers.add(httpServer);
48
+
49
+ // Patch emit to stop propagation once a socket is claimed.
50
+ const originalEmit = httpServer.emit;
51
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
52
+ httpServer.emit = function (this: import('http').Server, event: string | symbol, ...args: any[]): boolean {
53
+ if (event !== 'upgrade') {
54
+ return originalEmit.apply(this, [event, ...args]);
55
+ }
56
+
57
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
58
+ const socket = args[1] as any;
59
+ const listeners = this.rawListeners('upgrade').slice();
60
+ for (const fn of listeners) {
61
+ (fn as Function).apply(this, args);
62
+ if (socket[UpgradeClaimedSymbol]) break;
63
+ }
64
+ return listeners.length > 0;
65
+ };
66
+
67
+ // Fallback: destroy sockets not claimed by any handler.
68
+ httpServer.on('upgrade', (_req, socket: import('net').Socket) => {
69
+ setImmediate(() => {
70
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
71
+ if (!(socket as any)[UpgradeClaimedSymbol] && !socket.destroyed) {
72
+ socket.write('HTTP/1.1 400 Bad Request\r\n\r\n');
73
+ socket.destroy();
74
+ }
75
+ });
76
+ });
77
+ }
78
+
79
+ /**
80
+ * Returns `true` if the given socket has already been claimed by an
81
+ * upgrade handler (via `markUpgradeClaimed`).
82
+ */
83
+ export function isUpgradeClaimed(socket: import('net').Socket): boolean {
84
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
85
+ return !!(socket as any)[UpgradeClaimedSymbol];
86
+ }
87
+
88
+ /**
89
+ * Mark a socket as claimed so that `installUpgradeClaimHandling`'s
90
+ * patched emit stops propagating the `'upgrade'` event to subsequent
91
+ * listeners. SrpcServer calls this automatically; consumer apps with
92
+ * their own WebSocket upgrade logic can call it to participate in the
93
+ * same claim protocol.
94
+ */
95
+ export function markUpgradeClaimed(socket: import('net').Socket): void {
96
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
97
+ (socket as any)[UpgradeClaimedSymbol] = true;
98
+ }
99
+
100
+ export class SrpcServer<
101
+ TMeta extends SrpcMeta = SrpcMeta,
102
+ TClientOutput extends BaseMessage = BaseMessage,
103
+ TServerOutput extends BaseMessage = BaseMessage
104
+ > {
105
+ private standardSrpcAuthKey?: string;
106
+ private authClockDriftMs: number;
107
+ private useRealIpHeader: boolean;
108
+
109
+ private logger: ScopedLogger;
110
+ private wsServer: WebSocket.Server;
111
+ private httpServer: import('http').Server;
112
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
113
+ private upgradeHandler: (...args: any[]) => void;
114
+ private inboundType: SrpcMessageFns<TClientOutput>;
115
+ private outboundType: SrpcMessageFns<TServerOutput>;
116
+
117
+ private clientAuthorizer?: (metadata: SrpcMeta, req: IncomingMessage) => Promise<boolean | SrpcMeta>;
118
+ private clientKeyFetcher?: (clientId: string) => Promise<false | string>;
119
+ private streamConnectionHandlers = new Set<(stream: SrpcStream<TMeta>) => void>();
120
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
121
+ private streamMessageHandlers = new Map<
122
+ RequestKeys<TClientOutput>,
123
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
124
+ { resultType: string; handler: TSrpcMessageHandlerFnOrClass<SrpcStream<TMeta>, any, any> }
125
+ >();
126
+ private streamDisconnectionHandlers = new Set<(stream: SrpcStream<TMeta>, cause: SrpcDisconnectCause) => void>();
127
+ private inactivityCheckInterval: ReturnType<typeof setInterval>;
128
+
129
+ public readonly streamsById = new Map<string, SrpcStream<TMeta>>();
130
+ public readonly streamsByClientId = new Map<string, SrpcStream<TMeta>>();
131
+
132
+ constructor(private options: ISrpcServerOptions<TClientOutput, TServerOutput>) {
133
+ const logLevel = options.logLevel ?? 'info';
134
+ if (logLevel === false) {
135
+ const noop = (() => {}) as any;
136
+ this.logger = { info: noop, warn: noop, error: noop, debug: noop } as any;
137
+ options.debug = false;
138
+ } else if (logLevel === 'debug') {
139
+ const base = options.logger;
140
+ this.logger = {
141
+ info: base.debug.bind(base),
142
+ warn: base.warn.bind(base),
143
+ error: base.error.bind(base),
144
+ debug: base.debug.bind(base)
145
+ } as any;
146
+ } else {
147
+ this.logger = options.logger;
148
+ }
149
+ this.inboundType = options.clientMessage;
150
+ this.outboundType = options.serverMessage;
151
+
152
+ const appConfig = getAppConfig();
153
+ this.standardSrpcAuthKey = appConfig.SRPC_AUTH_SECRET;
154
+ this.authClockDriftMs = appConfig.SRPC_AUTH_CLOCK_DRIFT_MS;
155
+ this.useRealIpHeader = appConfig.USE_REAL_IP_HEADER ?? false;
156
+
157
+ // WebSocket server setup — use noServer mode so multiple ws servers
158
+ // can coexist on the same HTTP server without aborting each other's
159
+ // upgrade requests (the default `{ server, path }` mode aborts
160
+ // non-matching upgrades, breaking other ws servers on the same port).
161
+ const app = r(ApplicationServer);
162
+ this.httpServer = app.getHttpWorker()['server']!;
163
+ this.wsServer = new WebSocket.Server({ noServer: true });
164
+ this.wsServer.on('connection', this.attachConnection.bind(this));
165
+
166
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
167
+ this.upgradeHandler = (req: IncomingMessage, socket: any, head: Buffer) => {
168
+ const pathname = req.url?.split('?')[0];
169
+ if (pathname !== options.wsPath) return;
170
+
171
+ markUpgradeClaimed(socket);
172
+
173
+ this.verifyClient({ origin: '', secure: false, req }, (allowed, code, message) => {
174
+ if (!allowed) {
175
+ socket.write(`HTTP/1.1 ${code ?? 403} ${message ?? 'Forbidden'}\r\n\r\n`);
176
+ socket.destroy();
177
+ return;
178
+ }
179
+ this.wsServer.handleUpgrade(req, socket, head, ws => {
180
+ this.wsServer.emit('connection', ws, req);
181
+ });
182
+ });
183
+ };
184
+ this.httpServer.prependListener('upgrade', this.upgradeHandler);
185
+ installUpgradeClaimHandling(this.httpServer);
186
+
187
+ this.logger.info('WebSocket server listening', { path: options.wsPath });
188
+
189
+ this.inactivityCheckInterval = setInterval(() => this.terminateInactiveStreams(), 15_000);
190
+ }
191
+
192
+ ////////////////////////////////////////
193
+ // WebSocket Connection Handling
194
+
195
+ private verifyClient(
196
+ info: { origin: string; secure: boolean; req: IncomingMessage },
197
+ cb: (res: boolean, code?: number, message?: string) => void
198
+ ) {
199
+ const url = new URL(info.req.url!, 'http://localhost');
200
+ const q = Object.fromEntries(url.searchParams.entries());
201
+
202
+ const { id: clientStreamId, cid: clientId, appv: appVersion } = q;
203
+ const address = (this.useRealIpHeader && info.req.headers['x-real-ip']) || info.req.socket.remoteAddress;
204
+
205
+ this.logger.info('Incoming streaming WebSocket request', {
206
+ address,
207
+ clientStreamId,
208
+ clientId,
209
+ appVersion
210
+ });
211
+
212
+ if (!clientStreamId || !clientId || !appVersion) {
213
+ this.logger.warn('Client missing required query parameters', { clientId, clientStreamId });
214
+ cb(false, 400, 'Missing required query parameters');
215
+ return;
216
+ }
217
+
218
+ this.validateClientAuth(q, info.req).then(
219
+ result => {
220
+ if (!result) {
221
+ this.logger.warn('Client failed authentication', { clientId, clientStreamId });
222
+ // eslint-disable-next-line promise/no-callback-in-promise
223
+ return cb(false, 403, 'Failed authentication');
224
+ }
225
+
226
+ const authMeta = result !== true ? result : undefined;
227
+ const meta = Object.fromEntries(
228
+ Object.entries(q)
229
+ .filter(([key]) => key.startsWith('m--'))
230
+ .map(([key, value]) => [key.slice(3), value])
231
+ );
232
+
233
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
234
+ (info.req as any)[StreamInfoSymbol] = {
235
+ clientStreamId,
236
+ clientId,
237
+ appVersion,
238
+ configureTs: parseInt(q.ts ?? '0'),
239
+ address,
240
+ meta: {
241
+ ...meta,
242
+ ...authMeta
243
+ }
244
+ };
245
+
246
+ // eslint-disable-next-line promise/no-callback-in-promise
247
+ cb(true);
248
+ },
249
+ err => {
250
+ this.logger.error('Error validating client auth', err, { clientId, clientStreamId });
251
+ // eslint-disable-next-line promise/no-callback-in-promise
252
+ cb(false, 500, 'Error during authentication');
253
+ }
254
+ );
255
+ }
256
+
257
+ private attachConnection(ws: WebSocket, req: IncomingMessage) {
258
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
259
+ const { clientId, clientStreamId, appVersion, address, configureTs, meta } = (req as any)[StreamInfoSymbol];
260
+
261
+ const streamId = uuid();
262
+
263
+ this.logger.info('WebSocket request answered', {
264
+ address,
265
+ streamId,
266
+ clientId,
267
+ clientStreamId,
268
+ meta
269
+ });
270
+
271
+ const now = Date.now();
272
+ const stream: SrpcStream<TMeta> = {
273
+ $ws: ws,
274
+ $queue: new Map<string, IQueuedRequest>(),
275
+ id: streamId,
276
+ clientStreamId,
277
+ address,
278
+ clientId,
279
+ appVersion,
280
+ configureTs,
281
+ connectedAt: now,
282
+ lastPingAt: now,
283
+ meta,
284
+ byteStream: {
285
+ parentStreamId: streamId,
286
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
287
+ write: (substreamId: number, chunk: any) => {
288
+ this.write(ws, { byteStreamOperation: { streamId: substreamId, write: { chunk } } } as TServerOutput);
289
+ return true;
290
+ },
291
+ finish: (substreamId: number) => {
292
+ this.write(ws, { byteStreamOperation: { streamId: substreamId, finish: {} } } as TServerOutput);
293
+ },
294
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
295
+ destroy: (substreamId: number, err?: any) => {
296
+ this.write(ws, {
297
+ byteStreamOperation: { streamId: substreamId, destroy: { error: err ? String(err) : undefined } }
298
+ } as TServerOutput);
299
+ },
300
+ attachDisconnectHandler(handler: () => void) {
301
+ ws.on('close', handler);
302
+ },
303
+ detachDisconnectHandler(handler: () => void) {
304
+ ws.off('close', handler);
305
+ },
306
+ getBufferedAmount() {
307
+ return ws.bufferedAmount;
308
+ }
309
+ }
310
+ };
311
+
312
+ SrpcByteStream.init(stream, { startId: 2, step: 2 });
313
+
314
+ ws.on('message', data => this.handleWsMessage(stream, data));
315
+ ws.on('error', err => this.handleStreamError(stream, err));
316
+ ws.on('close', () => this.handleStreamDisconnected(stream));
317
+
318
+ this.handleStreamEstablished(stream);
319
+ }
320
+
321
+ private handleWsMessage(stream: SrpcStream<TMeta>, data: WebSocket.Data) {
322
+ if (!(data instanceof Buffer)) {
323
+ return this.closeStreamWithError(stream, 'badArg', 'Received non-binary data');
324
+ }
325
+
326
+ try {
327
+ const decoded = this.inboundType.decode(data as Uint8Array);
328
+ this.handleStreamDataReceived(stream, decoded);
329
+ } catch (error) {
330
+ this.logger.warn('Failed to decode message', { error, streamId: stream.id, clientId: stream.clientId });
331
+ return this.closeStreamWithError(stream, 'badArg', 'Invalid message format');
332
+ }
333
+ }
334
+
335
+ private write(ws: WebSocket, message: TServerOutput) {
336
+ const encoded = this.outboundType.encode(message).finish();
337
+ ws.send(encoded);
338
+ }
339
+
340
+ private writeToStream(stream: SrpcStream<TMeta>, data: TServerOutput): void {
341
+ this.write(stream.$ws, data);
342
+ }
343
+
344
+ private closeStreamWithError(stream: SrpcStream<TMeta>, cause: SrpcDisconnectCause, message: string) {
345
+ stream.$ws.close(cause === 'disconnect' ? 1000 : 4000, message.substring(0, 123));
346
+ }
347
+
348
+ ////////////////////////////////////////
349
+ // Authentication
350
+
351
+ private async validateClientAuth(meta: SrpcMeta, req: IncomingMessage) {
352
+ if (this.clientAuthorizer) {
353
+ return this.clientAuthorizer(meta, req);
354
+ }
355
+
356
+ const { authv, appv, ts, id, cid, signature } = meta;
357
+ if (!meta.authv || !meta.appv || !meta.ts || !meta.signature) {
358
+ throw new Error('Missing authorization metadata');
359
+ }
360
+
361
+ const clientKey = await this.fetchClientKey(cid);
362
+ if (clientKey === false) return false;
363
+
364
+ const tsInt = parseInt(ts, 10);
365
+ if (isNaN(tsInt)) {
366
+ this.logger.warn('Invalid timestamp');
367
+ return false;
368
+ }
369
+
370
+ if (Math.abs(Date.now() - tsInt) > this.authClockDriftMs) {
371
+ this.logger.warn('Timestamp expired');
372
+ return false;
373
+ }
374
+
375
+ const computedSignature = createHmac('sha256', clientKey).update(`${authv}\n${appv}\n${ts}\n${id}\n${cid}\n`).digest('hex');
376
+
377
+ const sigBuf = Buffer.from(signature ?? '');
378
+ const computedBuf = Buffer.from(computedSignature);
379
+ if (sigBuf.length !== computedBuf.length || !timingSafeEqual(sigBuf, computedBuf)) {
380
+ this.logger.warn('Invalid signature');
381
+ return false;
382
+ }
383
+
384
+ return true;
385
+ }
386
+
387
+ private async fetchClientKey(clientId: string) {
388
+ if (this.clientKeyFetcher) return this.clientKeyFetcher(clientId);
389
+ if (!this.standardSrpcAuthKey) {
390
+ throw new Error('SRPC_AUTH_SECRET is not configured.');
391
+ }
392
+ return this.standardSrpcAuthKey;
393
+ }
394
+
395
+ setClientAuthorizer(authorizer: (metadata: SrpcMeta, req: IncomingMessage) => Promise<boolean | SrpcMeta>) {
396
+ this.clientAuthorizer = authorizer;
397
+ }
398
+
399
+ setClientKeyFetcher(fetcher: (clientId: string) => Promise<false | string>) {
400
+ this.clientKeyFetcher = fetcher;
401
+ }
402
+
403
+ close() {
404
+ clearInterval(this.inactivityCheckInterval);
405
+ this.httpServer.off('upgrade', this.upgradeHandler);
406
+ for (const stream of this.streamsById.values()) {
407
+ this.cleanupStream(stream, 'disconnect');
408
+ }
409
+ this.wsServer.close();
410
+ }
411
+
412
+ ////////////////////////////////////////
413
+ // Stream Lifecycle
414
+
415
+ private handleStreamEstablished(stream: SrpcStream<TMeta>) {
416
+ const conflictingStream = this.streamsByClientId.get(stream.clientId);
417
+ if (conflictingStream) {
418
+ this.logger.warn('Kicking existing stream with same client ID', {
419
+ streamId: stream.id,
420
+ clientId: stream.clientId,
421
+ conflictingStreamId: conflictingStream.id
422
+ });
423
+ this.cleanupStream(conflictingStream, 'duplicate');
424
+ }
425
+
426
+ this.streamsById.set(stream.id, stream);
427
+ this.streamsByClientId.set(stream.clientId, stream);
428
+ this.streamConnectionHandlers.forEach(handler => handler(stream));
429
+
430
+ this.writeToStream(stream, { pingPong: {} } as TServerOutput);
431
+ }
432
+
433
+ private handleStreamDisconnected(stream: SrpcStream<TMeta>): void {
434
+ const { id: streamId, clientId } = stream;
435
+ this.logger.info('Stream disconnected', { streamId, clientId });
436
+ this.cleanupStream(stream);
437
+ }
438
+
439
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
440
+ private handleStreamError(stream: SrpcStream<TMeta>, err: any): void {
441
+ const { id: streamId, clientId } = stream;
442
+ this.logger.warn('Stream error', { err, streamId, clientId });
443
+ this.cleanupStream(stream);
444
+ }
445
+
446
+ private terminateInactiveStreams() {
447
+ const deadlineMs = Date.now() - 75_000;
448
+ for (const stream of this.streamsById.values()) {
449
+ if (stream.lastPingAt < deadlineMs) {
450
+ this.logger.warn('Terminating inactive stream', { streamId: stream.id, clientId: stream.clientId });
451
+ this.cleanupStream(stream, 'timeout');
452
+ }
453
+ }
454
+ }
455
+
456
+ private cleanupStream(stream: SrpcStream<TMeta>, forceCause?: SrpcDisconnectCause) {
457
+ if (stream.lastPingAt < 0) return; // already cleaned up
458
+ stream.lastPingAt = -1;
459
+
460
+ if (forceCause) this.closeStreamWithError(stream, forceCause, `Stream terminated with cause: ${forceCause}`);
461
+ this.streamDisconnectionHandlers.forEach(handler => handler(stream, forceCause ?? 'disconnect'));
462
+
463
+ stream.$queue.forEach(item => item.reject(new Error('Stream disconnected')));
464
+ stream.$queue.clear();
465
+
466
+ this.streamsById.delete(stream.id);
467
+
468
+ if (this.streamsByClientId.get(stream.clientId) === stream) {
469
+ this.streamsByClientId.delete(stream.clientId);
470
+ }
471
+ }
472
+
473
+ ////////////////////////////////////////
474
+ // Message Handling
475
+
476
+ private handleStreamDataReceived(stream: SrpcStream<TMeta>, data: TClientOutput): void {
477
+ if (data.pingPong) {
478
+ stream.lastPingAt = Date.now();
479
+ return this.writeToStream(stream, { pingPong: {} } as TServerOutput);
480
+ }
481
+
482
+ if (data.byteStreamOperation) {
483
+ return this.handleByteSubstreamOperation(stream, data.byteStreamOperation);
484
+ }
485
+
486
+ const { id: streamId, clientId } = stream;
487
+ const { requestId, reply } = data;
488
+
489
+ const logObject = {
490
+ streamId,
491
+ clientId,
492
+ requestId,
493
+ reply,
494
+ error: data.userError ? 'user' : data.error ? 'application' : undefined
495
+ };
496
+ this.logger[this.options.debug ? 'info' : 'debug']('Client message received', this.options.debug ? { ...logObject, data } : logObject);
497
+
498
+ if (!requestId) {
499
+ this.logger.warn('Invalid request ID', { srpc: { streamId, clientId, requestId } });
500
+ return this.closeStreamWithError(stream, 'badArg', 'Invalid request ID');
501
+ }
502
+
503
+ if (reply) {
504
+ const queueItem = stream.$queue.get(requestId);
505
+ if (!queueItem) {
506
+ this.logger.warn('Unknown request ID for reply', { srpc: { streamId, clientId, requestId } });
507
+ return this.closeStreamWithError(stream, 'badArg', 'Unknown request ID');
508
+ }
509
+
510
+ stream.$queue.delete(requestId);
511
+ if (data.error) {
512
+ return queueItem.reject(new SrpcError(data.error, data.userError));
513
+ }
514
+ return queueItem.resolve(data);
515
+ }
516
+
517
+ this.handleClientRequest(stream, requestId, data).then(
518
+ response => {
519
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
520
+ this.writeToStream(stream, { requestId, reply: true, ...response } as any);
521
+ },
522
+ err => {
523
+ this.logger.warn('Error processing client request', err, { srpc: { streamId, clientId, requestId } });
524
+ const isUserError = err instanceof SrpcError && err.isUserError;
525
+ this.writeToStream(stream, {
526
+ requestId,
527
+ reply: true,
528
+ error: isUserError ? err.message : String(err),
529
+ userError: isUserError
530
+ } as TServerOutput);
531
+ }
532
+ );
533
+ }
534
+
535
+ private handleByteSubstreamOperation(stream: SrpcStream<TMeta>, op: NonNullable<TClientOutput['byteStreamOperation']>): void {
536
+ if (op.write) {
537
+ return SrpcByteStream.writeReceiver(stream, op.streamId, op.write.chunk);
538
+ }
539
+
540
+ if (op.finish) {
541
+ return SrpcByteStream.finishReceiver(stream, op.streamId);
542
+ }
543
+
544
+ if (op.destroy) {
545
+ return SrpcByteStream.destroySubstream(stream, op.streamId, op.destroy.error);
546
+ }
547
+ }
548
+
549
+ private async handleClientRequest(stream: SrpcStream<TMeta>, requestId: string, message: TClientOutput): Promise<Partial<TServerOutput>> {
550
+ const logMeta = { streamId: stream.id, clientId: stream.clientId, requestId };
551
+
552
+ for (const key of this.streamMessageHandlers.keys()) {
553
+ if (message[key]) {
554
+ Object.assign(logMeta, { requestType: key });
555
+ return withRemoteSpan('srpc:handleClientRequest', message.trace, logMeta, () =>
556
+ withLoggerContext({ srpc: logMeta }, async () => {
557
+ try {
558
+ this.logger.info('Client request received');
559
+ const handlerMeta = this.streamMessageHandlers.get(key)!;
560
+ const result = await this.runMessageHandler(handlerMeta.handler, stream, message[key]);
561
+ this.logger.info('Client request processed');
562
+ return {
563
+ [handlerMeta.resultType]: result
564
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
565
+ } as any;
566
+ } catch (err) {
567
+ this.logger.warn('Client request failed', err);
568
+ throw err;
569
+ }
570
+ })
571
+ );
572
+ }
573
+ }
574
+
575
+ throw new Error('Unhandled message type');
576
+ }
577
+
578
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
579
+ private async runMessageHandler(handler: TSrpcMessageHandlerFnOrClass<SrpcStream<TMeta>, any, any>, stream: SrpcStream<TMeta>, data: any) {
580
+ if (isSrpcMessageHandlerClass(handler)) {
581
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
582
+ const handlerInstance = new (handler as any)() as ISrpcMessageHandler<SrpcStream<TMeta>, any, any>;
583
+ return handlerInstance.handle(stream, data);
584
+ }
585
+
586
+ return handler(stream, data);
587
+ }
588
+
589
+ ////////////////////////////////////////
590
+ // Public API
591
+
592
+ registerConnectionHandler(handler: (stream: SrpcStream<TMeta>) => void) {
593
+ this.streamConnectionHandlers.add(handler);
594
+ }
595
+
596
+ /**
597
+ * Register a handler for client requests.
598
+ * @example server.registerMessageHandler('uEcho', async (stream, data) => ({ message: `Echo: ${data.message}` }))
599
+ */
600
+ registerMessageHandler<P extends InvokePrefixes<TClientOutput, TServerOutput>>(
601
+ prefix: P,
602
+ handler: TSrpcMessageHandlerFnOrClass<SrpcStream<TMeta>, HandlerRequestData<TClientOutput, P>, ResponseData<TServerOutput, P>>
603
+ ) {
604
+ const actionType = `${prefix}Request` as RequestKeys<TClientOutput>;
605
+ const resultType = `${prefix}Response`;
606
+ this.streamMessageHandlers.set(actionType, {
607
+ resultType,
608
+ handler
609
+ });
610
+ }
611
+
612
+ registerDisconnectHandler(handler: (stream: SrpcStream<TMeta>, cause: SrpcDisconnectCause) => void) {
613
+ this.streamDisconnectionHandlers.add(handler);
614
+ }
615
+
616
+ /**
617
+ * Invoke a client method.
618
+ * @example server.invoke(stream, 'dNotify', { notification: 'hello' })
619
+ */
620
+ invoke<P extends InvokePrefixes<TServerOutput, TClientOutput>>(
621
+ stream: SrpcStream<TMeta>,
622
+ prefix: P,
623
+ data: RequestData<TServerOutput, P>,
624
+ timeoutMs = 30_000
625
+ ): Promise<ResponseData<TClientOutput, P>> {
626
+ const requestType = `${prefix}Request`;
627
+ const resultType = `${prefix}Response`;
628
+ const requestId = uuid7();
629
+
630
+ const traceContext = getTraceContext();
631
+ const trace = traceContext ? { traceId: traceContext.traceId, spanId: traceContext.spanId, traceFlags: traceContext.traceFlags } : undefined;
632
+
633
+ const logMeta = { streamId: stream.id, clientId: stream.clientId, requestId, requestType };
634
+ return withSpan('srpc:invokeClient', logMeta, () =>
635
+ withLoggerContext({ srpc: logMeta }, async () => {
636
+ try {
637
+ this.logger.info('Requesting client invocation', this.options.debug ? { data } : undefined);
638
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
639
+ const response = await new Promise<any>((resolve, reject) => {
640
+ stream.$queue.set(requestId, {
641
+ exp: Date.now() + timeoutMs,
642
+ resolve,
643
+ reject
644
+ });
645
+ this.writeToStream(stream, { requestId, trace, [requestType]: data } as unknown as TServerOutput);
646
+ });
647
+
648
+ // Use null check instead of `in` for consistency with ts-proto field materialization
649
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
650
+ if ((response as any)[resultType] == null) {
651
+ throw new Error('Invalid response from client');
652
+ }
653
+
654
+ this.logger.info('Client invocation completed');
655
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
656
+ return (response as any)[resultType];
657
+ } catch (err) {
658
+ const isUserError = err instanceof SrpcError && err.isUserError;
659
+ if (isUserError) {
660
+ this.logger.warn('Client invocation returned user error', { err: err.message });
661
+ } else {
662
+ this.logger.warn('Client invocation failed', err);
663
+ }
664
+ throw err;
665
+ }
666
+ })
667
+ );
668
+ }
669
+
670
+ static createInvoke<TM extends SrpcMeta, TCO extends BaseMessage, TSO extends BaseMessage>(
671
+ instanceFn: () => SrpcServer<TM, TCO, TSO>
672
+ ): SrpcServer<TM, TCO, TSO>['invoke'] {
673
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
674
+ const fn = (...args: any[]) => {
675
+ const instance = instanceFn();
676
+ // eslint-disable-next-line prefer-spread, @typescript-eslint/no-explicit-any
677
+ return instance.invoke.apply(instance, args as any);
678
+ };
679
+ return fn as SrpcServer<TM, TCO, TSO>['invoke'];
680
+ }
681
+ }
@@ -0,0 +1,15 @@
1
+ export { SrpcByteStream } from './SrpcByteStream';
2
+ export type { SrpcClientOptions } from './SrpcClient';
3
+ export { SrpcClient } from './SrpcClient';
4
+ export { SrpcServer } from './SrpcServer';
5
+ export type {
6
+ HandlerRequestData,
7
+ InvokePrefixes,
8
+ RequestData,
9
+ ResponseData,
10
+ SrpcDisconnectCause,
11
+ SrpcMessageFns,
12
+ SrpcMeta,
13
+ SrpcStream
14
+ } from './types';
15
+ export { SrpcError } from './types';