@social.dev/server-sdk 0.0.1-alpha.8 → 0.0.1-alpha.81

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (345) hide show
  1. package/README.md +696 -40
  2. package/dist/__mocks__/kafka.mock.d.ts +11 -0
  3. package/dist/__mocks__/kafka.mock.js +15 -0
  4. package/dist/__mocks__/kafka.mock.js.map +1 -0
  5. package/dist/app.module.d.ts +4 -4
  6. package/dist/app.module.js +17 -7
  7. package/dist/app.module.js.map +1 -1
  8. package/dist/auth/auth.controller.d.ts +7 -1
  9. package/dist/auth/auth.controller.js +28 -3
  10. package/dist/auth/auth.controller.js.map +1 -1
  11. package/dist/auth/auth.middleware.d.ts +3 -5
  12. package/dist/auth/auth.middleware.js +7 -15
  13. package/dist/auth/auth.middleware.js.map +1 -1
  14. package/dist/auth/auth.module.js +4 -1
  15. package/dist/auth/auth.module.js.map +1 -1
  16. package/dist/auth/auth.service.d.ts +9 -1
  17. package/dist/auth/auth.service.js +34 -2
  18. package/dist/auth/auth.service.js.map +1 -1
  19. package/dist/auth/constants.js +2 -1
  20. package/dist/auth/constants.js.map +1 -1
  21. package/dist/auth/dto/login-success.dto.d.ts +1 -1
  22. package/dist/auth/dto/login-success.dto.js +6 -3
  23. package/dist/auth/dto/login-success.dto.js.map +1 -1
  24. package/dist/auth/dto/register-success.dto.d.ts +3 -0
  25. package/dist/auth/dto/register-success.dto.js +12 -0
  26. package/dist/auth/dto/register-success.dto.js.map +1 -0
  27. package/dist/auth/dto/register.dto.d.ts +6 -0
  28. package/dist/auth/dto/register.dto.js +45 -0
  29. package/dist/auth/dto/register.dto.js.map +1 -0
  30. package/dist/auth/oidc/dto/requests.d.ts +6 -0
  31. package/dist/auth/oidc/dto/requests.js +47 -0
  32. package/dist/auth/oidc/dto/requests.js.map +1 -0
  33. package/dist/auth/oidc/dto/responses.js +1 -1
  34. package/dist/auth/oidc/oidc.controller.d.ts +7 -2
  35. package/dist/auth/oidc/oidc.controller.js +31 -17
  36. package/dist/auth/oidc/oidc.controller.js.map +1 -1
  37. package/dist/auth/oidc/oidc.service.d.ts +9 -4
  38. package/dist/auth/oidc/oidc.service.js +64 -38
  39. package/dist/auth/oidc/oidc.service.js.map +1 -1
  40. package/dist/auth/session/session.controller.js +8 -3
  41. package/dist/auth/session/session.controller.js.map +1 -1
  42. package/dist/auth/session/session.service.d.ts +2 -2
  43. package/dist/auth/session/session.service.js +14 -7
  44. package/dist/auth/session/session.service.js.map +1 -1
  45. package/dist/bootstrap.d.ts +2 -1
  46. package/dist/bootstrap.js +7 -1
  47. package/dist/bootstrap.js.map +1 -1
  48. package/dist/chat/chat.acl.d.ts +3 -0
  49. package/dist/chat/chat.acl.js +50 -0
  50. package/dist/chat/chat.acl.js.map +1 -0
  51. package/dist/chat/chat.controller.d.ts +15 -6
  52. package/dist/chat/chat.controller.js +153 -14
  53. package/dist/chat/chat.controller.js.map +1 -1
  54. package/dist/chat/chat.module.d.ts +3 -0
  55. package/dist/chat/chat.module.js +30 -4
  56. package/dist/chat/chat.module.js.map +1 -1
  57. package/dist/chat/chat.service.d.ts +63 -12
  58. package/dist/chat/chat.service.js +468 -36
  59. package/dist/chat/chat.service.js.map +1 -1
  60. package/dist/chat/dto/add-reaction.dto.d.ts +5 -0
  61. package/dist/chat/dto/add-reaction.dto.js +42 -0
  62. package/dist/chat/dto/add-reaction.dto.js.map +1 -0
  63. package/dist/chat/dto/create-message.dto.d.ts +4 -1
  64. package/dist/chat/dto/create-message.dto.js +23 -1
  65. package/dist/chat/dto/create-message.dto.js.map +1 -1
  66. package/dist/chat/dto/edit-message.dto.d.ts +5 -0
  67. package/dist/chat/dto/edit-message.dto.js +31 -0
  68. package/dist/chat/dto/edit-message.dto.js.map +1 -0
  69. package/dist/chat/dto/responses.dto.d.ts +27 -5
  70. package/dist/chat/dto/responses.dto.js +177 -18
  71. package/dist/chat/dto/responses.dto.js.map +1 -1
  72. package/dist/chat/dto/update-cursor.dto.d.ts +5 -0
  73. package/dist/chat/dto/update-cursor.dto.js +36 -0
  74. package/dist/chat/dto/update-cursor.dto.js.map +1 -0
  75. package/dist/chat/entities/conversation-member.entity.js +1 -1
  76. package/dist/chat/entities/conversation-member.entity.js.map +1 -1
  77. package/dist/chat/entities/conversation.entity.d.ts +4 -0
  78. package/dist/chat/entities/conversation.entity.js +13 -1
  79. package/dist/chat/entities/conversation.entity.js.map +1 -1
  80. package/dist/chat/entities/message.entity.d.ts +8 -0
  81. package/dist/chat/entities/message.entity.js +32 -2
  82. package/dist/chat/entities/message.entity.js.map +1 -1
  83. package/dist/chat/entities/reaction.entity.d.ts +10 -0
  84. package/dist/chat/entities/reaction.entity.js +62 -0
  85. package/dist/chat/entities/reaction.entity.js.map +1 -0
  86. package/dist/chat/entities/read-cursor.entity.d.ts +10 -0
  87. package/dist/chat/entities/read-cursor.entity.js +64 -0
  88. package/dist/chat/entities/read-cursor.entity.js.map +1 -0
  89. package/dist/chat/enums/conversation-type.enum.d.ts +2 -1
  90. package/dist/chat/enums/conversation-type.enum.js +1 -0
  91. package/dist/chat/enums/conversation-type.enum.js.map +1 -1
  92. package/dist/common/decorators/api-paginated-response.d.ts +1 -1
  93. package/dist/common/decorators/api-paginated-response.js +2 -2
  94. package/dist/common/decorators/api-paginated-response.js.map +1 -1
  95. package/dist/common/dto/paginated-response.dto.d.ts +2 -0
  96. package/dist/common/dto/paginated-response.dto.js +14 -3
  97. package/dist/common/dto/paginated-response.dto.js.map +1 -1
  98. package/dist/common/injection-tokens.d.ts +2 -0
  99. package/dist/common/injection-tokens.js +3 -1
  100. package/dist/common/injection-tokens.js.map +1 -1
  101. package/dist/common/utils/cursor.d.ts +2 -0
  102. package/dist/common/utils/cursor.js +12 -0
  103. package/dist/common/utils/cursor.js.map +1 -0
  104. package/dist/community/avatar/avatar.controller.d.ts +11 -0
  105. package/dist/community/avatar/avatar.controller.js +90 -0
  106. package/dist/community/avatar/avatar.controller.js.map +1 -0
  107. package/dist/community/avatar/avatar.service.d.ts +13 -0
  108. package/dist/community/avatar/avatar.service.js +78 -0
  109. package/dist/community/avatar/avatar.service.js.map +1 -0
  110. package/dist/community/community.acl.d.ts +6 -3
  111. package/dist/community/community.acl.js +58 -35
  112. package/dist/community/community.acl.js.map +1 -1
  113. package/dist/community/community.controller.d.ts +8 -5
  114. package/dist/community/community.controller.js +102 -17
  115. package/dist/community/community.controller.js.map +1 -1
  116. package/dist/community/community.module.d.ts +3 -0
  117. package/dist/community/community.module.js +17 -7
  118. package/dist/community/community.module.js.map +1 -1
  119. package/dist/community/community.service.d.ts +26 -6
  120. package/dist/community/community.service.js +152 -23
  121. package/dist/community/community.service.js.map +1 -1
  122. package/dist/community/dto/community-response.dto.d.ts +5 -1
  123. package/dist/community/dto/community-response.dto.js +30 -1
  124. package/dist/community/dto/community-response.dto.js.map +1 -1
  125. package/dist/community/dto/create-community.dto.d.ts +2 -0
  126. package/dist/community/dto/create-community.dto.js +14 -2
  127. package/dist/community/dto/create-community.dto.js.map +1 -1
  128. package/dist/community/dto/update-community.dto.d.ts +2 -0
  129. package/dist/community/dto/update-community.dto.js +15 -1
  130. package/dist/community/dto/update-community.dto.js.map +1 -1
  131. package/dist/community/entities/community-member.entity.js +1 -0
  132. package/dist/community/entities/community-member.entity.js.map +1 -1
  133. package/dist/community/entities/community.entity.d.ts +2 -0
  134. package/dist/community/entities/community.entity.js +11 -1
  135. package/dist/community/entities/community.entity.js.map +1 -1
  136. package/dist/configs/configs.service.d.ts +12 -2
  137. package/dist/configs/configs.service.js.map +1 -1
  138. package/dist/core/context/context.d.ts +3 -0
  139. package/dist/core/context/context.js +15 -0
  140. package/dist/core/context/context.js.map +1 -1
  141. package/dist/core/context/context.store.d.ts +2 -0
  142. package/dist/core/core.module.js +2 -1
  143. package/dist/core/core.module.js.map +1 -1
  144. package/dist/core/event-stream/event-stream-processor.interface.d.ts +8 -0
  145. package/dist/core/event-stream/event-stream-processor.interface.js +3 -0
  146. package/dist/core/event-stream/event-stream-processor.interface.js.map +1 -0
  147. package/dist/core/event-stream/event-stream-processor.service.d.ts +13 -0
  148. package/dist/core/event-stream/event-stream-processor.service.js +60 -0
  149. package/dist/core/event-stream/event-stream-processor.service.js.map +1 -0
  150. package/dist/core/event-stream/event-stream.module.d.ts +11 -0
  151. package/dist/core/event-stream/event-stream.module.js +50 -0
  152. package/dist/core/event-stream/event-stream.module.js.map +1 -0
  153. package/dist/core/event-stream/event-stream.service.d.ts +18 -0
  154. package/dist/core/event-stream/event-stream.service.js +107 -0
  155. package/dist/core/event-stream/event-stream.service.js.map +1 -0
  156. package/dist/core/event-stream/types.d.ts +3 -0
  157. package/dist/core/event-stream/types.js +3 -0
  158. package/dist/core/event-stream/types.js.map +1 -0
  159. package/dist/core/hook/hook.module.d.ts +4 -0
  160. package/dist/core/hook/hook.module.js +30 -0
  161. package/dist/core/hook/hook.module.js.map +1 -0
  162. package/dist/core/hook/hook.service.d.ts +7 -0
  163. package/dist/core/{plugin/plugin-hook.service.js → hook/hook.service.js} +10 -10
  164. package/dist/core/hook/hook.service.js.map +1 -0
  165. package/dist/core/plugin/plugin.module.js +5 -6
  166. package/dist/core/plugin/plugin.module.js.map +1 -1
  167. package/dist/core/websocket/gateway.service.d.ts +24 -0
  168. package/dist/core/websocket/gateway.service.js +150 -0
  169. package/dist/core/websocket/gateway.service.js.map +1 -0
  170. package/dist/core/websocket/websocket.module.d.ts +2 -0
  171. package/dist/core/websocket/websocket.module.js +24 -0
  172. package/dist/core/websocket/websocket.module.js.map +1 -0
  173. package/dist/db.js +2 -1
  174. package/dist/db.js.map +1 -1
  175. package/dist/file-storage/file-storage.service.d.ts +1 -1
  176. package/dist/file-storage/file-storage.service.js +6 -6
  177. package/dist/file-storage/file-storage.service.js.map +1 -1
  178. package/dist/file-storage/utils.d.ts +2 -0
  179. package/dist/file-storage/utils.js +9 -2
  180. package/dist/file-storage/utils.js.map +1 -1
  181. package/dist/index.d.ts +0 -1
  182. package/dist/index.js +1 -3
  183. package/dist/index.js.map +1 -1
  184. package/dist/manage-db.d.ts +1 -0
  185. package/dist/manage-db.js +10 -0
  186. package/dist/manage-db.js.map +1 -0
  187. package/dist/media/dto/media-response.dto.d.ts +2 -0
  188. package/dist/media/dto/media-response.dto.js +15 -2
  189. package/dist/media/dto/media-response.dto.js.map +1 -1
  190. package/dist/media/entities/audio.entity.d.ts +2 -2
  191. package/dist/media/entities/audio.entity.js +2 -2
  192. package/dist/media/entities/audio.entity.js.map +1 -1
  193. package/dist/media/entities/image.entity.d.ts +5 -0
  194. package/dist/media/entities/{post-media.entity.js → image.entity.js} +16 -12
  195. package/dist/media/entities/image.entity.js.map +1 -0
  196. package/dist/media/entities/media.entity.d.ts +6 -0
  197. package/dist/media/entities/media.entity.js +25 -2
  198. package/dist/media/entities/media.entity.js.map +1 -1
  199. package/dist/media/media.acl.d.ts +2 -4
  200. package/dist/media/media.acl.js +22 -1
  201. package/dist/media/media.acl.js.map +1 -1
  202. package/dist/media/media.controller.d.ts +2 -0
  203. package/dist/media/media.controller.js +58 -0
  204. package/dist/media/media.controller.js.map +1 -1
  205. package/dist/media/media.module.js +2 -1
  206. package/dist/media/media.module.js.map +1 -1
  207. package/dist/media/media.service.d.ts +6 -3
  208. package/dist/media/media.service.js +118 -19
  209. package/dist/media/media.service.js.map +1 -1
  210. package/dist/migrations/1757061785934-PushNotificationTokens.d.ts +6 -0
  211. package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
  212. package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
  213. package/dist/migrations/1758623241397-AddUserTimestamps.d.ts +6 -0
  214. package/dist/migrations/1758623241397-AddUserTimestamps.js +16 -0
  215. package/dist/migrations/1758623241397-AddUserTimestamps.js.map +1 -0
  216. package/dist/migrations/1758704603161-UserFollows.d.ts +6 -0
  217. package/dist/migrations/1758704603161-UserFollows.js +18 -0
  218. package/dist/migrations/1758704603161-UserFollows.js.map +1 -0
  219. package/dist/migrations/1759757532702-UpdateCommunityCascades.d.ts +6 -0
  220. package/dist/migrations/1759757532702-UpdateCommunityCascades.js +20 -0
  221. package/dist/migrations/1759757532702-UpdateCommunityCascades.js.map +1 -0
  222. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.d.ts +6 -0
  223. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js +16 -0
  224. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js.map +1 -0
  225. package/dist/migrations/1759919335188-CommunityChats.d.ts +6 -0
  226. package/dist/migrations/1759919335188-CommunityChats.js +28 -0
  227. package/dist/migrations/1759919335188-CommunityChats.js.map +1 -0
  228. package/dist/migrations/1760363804673-ChatVoiceNotes.d.ts +6 -0
  229. package/dist/migrations/1760363804673-ChatVoiceNotes.js +24 -0
  230. package/dist/migrations/1760363804673-ChatVoiceNotes.js.map +1 -0
  231. package/dist/migrations/1760444646328-ChatReadCursor.d.ts +6 -0
  232. package/dist/migrations/1760444646328-ChatReadCursor.js +18 -0
  233. package/dist/migrations/1760444646328-ChatReadCursor.js.map +1 -0
  234. package/dist/migrations/1761598291629-AddChatImages.d.ts +6 -0
  235. package/dist/migrations/1761598291629-AddChatImages.js +16 -0
  236. package/dist/migrations/1761598291629-AddChatImages.js.map +1 -0
  237. package/dist/migrations/1761648419807-ChatReactions.d.ts +6 -0
  238. package/dist/migrations/1761648419807-ChatReactions.js +18 -0
  239. package/dist/migrations/1761648419807-ChatReactions.js.map +1 -0
  240. package/dist/migrations/1762953835109-AddChatReplies.d.ts +6 -0
  241. package/dist/migrations/1762953835109-AddChatReplies.js +22 -0
  242. package/dist/migrations/1762953835109-AddChatReplies.js.map +1 -0
  243. package/dist/network/entities/network.entity.js +1 -3
  244. package/dist/network/entities/network.entity.js.map +1 -1
  245. package/dist/network/network.middleware.d.ts +3 -1
  246. package/dist/network/network.middleware.js +12 -4
  247. package/dist/network/network.middleware.js.map +1 -1
  248. package/dist/network/network.module.js +2 -1
  249. package/dist/network/network.module.js.map +1 -1
  250. package/dist/network/network.service.d.ts +4 -2
  251. package/dist/network/network.service.js +16 -6
  252. package/dist/network/network.service.js.map +1 -1
  253. package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
  254. package/dist/notification/dto/delete-push-token.dto.js +26 -0
  255. package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
  256. package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
  257. package/dist/notification/dto/register-push-token.dto.js +38 -0
  258. package/dist/notification/dto/register-push-token.dto.js.map +1 -0
  259. package/dist/notification/entities/push-token.entity.d.ts +11 -0
  260. package/dist/notification/entities/push-token.entity.js +60 -0
  261. package/dist/notification/entities/push-token.entity.js.map +1 -0
  262. package/dist/notification/enums/push-service.enum.d.ts +6 -0
  263. package/dist/notification/enums/push-service.enum.js +11 -0
  264. package/dist/notification/enums/push-service.enum.js.map +1 -0
  265. package/dist/notification/hook-listener.service.d.ts +13 -0
  266. package/dist/notification/hook-listener.service.js +58 -0
  267. package/dist/notification/hook-listener.service.js.map +1 -0
  268. package/dist/notification/notification.module.d.ts +2 -0
  269. package/dist/notification/notification.module.js +24 -0
  270. package/dist/notification/notification.module.js.map +1 -0
  271. package/dist/notification/push-notification.controller.d.ts +9 -0
  272. package/dist/notification/push-notification.controller.js +69 -0
  273. package/dist/notification/push-notification.controller.js.map +1 -0
  274. package/dist/notification/push-notification.module.d.ts +2 -0
  275. package/dist/notification/push-notification.module.js +27 -0
  276. package/dist/notification/push-notification.module.js.map +1 -0
  277. package/dist/notification/push-notification.service.d.ts +23 -0
  278. package/dist/notification/push-notification.service.js +89 -0
  279. package/dist/notification/push-notification.service.js.map +1 -0
  280. package/dist/post/entities/post.entity.js +3 -3
  281. package/dist/post/entities/post.entity.js.map +1 -1
  282. package/dist/post/post.controller.d.ts +3 -2
  283. package/dist/post/post.controller.js +28 -8
  284. package/dist/post/post.controller.js.map +1 -1
  285. package/dist/post/post.module.js +2 -0
  286. package/dist/post/post.module.js.map +1 -1
  287. package/dist/post/post.service.d.ts +7 -3
  288. package/dist/post/post.service.js +18 -8
  289. package/dist/post/post.service.js.map +1 -1
  290. package/dist/tsconfig.build.tsbuildinfo +1 -1
  291. package/dist/user/avatar/avatar.controller.d.ts +10 -0
  292. package/dist/user/avatar/avatar.controller.js +89 -0
  293. package/dist/user/avatar/avatar.controller.js.map +1 -0
  294. package/dist/user/avatar/avatar.service.d.ts +12 -0
  295. package/dist/user/avatar/avatar.service.js +72 -0
  296. package/dist/user/avatar/avatar.service.js.map +1 -0
  297. package/dist/user/constants.d.ts +1 -0
  298. package/dist/user/constants.js +5 -0
  299. package/dist/user/constants.js.map +1 -0
  300. package/dist/user/dto/update-profile.dto.d.ts +3 -0
  301. package/dist/user/dto/update-profile.dto.js +26 -0
  302. package/dist/user/dto/update-profile.dto.js.map +1 -0
  303. package/dist/user/dto/user-response.dto.d.ts +6 -0
  304. package/dist/user/dto/user-response.dto.js +37 -1
  305. package/dist/user/dto/user-response.dto.js.map +1 -1
  306. package/dist/user/dto/user.dto.d.ts +8 -0
  307. package/dist/user/dto/user.dto.js +21 -0
  308. package/dist/user/dto/user.dto.js.map +1 -0
  309. package/dist/user/entities/user.entity.d.ts +4 -0
  310. package/dist/user/entities/user.entity.js +19 -1
  311. package/dist/user/entities/user.entity.js.map +1 -1
  312. package/dist/user/follow/dto/follow-response.dto.d.ts +4 -0
  313. package/dist/user/follow/dto/follow-response.dto.js +38 -0
  314. package/dist/user/follow/dto/follow-response.dto.js.map +1 -0
  315. package/dist/user/follow/dto/follow.dto.d.ts +4 -0
  316. package/dist/user/follow/dto/follow.dto.js +26 -0
  317. package/dist/user/follow/dto/follow.dto.js.map +1 -0
  318. package/dist/user/follow/entities/follow.entity.d.ts +10 -0
  319. package/dist/user/follow/entities/follow.entity.js +60 -0
  320. package/dist/user/follow/entities/follow.entity.js.map +1 -0
  321. package/dist/user/follow/follow.controller.d.ts +9 -0
  322. package/dist/user/follow/follow.controller.js +56 -0
  323. package/dist/user/follow/follow.controller.js.map +1 -0
  324. package/dist/user/follow/follow.module.d.ts +2 -0
  325. package/dist/user/follow/follow.module.js +26 -0
  326. package/dist/user/follow/follow.module.js.map +1 -0
  327. package/dist/user/follow/follow.service.d.ts +11 -0
  328. package/dist/user/follow/follow.service.js +56 -0
  329. package/dist/user/follow/follow.service.js.map +1 -0
  330. package/dist/user/user.controller.d.ts +4 -1
  331. package/dist/user/user.controller.js +38 -4
  332. package/dist/user/user.controller.js.map +1 -1
  333. package/dist/user/user.module.js +12 -3
  334. package/dist/user/user.module.js.map +1 -1
  335. package/dist/user/user.service.d.ts +12 -5
  336. package/dist/user/user.service.js +49 -11
  337. package/dist/user/user.service.js.map +1 -1
  338. package/package.json +16 -5
  339. package/dist/core/plugin/plugin-hook.service.d.ts +0 -7
  340. package/dist/core/plugin/plugin-hook.service.js.map +0 -1
  341. package/dist/media/entities/post-media.entity.d.ts +0 -5
  342. package/dist/media/entities/post-media.entity.js.map +0 -1
  343. package/dist/user/dto/update-user.dto.d.ts +0 -5
  344. package/dist/user/dto/update-user.dto.js +0 -13
  345. package/dist/user/dto/update-user.dto.js.map +0 -1
@@ -0,0 +1,11 @@
1
+ export declare const Kafka: jest.Mock<any, any, any>;
2
+ export declare const Producer: jest.Mock<any, any, any>;
3
+ export declare const Consumer: jest.Mock<any, any, any>;
4
+ export declare const Admin: jest.Mock<any, any, any>;
5
+ export declare const logLevel: {
6
+ NOTHING: number;
7
+ ERROR: number;
8
+ WARN: number;
9
+ INFO: number;
10
+ DEBUG: number;
11
+ };
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.logLevel = exports.Admin = exports.Consumer = exports.Producer = exports.Kafka = void 0;
4
+ exports.Kafka = jest.fn();
5
+ exports.Producer = jest.fn();
6
+ exports.Consumer = jest.fn();
7
+ exports.Admin = jest.fn();
8
+ exports.logLevel = {
9
+ NOTHING: 0,
10
+ ERROR: 1,
11
+ WARN: 2,
12
+ INFO: 4,
13
+ DEBUG: 5,
14
+ };
15
+ //# sourceMappingURL=kafka.mock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kafka.mock.js","sourceRoot":"","sources":["../../src/__mocks__/kafka.mock.ts"],"names":[],"mappings":";;;AACa,QAAA,KAAK,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAClB,QAAA,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACrB,QAAA,QAAQ,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AACrB,QAAA,KAAK,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAClB,QAAA,QAAQ,GAAG;IACtB,OAAO,EAAE,CAAC;IACV,KAAK,EAAE,CAAC;IACR,IAAI,EAAE,CAAC;IACP,IAAI,EAAE,CAAC;IACP,KAAK,EAAE,CAAC;CACT,CAAC"}
@@ -1,10 +1,10 @@
1
1
  import { MiddlewareConsumer, NestModule } from '@nestjs/common';
2
2
  import { ContextService } from './core/context/context.service';
3
- import { DataSource } from 'typeorm';
3
+ import { EventStreamService } from './core/event-stream/event-stream.service';
4
4
  export declare class AppModule implements NestModule {
5
5
  private readonly contextService;
6
- private readonly dataSource;
7
- constructor(contextService: ContextService, dataSource: DataSource);
8
- onModuleInit(): void;
6
+ private readonly eventStream;
7
+ constructor(contextService: ContextService, eventStream: EventStreamService);
8
+ onModuleInit(): Promise<void>;
9
9
  configure(consumer: MiddlewareConsumer): void;
10
10
  }
@@ -31,17 +31,25 @@ const context_service_1 = require("./core/context/context.service");
31
31
  const chat_module_1 = require("./chat/chat.module");
32
32
  const core_module_1 = require("./core/core.module");
33
33
  const context_module_1 = require("./core/context/context.module");
34
- const typeorm_2 = require("typeorm");
35
34
  const db_1 = __importDefault(require("./db"));
35
+ const notification_module_1 = require("./notification/notification.module");
36
+ const event_stream_module_1 = require("./core/event-stream/event-stream.module");
37
+ const event_stream_service_1 = require("./core/event-stream/event-stream.service");
36
38
  let AppModule = class AppModule {
37
39
  contextService;
38
- dataSource;
39
- constructor(contextService, dataSource) {
40
+ eventStream;
41
+ constructor(contextService, eventStream) {
40
42
  this.contextService = contextService;
41
- this.dataSource = dataSource;
43
+ this.eventStream = eventStream;
42
44
  }
43
- onModuleInit() {
45
+ async onModuleInit() {
44
46
  context_1.Context.setService(this.contextService);
47
+ try {
48
+ await this.eventStream.createTopics();
49
+ }
50
+ catch (err) {
51
+ console.error('Unable to create event stream topics', err);
52
+ }
45
53
  }
46
54
  configure(consumer) {
47
55
  consumer.apply(network_middleware_1.NetworkContextMiddleware).forRoutes('*');
@@ -65,8 +73,10 @@ exports.AppModule = AppModule = __decorate([
65
73
  auth_module_1.AuthModule,
66
74
  configs_module_1.ConfigsModule,
67
75
  post_module_1.PostModule,
68
- media_module_1.MediaModule,
69
76
  chat_module_1.ChatModule,
77
+ media_module_1.MediaModule,
78
+ notification_module_1.NotificationModule,
79
+ event_stream_module_1.EventStreamModule.forRoot(),
70
80
  ],
71
81
  providers: [
72
82
  {
@@ -82,6 +92,6 @@ exports.AppModule = AppModule = __decorate([
82
92
  ],
83
93
  }),
84
94
  __metadata("design:paramtypes", [context_service_1.ContextService,
85
- typeorm_2.DataSource])
95
+ event_stream_service_1.EventStreamService])
86
96
  ], AppModule);
87
97
  //# sourceMappingURL=app.module.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,6CAAgD;AAChD,2CAA8C;AAC9C,oDAAgD;AAEhD,6DAAyD;AAEzD,mEAA+D;AAC/D,oDAAgD;AAEhD,uCAA0D;AAC1D,oDAAgD;AAChD,4DAAwD;AACxD,6DAAyD;AACzD,qEAAwE;AACxE,uDAAmD;AACnD,oDAAiD;AACjD,oEAAgE;AAChE,oDAAgD;AAChD,oDAAgD;AAChD,kEAA8D;AAC9D,qCAAqC;AACrC,8CAAmC;AAiC5B,IAAM,SAAS,GAAf,MAAM,SAAS;IAED;IACA;IAFnB,YACmB,cAA8B,EAC9B,UAAsB;QADtB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,eAAU,GAAV,UAAU,CAAY;IACtC,CAAC;IAEJ,YAAY;QAEV,iBAAO,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC1C,CAAC;IAED,SAAS,CAAC,QAA4B;QACpC,QAAQ,CAAC,KAAK,CAAC,6CAAwB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACxD,QAAQ,CAAC,KAAK,CAAC,gCAAc,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAChD,CAAC;CACF,CAAA;AAfY,8BAAS;oBAAT,SAAS;IA/BrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,8BAAa;YACb,qBAAY,CAAC,OAAO,CAAC;gBACnB,WAAW,EAAE,YAAY;gBACzB,QAAQ,EAAE,IAAI;aACf,CAAC;YACF,uBAAa,CAAC,OAAO,CAAC,YAAe,CAAC,OAAO,CAAC;YAC9C,wBAAU;YACV,wBAAU;YACV,8BAAa;YACb,kCAAe;YACf,wBAAU;YACV,8BAAa;YACb,wBAAU;YACV,0BAAW;YACX,wBAAU;SACX;QACD,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,sBAAe;gBACxB,MAAM,EAAE,CAAC,gBAAS,CAAC;gBACnB,UAAU,EAAE,CAAC,SAAoB,EAAE,EAAE;oBACnC,OAAO,IAAI,mCAA0B,CAAC,SAAS,EAAE;wBAC/C,wBAAwB,EAAE,IAAI;wBAC9B,uBAAuB,EAAE,IAAI;qBAC9B,CAAC,CAAC;gBACL,CAAC;aACF;SACF;KACF,CAAC;qCAGmC,gCAAc;QAClB,oBAAU;GAH9B,SAAS,CAerB"}
1
+ {"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,6CAAgD;AAChD,2CAA8C;AAC9C,oDAAgD;AAChD,6DAAyD;AACzD,mEAA+D;AAC/D,oDAAgD;AAChD,uCAA0D;AAC1D,oDAAgD;AAChD,4DAAwD;AACxD,6DAAyD;AACzD,qEAAwE;AACxE,uDAAmD;AACnD,oDAAiD;AACjD,oEAAgE;AAChE,oDAAgD;AAChD,oDAAgD;AAChD,kEAA8D;AAE9D,8CAAmC;AACnC,4EAAwE;AACxE,iFAA4E;AAC5E,mFAA8E;AAmCvE,IAAM,SAAS,GAAf,MAAM,SAAS;IAED;IACA;IAFnB,YACmB,cAA8B,EAC9B,WAA+B;QAD/B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAoB;IAC/C,CAAC;IAEJ,KAAK,CAAC,YAAY;QAEhB,iBAAO,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAExC,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;QACxC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,GAAG,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,SAAS,CAAC,QAA4B;QACpC,QAAQ,CAAC,KAAK,CAAC,6CAAwB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACxD,QAAQ,CAAC,KAAK,CAAC,gCAAc,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAChD,CAAC;CACF,CAAA;AArBY,8BAAS;oBAAT,SAAS;IAjCrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,8BAAa;YACb,qBAAY,CAAC,OAAO,CAAC;gBACnB,WAAW,EAAE,YAAY;gBACzB,QAAQ,EAAE,IAAI;aACf,CAAC;YACF,uBAAa,CAAC,OAAO,CAAC,YAAe,CAAC,OAAO,CAAC;YAC9C,wBAAU;YACV,wBAAU;YACV,8BAAa;YACb,kCAAe;YACf,wBAAU;YACV,8BAAa;YACb,wBAAU;YACV,wBAAU;YACV,0BAAW;YACX,wCAAkB;YAClB,uCAAiB,CAAC,OAAO,EAAE;SAC5B;QACD,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,sBAAe;gBACxB,MAAM,EAAE,CAAC,gBAAS,CAAC;gBACnB,UAAU,EAAE,CAAC,SAAoB,EAAE,EAAE;oBACnC,OAAO,IAAI,mCAA0B,CAAC,SAAS,EAAE;wBAC/C,wBAAwB,EAAE,IAAI;wBAC9B,uBAAuB,EAAE,IAAI;qBAC9B,CAAC,CAAC;gBACL,CAAC;aACF;SACF;KACF,CAAC;qCAGmC,gCAAc;QACjB,yCAAkB;GAHvC,SAAS,CAqBrB"}
@@ -1,8 +1,14 @@
1
+ import { Response as ExpressResponse } from 'express';
1
2
  import { AuthService } from './auth.service';
2
3
  import { AuthMethodEnum } from './enums/auth-method.enum';
4
+ import { RegisterDto } from './dto/register.dto';
5
+ import { RegisterSuccessResponseDto } from './dto/register-success.dto';
6
+ import { SessionService } from './session/session.service';
3
7
  export declare class AuthController {
4
8
  private authService;
5
- constructor(authService: AuthService);
9
+ private sessionService;
10
+ constructor(authService: AuthService, sessionService: SessionService);
6
11
  listAuthMethod(): AuthMethodEnum[];
7
12
  getProfile(req: any): any;
13
+ register(dto: RegisterDto, res: ExpressResponse): Promise<RegisterSuccessResponseDto>;
8
14
  }
@@ -19,10 +19,16 @@ const auth_service_1 = require("./auth.service");
19
19
  const auth_guard_1 = require("./auth.guard");
20
20
  const auth_method_enum_1 = require("./enums/auth-method.enum");
21
21
  const swagger_1 = require("@nestjs/swagger");
22
+ const register_dto_1 = require("./dto/register.dto");
23
+ const user_response_dto_1 = require("../user/dto/user-response.dto");
24
+ const class_transformer_1 = require("class-transformer");
25
+ const session_service_1 = require("./session/session.service");
22
26
  let AuthController = class AuthController {
23
27
  authService;
24
- constructor(authService) {
28
+ sessionService;
29
+ constructor(authService, sessionService) {
25
30
  this.authService = authService;
31
+ this.sessionService = sessionService;
26
32
  }
27
33
  listAuthMethod() {
28
34
  return this.authService.getAuthMethods();
@@ -30,6 +36,15 @@ let AuthController = class AuthController {
30
36
  getProfile(req) {
31
37
  return req.user;
32
38
  }
39
+ async register(dto, res) {
40
+ const user = await this.authService.register(dto);
41
+ const { authToken } = await this.sessionService.create(user);
42
+ this.sessionService.setSessionCookie(authToken, res);
43
+ return {
44
+ authToken,
45
+ user: (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, user),
46
+ };
47
+ }
33
48
  };
34
49
  exports.AuthController = AuthController;
35
50
  __decorate([
@@ -61,9 +76,19 @@ __decorate([
61
76
  __metadata("design:paramtypes", [Object]),
62
77
  __metadata("design:returntype", void 0)
63
78
  ], AuthController.prototype, "getProfile", null);
79
+ __decorate([
80
+ (0, common_1.Post)('auth.register'),
81
+ openapi.ApiResponse({ status: 201, type: require("./dto/register-success.dto").RegisterSuccessResponseDto }),
82
+ __param(0, (0, common_1.Body)()),
83
+ __param(1, (0, common_1.Response)({ passthrough: true })),
84
+ __metadata("design:type", Function),
85
+ __metadata("design:paramtypes", [register_dto_1.RegisterDto, Object]),
86
+ __metadata("design:returntype", Promise)
87
+ ], AuthController.prototype, "register", null);
64
88
  exports.AuthController = AuthController = __decorate([
65
- (0, swagger_1.ApiTags)('auth'),
89
+ (0, swagger_1.ApiTags)('Auth'),
66
90
  (0, common_1.Controller)(),
67
- __metadata("design:paramtypes", [auth_service_1.AuthService])
91
+ __metadata("design:paramtypes", [auth_service_1.AuthService,
92
+ session_service_1.SessionService])
68
93
  ], AuthController);
69
94
  //# sourceMappingURL=auth.controller.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAqE;AACrE,iDAA6C;AAC7C,6CAAyC;AACzC,+DAA0D;AAC1D,6CAAqE;AAI9D,IAAM,cAAc,GAApB,MAAM,cAAc;IACL;IAApB,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAgBhD,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;IAC3C,CAAC;IAID,UAAU,CAAY,GAAG;QACvB,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;CACF,CAAA;AA1BY,wCAAc;AAiBzB;IAdC,IAAA,YAAG,EAAC,kBAAkB,CAAC;IACvB,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,uCAAuC,EAAE,CAAC;IAClE,IAAA,qBAAW,EAAC;QACX,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,0CAA0C;QACvD,MAAM,EAAE;YACN,IAAI,EAAE,OAAO;YACb,KAAK,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,iCAAc,CAAC;aACpC;YACD,OAAO,EAAE,CAAC,iCAAc,CAAC,QAAQ,EAAE,iCAAc,CAAC,IAAI,CAAC;SACxD;KACF,CAAC;;;;;oDAGD;AAID;IAFC,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,YAAG,EAAC,mBAAmB,CAAC;;IACb,WAAA,IAAA,gBAAO,GAAE,CAAA;;;;gDAEpB;yBAzBU,cAAc;IAF1B,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAEsB,0BAAW;GADjC,cAAc,CA0B1B"}
1
+ {"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAQwB;AAExB,iDAA6C;AAC7C,6CAAyC;AACzC,+DAA0D;AAC1D,6CAAqE;AACrE,qDAAiD;AACjD,qEAA+D;AAC/D,yDAAoD;AAEpD,+DAA2D;AAIpD,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,WAAwB,EACxB,cAA8B;QAD9B,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;IACrC,CAAC;IAgBJ,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,CAAC;IAC3C,CAAC;IAID,UAAU,CAAY,GAAG;QACvB,OAAO,GAAG,CAAC,IAAI,CAAC;IAClB,CAAC;IAGK,AAAN,KAAK,CAAC,QAAQ,CACJ,GAAgB,EACS,GAAoB;QAErD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAElD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAE7D,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAErD,OAAO;YACL,SAAS;YACT,IAAI,EAAE,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,CAAC;SAC7C,CAAC;IACJ,CAAC;CACF,CAAA;AA9CY,wCAAc;AAoBzB;IAdC,IAAA,YAAG,EAAC,kBAAkB,CAAC;IACvB,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,uCAAuC,EAAE,CAAC;IAClE,IAAA,qBAAW,EAAC;QACX,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,0CAA0C;QACvD,MAAM,EAAE;YACN,IAAI,EAAE,OAAO;YACb,KAAK,EAAE;gBACL,IAAI,EAAE,QAAQ;gBACd,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,iCAAc,CAAC;aACpC;YACD,OAAO,EAAE,CAAC,iCAAc,CAAC,QAAQ,EAAE,iCAAc,CAAC,IAAI,CAAC;SACxD;KACF,CAAC;;;;;oDAGD;AAID;IAFC,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,YAAG,EAAC,mBAAmB,CAAC;;IACb,WAAA,IAAA,gBAAO,GAAE,CAAA;;;;gDAEpB;AAGK;IADL,IAAA,aAAI,EAAC,eAAe,CAAC;;IAEnB,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,iBAAQ,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;qCADnB,0BAAW;;8CAazB;yBA7CU,cAAc;IAF1B,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACR,gCAAc;GAH7B,cAAc,CA8C1B"}
@@ -1,13 +1,11 @@
1
1
  import { NestMiddleware } from '@nestjs/common';
2
- import { JwtService } from '@nestjs/jwt';
3
2
  import { Request, Response, NextFunction } from 'express';
4
- import { UserService } from '~/user/user.service';
5
3
  import { ContextService } from '~/core/context/context.service';
4
+ import { AuthService } from './auth.service';
6
5
  export declare class AuthMiddleware implements NestMiddleware {
7
- private jwtService;
8
- private userService;
9
6
  private contextService;
10
- constructor(jwtService: JwtService, userService: UserService, contextService: ContextService);
7
+ private authService;
8
+ constructor(contextService: ContextService, authService: AuthService);
11
9
  use(req: Request, res: Response, next: NextFunction): Promise<void>;
12
10
  private extractTokenFromHeader;
13
11
  private extractTokenFromCookie;
@@ -11,18 +11,14 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.AuthMiddleware = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
- const jwt_1 = require("@nestjs/jwt");
15
- const constants_1 = require("./constants");
16
- const user_service_1 = require("../user/user.service");
17
14
  const context_service_1 = require("../core/context/context.service");
15
+ const auth_service_1 = require("./auth.service");
18
16
  let AuthMiddleware = class AuthMiddleware {
19
- jwtService;
20
- userService;
21
17
  contextService;
22
- constructor(jwtService, userService, contextService) {
23
- this.jwtService = jwtService;
24
- this.userService = userService;
18
+ authService;
19
+ constructor(contextService, authService) {
25
20
  this.contextService = contextService;
21
+ this.authService = authService;
26
22
  }
27
23
  async use(req, res, next) {
28
24
  const token = this.extractTokenFromHeader(req) || this.extractTokenFromCookie(req);
@@ -30,10 +26,7 @@ let AuthMiddleware = class AuthMiddleware {
30
26
  return next();
31
27
  }
32
28
  try {
33
- const payload = await this.jwtService.verifyAsync(token, {
34
- secret: constants_1.jwtConstants.secret,
35
- });
36
- const user = await this.userService.findOne(payload.sub);
29
+ const user = await this.authService.getUserFromToken(token);
37
30
  if (user) {
38
31
  this.contextService.set('user', user);
39
32
  }
@@ -53,8 +46,7 @@ let AuthMiddleware = class AuthMiddleware {
53
46
  exports.AuthMiddleware = AuthMiddleware;
54
47
  exports.AuthMiddleware = AuthMiddleware = __decorate([
55
48
  (0, common_1.Injectable)(),
56
- __metadata("design:paramtypes", [jwt_1.JwtService,
57
- user_service_1.UserService,
58
- context_service_1.ContextService])
49
+ __metadata("design:paramtypes", [context_service_1.ContextService,
50
+ auth_service_1.AuthService])
59
51
  ], AuthMiddleware);
60
52
  //# sourceMappingURL=auth.middleware.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.middleware.js","sourceRoot":"","sources":["../../src/auth/auth.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4D;AAC5D,qCAAyC;AAEzC,2CAA2C;AAC3C,uDAAkD;AAClD,qEAAgE;AAGzD,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IACA;IAHV,YACU,UAAsB,EACtB,WAAwB,EACxB,cAA8B;QAF9B,eAAU,GAAV,UAAU,CAAY;QACtB,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;IACrC,CAAC;IAEJ,KAAK,CAAC,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QACvD,MAAM,KAAK,GACT,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC;QACvE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE;gBACvD,MAAM,EAAE,wBAAY,CAAC,MAAM;aAC5B,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAEzD,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACxC,CAAC;YAGD,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;QACrB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC,CAAA,CAAC;QAChB,IAAI,EAAE,CAAC;IACT,CAAC;IAMO,sBAAsB,CAAC,OAAgB;QAC7C,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QACtE,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAMO,sBAAsB,CAAC,OAAgB;QAC7C,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC;IAC9B,CAAC;CACF,CAAA;AA9CY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGW,gBAAU;QACT,0BAAW;QACR,gCAAc;GAJ7B,cAAc,CA8C1B"}
1
+ {"version":3,"file":"auth.middleware.js","sourceRoot":"","sources":["../../src/auth/auth.middleware.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4D;AAE5D,qEAAgE;AAChE,iDAA6C;AAGtC,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,cAA8B,EAC9B,WAAwB;QADxB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAa;IAC/B,CAAC;IAEJ,KAAK,CAAC,GAAG,CAAC,GAAY,EAAE,GAAa,EAAE,IAAkB;QACvD,MAAM,KAAK,GACT,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC;QAEvE,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QACD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAE5D,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;YACxC,CAAC;YAGD,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;QACrB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC,CAAA,CAAC;QAChB,IAAI,EAAE,CAAC;IACT,CAAC;IAMO,sBAAsB,CAAC,OAAgB;QAC7C,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,aAAa,EAAE,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QACtE,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IAOO,sBAAsB,CAAC,OAAgB;QAC7C,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC;IAC9B,CAAC;CACF,CAAA;AA3CY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGe,gCAAc;QACjB,0BAAW;GAHvB,cAAc,CA2C1B"}
@@ -15,6 +15,7 @@ const jwt_1 = require("@nestjs/jwt");
15
15
  const constants_1 = require("./constants");
16
16
  const oidc_module_1 = require("./oidc/oidc.module");
17
17
  const configs_module_1 = require("../configs/configs.module");
18
+ const session_module_1 = require("./session/session.module");
18
19
  let AuthModule = class AuthModule {
19
20
  };
20
21
  exports.AuthModule = AuthModule;
@@ -25,13 +26,15 @@ exports.AuthModule = AuthModule = __decorate([
25
26
  jwt_1.JwtModule.register({
26
27
  global: true,
27
28
  secret: constants_1.jwtConstants.secret,
28
- signOptions: { expiresIn: '30d' },
29
+ signOptions: { expiresIn: '180d' },
29
30
  }),
30
31
  configs_module_1.ConfigsModule,
31
32
  oidc_module_1.OidcModule,
33
+ session_module_1.SessionModule,
32
34
  ],
33
35
  controllers: [auth_controller_1.AuthController],
34
36
  providers: [auth_service_1.AuthService],
37
+ exports: [auth_service_1.AuthService],
35
38
  })
36
39
  ], AuthModule);
37
40
  //# sourceMappingURL=auth.module.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,qDAAgD;AAChD,qCAAwC;AACxC,2CAA2C;AAC3C,oDAAgD;AAChD,8DAAyD;AAgBlD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAdtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,wBAAY,CAAC,MAAM;gBAC3B,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;aAClC,CAAC;YACF,8BAAa;YACb,wBAAU;SACX;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,CAAC;KACzB,CAAC;GACW,UAAU,CAAG"}
1
+ {"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,qDAAgD;AAChD,qCAAwC;AACxC,2CAA2C;AAC3C,oDAAgD;AAChD,8DAAyD;AACzD,6DAAyD;AAkBlD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAhBtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,wBAAY,CAAC,MAAM;gBAC3B,WAAW,EAAE,EAAE,SAAS,EAAE,MAAM,EAAE;aACnC,CAAC;YACF,8BAAa;YACb,wBAAU;YACV,8BAAa;SACd;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,OAAO,EAAE,CAAC,0BAAW,CAAC;KACvB,CAAC;GACW,UAAU,CAAG"}
@@ -1,7 +1,15 @@
1
+ import { UserService } from '../user/user.service';
2
+ import { User } from '~/user/entities/user.entity';
1
3
  import { AuthMethodEnum } from './enums/auth-method.enum';
2
4
  import { ConfigsService } from '~/configs/configs.service';
5
+ import { RegisterDto } from './dto/register.dto';
6
+ import { JwtService } from '@nestjs/jwt';
3
7
  export declare class AuthService {
4
8
  private configs;
5
- constructor(configs: ConfigsService);
9
+ private userService;
10
+ private jwtService;
11
+ constructor(configs: ConfigsService, userService: UserService, jwtService: JwtService);
6
12
  getAuthMethods(): AuthMethodEnum[];
13
+ getUserFromToken(token: string): Promise<User | null>;
14
+ register({ username, name, password, email, }: RegisterDto): Promise<User>;
7
15
  }
@@ -11,19 +11,51 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.AuthService = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
+ const user_service_1 = require("../user/user.service");
14
15
  const configs_service_1 = require("../configs/configs.service");
16
+ const argon2_1 = require("@node-rs/argon2");
17
+ const jwt_1 = require("@nestjs/jwt");
18
+ const constants_1 = require("./constants");
15
19
  let AuthService = class AuthService {
16
20
  configs;
17
- constructor(configs) {
21
+ userService;
22
+ jwtService;
23
+ constructor(configs, userService, jwtService) {
18
24
  this.configs = configs;
25
+ this.userService = userService;
26
+ this.jwtService = jwtService;
19
27
  }
20
28
  getAuthMethods() {
21
29
  return this.configs.get('auth')?.methods || [];
22
30
  }
31
+ async getUserFromToken(token) {
32
+ try {
33
+ const payload = await this.jwtService.verifyAsync(token, {
34
+ secret: constants_1.jwtConstants.secret,
35
+ });
36
+ const user = await this.userService.findOne(payload.sub);
37
+ return user;
38
+ }
39
+ catch (err) {
40
+ return null;
41
+ }
42
+ }
43
+ async register({ username, name, password, email, }) {
44
+ const passwordHash = await (0, argon2_1.hash)(password, { memoryCost: 20480 });
45
+ return this.userService.create({
46
+ username,
47
+ email,
48
+ name,
49
+ password: passwordHash,
50
+ verified: true,
51
+ });
52
+ }
23
53
  };
24
54
  exports.AuthService = AuthService;
25
55
  exports.AuthService = AuthService = __decorate([
26
56
  (0, common_1.Injectable)(),
27
- __metadata("design:paramtypes", [configs_service_1.ConfigsService])
57
+ __metadata("design:paramtypes", [configs_service_1.ConfigsService,
58
+ user_service_1.UserService,
59
+ jwt_1.JwtService])
28
60
  ], AuthService);
29
61
  //# sourceMappingURL=auth.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AAKnE,gEAA2D;AAGpD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACF;IAApB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAK/C,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;CACF,CAAA;AATY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAEkB,gCAAc;GADhC,WAAW,CASvB"}
1
+ {"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AACnE,uDAAmD;AAInD,gEAA2D;AAE3D,4CAAuC;AACvC,qCAAyC;AACzC,2CAA2C;AAGpC,IAAM,WAAW,GAAjB,MAAM,WAAW;IAEZ;IACA;IACA;IAHV,YACU,OAAuB,EACvB,WAAwB,EACxB,UAAsB;QAFtB,YAAO,GAAP,OAAO,CAAgB;QACvB,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAEJ,cAAc;QACZ,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;IAKD,KAAK,CAAC,gBAAgB,CAAC,KAAa;QAClC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,KAAK,EAAE;gBACvD,MAAM,EAAE,wBAAY,CAAC,MAAM;aAC5B,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAEzD,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;IAKD,KAAK,CAAC,QAAQ,CAAC,EACb,QAAQ,EACR,IAAI,EACJ,QAAQ,EACR,KAAK,GACO;QACZ,MAAM,YAAY,GAAG,MAAM,IAAA,aAAI,EAAC,QAAQ,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QAEjE,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;YAC7B,QAAQ;YACR,KAAK;YACL,IAAI;YACJ,QAAQ,EAAE,YAAY;YACtB,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AA/CY,kCAAW;sBAAX,WAAW;IADvB,IAAA,mBAAU,GAAE;qCAGQ,gCAAc;QACV,0BAAW;QACZ,gBAAU;GAJrB,WAAW,CA+CvB"}
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.jwtConstants = void 0;
4
4
  exports.jwtConstants = {
5
- secret: 'DO NOT USE THIS VALUE. INSTEAD, CREATE A COMPLEX SECRET AND KEEP IT SAFE OUTSIDE OF THE SOURCE CODE.',
5
+ secret: process.env.SOCIAL_DEV_AUTH_SECRET ||
6
+ 'DO NOT USE THIS VALUE. INSTEAD, CREATE A COMPLEX SECRET AND KEEP IT SAFE OUTSIDE OF THE SOURCE CODE.',
6
7
  };
7
8
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/auth/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,YAAY,GAAG;IAC1B,MAAM,EACJ,sGAAsG;CACzG,CAAC"}
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../src/auth/constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,YAAY,GAAG;IAC1B,MAAM,EACJ,OAAO,CAAC,GAAG,CAAC,sBAAsB;QAClC,sGAAsG;CACzG,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { UserResponseDto } from '~/user/dto/user-response.dto';
2
2
  export declare class LoginSuccessResponseDto {
3
- accessToken: string;
3
+ authToken: string;
4
4
  user: UserResponseDto;
5
5
  }
@@ -12,20 +12,23 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.LoginSuccessResponseDto = void 0;
13
13
  const openapi = require("@nestjs/swagger");
14
14
  const swagger_1 = require("@nestjs/swagger");
15
+ const class_transformer_1 = require("class-transformer");
15
16
  const user_response_dto_1 = require("../../user/dto/user-response.dto");
16
17
  class LoginSuccessResponseDto {
17
- accessToken;
18
+ authToken;
18
19
  user;
19
20
  static _OPENAPI_METADATA_FACTORY() {
20
- return { accessToken: { required: true, type: () => String }, user: { required: true, type: () => require("../../user/dto/user-response.dto").UserResponseDto } };
21
+ return { authToken: { required: true, type: () => String }, user: { required: true, type: () => require("../../user/dto/user-response.dto").UserResponseDto } };
21
22
  }
22
23
  }
23
24
  exports.LoginSuccessResponseDto = LoginSuccessResponseDto;
24
25
  __decorate([
25
26
  (0, swagger_1.ApiProperty)({ description: 'The session token' }),
27
+ (0, class_transformer_1.Expose)(),
26
28
  __metadata("design:type", String)
27
- ], LoginSuccessResponseDto.prototype, "accessToken", void 0);
29
+ ], LoginSuccessResponseDto.prototype, "authToken", void 0);
28
30
  __decorate([
31
+ (0, class_transformer_1.Expose)(),
29
32
  (0, swagger_1.ApiProperty)({
30
33
  description: 'User information',
31
34
  example: {
@@ -1 +1 @@
1
- {"version":3,"file":"login-success.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/login-success.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,wEAA+D;AAG/D,MAAa,uBAAuB;IAElC,WAAW,CAAS;IAWpB,IAAI,CAAkB;;;;CACvB;AAdD,0DAcC;AAZC;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;;4DAC9B;AAWpB;IATC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,kBAAkB;QAC/B,OAAO,EAAE;YACP,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,SAAS;YACnB,OAAO,EAAE,CAAC;SACX;KACF,CAAC;8BACI,mCAAe;qDAAC"}
1
+ {"version":3,"file":"login-success.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/login-success.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAA2C;AAC3C,wEAA+D;AAG/D,MAAa,uBAAuB;IAGlC,SAAS,CAAS;IAYlB,IAAI,CAAkB;;;;CACvB;AAhBD,0DAgBC;AAbC;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;IACjD,IAAA,0BAAM,GAAE;;0DACS;AAYlB;IAVC,IAAA,0BAAM,GAAE;IACR,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,kBAAkB;QAC/B,OAAO,EAAE;YACP,EAAE,EAAE,CAAC;YACL,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,SAAS;YACnB,OAAO,EAAE,CAAC;SACX;KACF,CAAC;8BACI,mCAAe;qDAAC"}
@@ -0,0 +1,3 @@
1
+ import { LoginSuccessResponseDto } from './login-success.dto';
2
+ export declare class RegisterSuccessResponseDto extends LoginSuccessResponseDto {
3
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RegisterSuccessResponseDto = void 0;
4
+ const openapi = require("@nestjs/swagger");
5
+ const login_success_dto_1 = require("./login-success.dto");
6
+ class RegisterSuccessResponseDto extends login_success_dto_1.LoginSuccessResponseDto {
7
+ static _OPENAPI_METADATA_FACTORY() {
8
+ return {};
9
+ }
10
+ }
11
+ exports.RegisterSuccessResponseDto = RegisterSuccessResponseDto;
12
+ //# sourceMappingURL=register-success.dto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"register-success.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/register-success.dto.ts"],"names":[],"mappings":";;;;AAAA,2DAA8D;AAE9D,MAAa,0BAA2B,SAAQ,2CAAuB;;;;CAAG;AAA1E,gEAA0E"}
@@ -0,0 +1,6 @@
1
+ export declare class RegisterDto {
2
+ username: string;
3
+ name: string;
4
+ password: string;
5
+ email: string;
6
+ }
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RegisterDto = void 0;
13
+ const openapi = require("@nestjs/swagger");
14
+ const swagger_1 = require("@nestjs/swagger");
15
+ class RegisterDto {
16
+ username;
17
+ name;
18
+ password;
19
+ email;
20
+ static _OPENAPI_METADATA_FACTORY() {
21
+ return { username: { required: true, type: () => String }, name: { required: true, type: () => String }, password: { required: true, type: () => String }, email: { required: true, type: () => String } };
22
+ }
23
+ }
24
+ exports.RegisterDto = RegisterDto;
25
+ __decorate([
26
+ (0, swagger_1.ApiProperty)({
27
+ description: 'Username (unique) to be assigned to the new user that will be created',
28
+ }),
29
+ __metadata("design:type", String)
30
+ ], RegisterDto.prototype, "username", void 0);
31
+ __decorate([
32
+ (0, swagger_1.ApiProperty)({
33
+ description: 'Display name that will show on the profile',
34
+ }),
35
+ __metadata("design:type", String)
36
+ ], RegisterDto.prototype, "name", void 0);
37
+ __decorate([
38
+ (0, swagger_1.ApiProperty)({ description: 'Secure phrase that will protect the account' }),
39
+ __metadata("design:type", String)
40
+ ], RegisterDto.prototype, "password", void 0);
41
+ __decorate([
42
+ (0, swagger_1.ApiProperty)({ description: 'Email associated with the account' }),
43
+ __metadata("design:type", String)
44
+ ], RegisterDto.prototype, "email", void 0);
45
+ //# sourceMappingURL=register.dto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"register.dto.js","sourceRoot":"","sources":["../../../src/auth/dto/register.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAE9C,MAAa,WAAW;IAKtB,QAAQ,CAAS;IAKjB,IAAI,CAAS;IAGb,QAAQ,CAAS;IAGjB,KAAK,CAAS;;;;CACf;AAjBD,kCAiBC;AAZC;IAJC,IAAA,qBAAW,EAAC;QACX,WAAW,EACT,uEAAuE;KAC1E,CAAC;;6CACe;AAKjB;IAHC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,4CAA4C;KAC1D,CAAC;;yCACW;AAGb;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,6CAA6C,EAAE,CAAC;;6CAC3D;AAGjB;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,mCAAmC,EAAE,CAAC;;0CACpD"}
@@ -0,0 +1,6 @@
1
+ export declare class OidcExchangeCodeDto {
2
+ code: string;
3
+ provider: string;
4
+ redirectUri: string;
5
+ codeVerifier: string;
6
+ }
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.OidcExchangeCodeDto = void 0;
13
+ const swagger_1 = require("@nestjs/swagger");
14
+ class OidcExchangeCodeDto {
15
+ code;
16
+ provider;
17
+ redirectUri;
18
+ codeVerifier;
19
+ }
20
+ exports.OidcExchangeCodeDto = OidcExchangeCodeDto;
21
+ __decorate([
22
+ (0, swagger_1.ApiProperty)({
23
+ description: 'Authorization code, obtained from the authorization flow',
24
+ }),
25
+ __metadata("design:type", String)
26
+ ], OidcExchangeCodeDto.prototype, "code", void 0);
27
+ __decorate([
28
+ (0, swagger_1.ApiProperty)({
29
+ description: 'OIDC provider ID, relevant to the code that was obtained',
30
+ }),
31
+ __metadata("design:type", String)
32
+ ], OidcExchangeCodeDto.prototype, "provider", void 0);
33
+ __decorate([
34
+ (0, swagger_1.ApiProperty)({
35
+ description: 'Redirect Uri that was used to obtain the authorization code',
36
+ required: false,
37
+ }),
38
+ __metadata("design:type", String)
39
+ ], OidcExchangeCodeDto.prototype, "redirectUri", void 0);
40
+ __decorate([
41
+ (0, swagger_1.ApiProperty)({
42
+ description: 'The same code_verifier that was used to obtain the authorization code. Required if PKCE was used in the authorization code grant request',
43
+ required: false,
44
+ }),
45
+ __metadata("design:type", String)
46
+ ], OidcExchangeCodeDto.prototype, "codeVerifier", void 0);
47
+ //# sourceMappingURL=requests.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"requests.js","sourceRoot":"","sources":["../../../../src/auth/oidc/dto/requests.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,6CAA8C;AAE9C,MAAa,mBAAmB;IAI9B,IAAI,CAAS;IAKb,QAAQ,CAAS;IAMjB,WAAW,CAAS;IAOpB,YAAY,CAAS;CACtB;AAvBD,kDAuBC;AAnBC;IAHC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,0DAA0D;KACxE,CAAC;;iDACW;AAKb;IAHC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,0DAA0D;KACxE,CAAC;;qDACe;AAMjB;IAJC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,6DAA6D;QAC1E,QAAQ,EAAE,KAAK;KAChB,CAAC;;wDACkB;AAOpB;IALC,IAAA,qBAAW,EAAC;QACX,WAAW,EACT,0IAA0I;QAC5I,QAAQ,EAAE,KAAK;KAChB,CAAC;;yDACmB"}
@@ -37,7 +37,7 @@ __decorate([
37
37
  description: 'Url to redirect the user to in order to start the OIDC flow',
38
38
  }),
39
39
  (0, class_transformer_1.Transform)(({ obj }) => {
40
- const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.login';
40
+ const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'auth.oidc.authorize';
41
41
  return baseUrl + '?id=' + obj.id;
42
42
  }),
43
43
  __metadata("design:type", String)
@@ -2,11 +2,16 @@ import { Response } from 'express';
2
2
  import { OidcService } from './oidc.service';
3
3
  import { OidcProviderResponseDto } from './dto/responses';
4
4
  import { SessionService } from '../session/session.service';
5
+ import { OidcExchangeCodeDto } from './dto/requests';
6
+ import { UserResponseDto } from '~/user/dto/user-response.dto';
5
7
  export declare class OidcController {
6
8
  private service;
7
9
  private sessions;
8
10
  constructor(service: OidcService, sessions: SessionService);
9
11
  listOidcProviders(): OidcProviderResponseDto[];
10
- login(id: string, res: Response): Promise<void>;
11
- callback(code: string, res: Response): Promise<string>;
12
+ login(id: string, params: Record<string, string>, res: Response): Promise<void>;
13
+ exchangeCode(dto: OidcExchangeCodeDto, res: Response): Promise<{
14
+ authToken: string;
15
+ user: UserResponseDto;
16
+ }>;
12
17
  }