@social.dev/server-sdk 0.0.1-alpha.6 → 0.0.1-alpha.61

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 (344) 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 +3 -3
  6. package/dist/app.module.js +11 -6
  7. package/dist/app.module.js.map +1 -1
  8. package/dist/auth/auth.controller.d.ts +9 -1
  9. package/dist/auth/auth.controller.js +53 -2
  10. package/dist/auth/auth.controller.js.map +1 -1
  11. package/dist/auth/auth.module.js +4 -0
  12. package/dist/auth/auth.module.js.map +1 -1
  13. package/dist/auth/auth.service.d.ts +7 -6
  14. package/dist/auth/auth.service.js +18 -15
  15. package/dist/auth/auth.service.js.map +1 -1
  16. package/dist/auth/dto/login-success.dto.d.ts +1 -1
  17. package/dist/auth/dto/login-success.dto.js +6 -3
  18. package/dist/auth/dto/login-success.dto.js.map +1 -1
  19. package/dist/auth/dto/register-success.dto.d.ts +3 -0
  20. package/dist/auth/dto/register-success.dto.js +12 -0
  21. package/dist/auth/dto/register-success.dto.js.map +1 -0
  22. package/dist/auth/dto/register.dto.d.ts +6 -0
  23. package/dist/auth/dto/register.dto.js +45 -0
  24. package/dist/auth/dto/register.dto.js.map +1 -0
  25. package/dist/auth/enums/auth-method.enum.d.ts +2 -2
  26. package/dist/auth/enums/auth-method.enum.js +2 -2
  27. package/dist/auth/enums/auth-method.enum.js.map +1 -1
  28. package/dist/auth/oidc/dto/requests.d.ts +6 -0
  29. package/dist/auth/oidc/dto/requests.js +47 -0
  30. package/dist/auth/oidc/dto/requests.js.map +1 -0
  31. package/dist/auth/oidc/dto/responses.js +1 -1
  32. package/dist/auth/oidc/dto/responses.js.map +1 -1
  33. package/dist/auth/oidc/oidc.controller.d.ts +7 -2
  34. package/dist/auth/oidc/oidc.controller.js +31 -17
  35. package/dist/auth/oidc/oidc.controller.js.map +1 -1
  36. package/dist/auth/oidc/oidc.module.js +2 -0
  37. package/dist/auth/oidc/oidc.module.js.map +1 -1
  38. package/dist/auth/oidc/oidc.service.d.ts +13 -7
  39. package/dist/auth/oidc/oidc.service.js +38 -30
  40. package/dist/auth/oidc/oidc.service.js.map +1 -1
  41. package/dist/auth/session/session.controller.js +8 -3
  42. package/dist/auth/session/session.controller.js.map +1 -1
  43. package/dist/auth/session/session.service.d.ts +2 -2
  44. package/dist/auth/session/session.service.js +9 -5
  45. package/dist/auth/session/session.service.js.map +1 -1
  46. package/dist/bootstrap.d.ts +2 -1
  47. package/dist/bootstrap.js +9 -1
  48. package/dist/bootstrap.js.map +1 -1
  49. package/dist/chat/chat.acl.d.ts +3 -0
  50. package/dist/chat/chat.acl.js +50 -0
  51. package/dist/chat/chat.acl.js.map +1 -0
  52. package/dist/chat/chat.controller.d.ts +14 -6
  53. package/dist/chat/chat.controller.js +137 -14
  54. package/dist/chat/chat.controller.js.map +1 -1
  55. package/dist/chat/chat.module.d.ts +3 -0
  56. package/dist/chat/chat.module.js +28 -2
  57. package/dist/chat/chat.module.js.map +1 -1
  58. package/dist/chat/chat.service.d.ts +54 -12
  59. package/dist/chat/chat.service.js +326 -36
  60. package/dist/chat/chat.service.js.map +1 -1
  61. package/dist/chat/dto/add-reaction.dto.d.ts +5 -0
  62. package/dist/chat/dto/add-reaction.dto.js +42 -0
  63. package/dist/chat/dto/add-reaction.dto.js.map +1 -0
  64. package/dist/chat/dto/create-message.dto.d.ts +3 -1
  65. package/dist/chat/dto/create-message.dto.js +15 -1
  66. package/dist/chat/dto/create-message.dto.js.map +1 -1
  67. package/dist/chat/dto/responses.dto.d.ts +26 -5
  68. package/dist/chat/dto/responses.dto.js +167 -18
  69. package/dist/chat/dto/responses.dto.js.map +1 -1
  70. package/dist/chat/dto/update-cursor.dto.d.ts +5 -0
  71. package/dist/chat/dto/update-cursor.dto.js +36 -0
  72. package/dist/chat/dto/update-cursor.dto.js.map +1 -0
  73. package/dist/chat/entities/conversation-member.entity.js +1 -1
  74. package/dist/chat/entities/conversation-member.entity.js.map +1 -1
  75. package/dist/chat/entities/conversation.entity.d.ts +4 -0
  76. package/dist/chat/entities/conversation.entity.js +13 -1
  77. package/dist/chat/entities/conversation.entity.js.map +1 -1
  78. package/dist/chat/entities/message.entity.d.ts +7 -0
  79. package/dist/chat/entities/message.entity.js +27 -2
  80. package/dist/chat/entities/message.entity.js.map +1 -1
  81. package/dist/chat/entities/reaction.entity.d.ts +10 -0
  82. package/dist/chat/entities/reaction.entity.js +62 -0
  83. package/dist/chat/entities/reaction.entity.js.map +1 -0
  84. package/dist/chat/entities/read-cursor.entity.d.ts +10 -0
  85. package/dist/chat/entities/read-cursor.entity.js +64 -0
  86. package/dist/chat/entities/read-cursor.entity.js.map +1 -0
  87. package/dist/chat/enums/conversation-type.enum.d.ts +2 -1
  88. package/dist/chat/enums/conversation-type.enum.js +1 -0
  89. package/dist/chat/enums/conversation-type.enum.js.map +1 -1
  90. package/dist/common/decorators/api-paginated-response.d.ts +1 -1
  91. package/dist/common/decorators/api-paginated-response.js +2 -2
  92. package/dist/common/decorators/api-paginated-response.js.map +1 -1
  93. package/dist/common/dto/paginated-response.dto.d.ts +2 -0
  94. package/dist/common/dto/paginated-response.dto.js +14 -3
  95. package/dist/common/dto/paginated-response.dto.js.map +1 -1
  96. package/dist/common/utils/cursor.d.ts +2 -0
  97. package/dist/common/utils/cursor.js +12 -0
  98. package/dist/common/utils/cursor.js.map +1 -0
  99. package/dist/community/avatar/avatar.controller.d.ts +11 -0
  100. package/dist/community/avatar/avatar.controller.js +90 -0
  101. package/dist/community/avatar/avatar.controller.js.map +1 -0
  102. package/dist/community/avatar/avatar.service.d.ts +13 -0
  103. package/dist/community/avatar/avatar.service.js +78 -0
  104. package/dist/community/avatar/avatar.service.js.map +1 -0
  105. package/dist/community/community.acl.d.ts +6 -3
  106. package/dist/community/community.acl.js +58 -35
  107. package/dist/community/community.acl.js.map +1 -1
  108. package/dist/community/community.controller.d.ts +4 -3
  109. package/dist/community/community.controller.js +23 -6
  110. package/dist/community/community.controller.js.map +1 -1
  111. package/dist/community/community.module.d.ts +3 -0
  112. package/dist/community/community.module.js +17 -7
  113. package/dist/community/community.module.js.map +1 -1
  114. package/dist/community/community.service.d.ts +13 -5
  115. package/dist/community/community.service.js +74 -17
  116. package/dist/community/community.service.js.map +1 -1
  117. package/dist/community/dto/community-response.dto.d.ts +5 -1
  118. package/dist/community/dto/community-response.dto.js +32 -1
  119. package/dist/community/dto/community-response.dto.js.map +1 -1
  120. package/dist/community/dto/create-community.dto.d.ts +2 -0
  121. package/dist/community/dto/create-community.dto.js +14 -2
  122. package/dist/community/dto/create-community.dto.js.map +1 -1
  123. package/dist/community/dto/update-community.dto.d.ts +2 -0
  124. package/dist/community/dto/update-community.dto.js +15 -1
  125. package/dist/community/dto/update-community.dto.js.map +1 -1
  126. package/dist/community/entities/community-member.entity.js +1 -0
  127. package/dist/community/entities/community-member.entity.js.map +1 -1
  128. package/dist/community/entities/community.entity.d.ts +2 -0
  129. package/dist/community/entities/community.entity.js +11 -1
  130. package/dist/community/entities/community.entity.js.map +1 -1
  131. package/dist/configs/configs.module.js +3 -0
  132. package/dist/configs/configs.module.js.map +1 -1
  133. package/dist/configs/configs.service.d.ts +23 -0
  134. package/dist/configs/configs.service.js +14 -1
  135. package/dist/configs/configs.service.js.map +1 -1
  136. package/dist/core/event-stream/event-stream-processor.interface.d.ts +8 -0
  137. package/dist/core/event-stream/event-stream-processor.interface.js +3 -0
  138. package/dist/core/event-stream/event-stream-processor.interface.js.map +1 -0
  139. package/dist/core/event-stream/event-stream-processor.service.d.ts +13 -0
  140. package/dist/core/event-stream/event-stream-processor.service.js +55 -0
  141. package/dist/core/event-stream/event-stream-processor.service.js.map +1 -0
  142. package/dist/core/event-stream/event-stream.module.d.ts +11 -0
  143. package/dist/core/event-stream/event-stream.module.js +49 -0
  144. package/dist/core/event-stream/event-stream.module.js.map +1 -0
  145. package/dist/core/event-stream/event-stream.service.d.ts +16 -0
  146. package/dist/core/event-stream/event-stream.service.js +100 -0
  147. package/dist/core/event-stream/event-stream.service.js.map +1 -0
  148. package/dist/core/event-stream/types.d.ts +2 -0
  149. package/dist/core/event-stream/types.js +3 -0
  150. package/dist/core/event-stream/types.js.map +1 -0
  151. package/dist/core/hook/hook.module.d.ts +4 -0
  152. package/dist/core/hook/hook.module.js +30 -0
  153. package/dist/core/hook/hook.module.js.map +1 -0
  154. package/dist/core/hook/hook.service.d.ts +7 -0
  155. package/dist/core/{plugin/plugin-hook.service.js → hook/hook.service.js} +10 -10
  156. package/dist/core/hook/hook.service.js.map +1 -0
  157. package/dist/core/plugin/plugin.module.js +7 -5
  158. package/dist/core/plugin/plugin.module.js.map +1 -1
  159. package/dist/db.js +1 -1
  160. package/dist/db.js.map +1 -1
  161. package/dist/file-storage/file-storage.service.d.ts +1 -1
  162. package/dist/file-storage/file-storage.service.js +6 -6
  163. package/dist/file-storage/file-storage.service.js.map +1 -1
  164. package/dist/file-storage/utils.d.ts +2 -0
  165. package/dist/file-storage/utils.js +9 -2
  166. package/dist/file-storage/utils.js.map +1 -1
  167. package/dist/index.d.ts +0 -1
  168. package/dist/index.js +1 -3
  169. package/dist/index.js.map +1 -1
  170. package/dist/manage-db.d.ts +1 -0
  171. package/dist/manage-db.js +10 -0
  172. package/dist/manage-db.js.map +1 -0
  173. package/dist/media/dto/media-response.dto.d.ts +2 -0
  174. package/dist/media/dto/media-response.dto.js +14 -1
  175. package/dist/media/dto/media-response.dto.js.map +1 -1
  176. package/dist/media/entities/audio.entity.d.ts +2 -2
  177. package/dist/media/entities/audio.entity.js +2 -2
  178. package/dist/media/entities/audio.entity.js.map +1 -1
  179. package/dist/media/entities/image.entity.d.ts +5 -0
  180. package/dist/media/entities/{post-media.entity.js → image.entity.js} +16 -12
  181. package/dist/media/entities/image.entity.js.map +1 -0
  182. package/dist/media/entities/media.entity.d.ts +6 -0
  183. package/dist/media/entities/media.entity.js +25 -2
  184. package/dist/media/entities/media.entity.js.map +1 -1
  185. package/dist/media/media.acl.d.ts +2 -4
  186. package/dist/media/media.acl.js +22 -1
  187. package/dist/media/media.acl.js.map +1 -1
  188. package/dist/media/media.controller.d.ts +2 -0
  189. package/dist/media/media.controller.js +58 -0
  190. package/dist/media/media.controller.js.map +1 -1
  191. package/dist/media/media.module.js +2 -1
  192. package/dist/media/media.module.js.map +1 -1
  193. package/dist/media/media.service.d.ts +6 -3
  194. package/dist/media/media.service.js +118 -19
  195. package/dist/media/media.service.js.map +1 -1
  196. package/dist/migrations/1757061785934-PushNotificationTokens.d.ts +6 -0
  197. package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
  198. package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
  199. package/dist/migrations/1758623241397-AddUserTimestamps.d.ts +6 -0
  200. package/dist/migrations/1758623241397-AddUserTimestamps.js +16 -0
  201. package/dist/migrations/1758623241397-AddUserTimestamps.js.map +1 -0
  202. package/dist/migrations/1758704603161-UserFollows.d.ts +6 -0
  203. package/dist/migrations/1758704603161-UserFollows.js +18 -0
  204. package/dist/migrations/1758704603161-UserFollows.js.map +1 -0
  205. package/dist/migrations/1759757532702-UpdateCommunityCascades.d.ts +6 -0
  206. package/dist/migrations/1759757532702-UpdateCommunityCascades.js +20 -0
  207. package/dist/migrations/1759757532702-UpdateCommunityCascades.js.map +1 -0
  208. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.d.ts +6 -0
  209. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js +16 -0
  210. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js.map +1 -0
  211. package/dist/migrations/1759919335188-CommunityChats.d.ts +6 -0
  212. package/dist/migrations/1759919335188-CommunityChats.js +28 -0
  213. package/dist/migrations/1759919335188-CommunityChats.js.map +1 -0
  214. package/dist/migrations/1760363804673-ChatVoiceNotes.d.ts +6 -0
  215. package/dist/migrations/1760363804673-ChatVoiceNotes.js +24 -0
  216. package/dist/migrations/1760363804673-ChatVoiceNotes.js.map +1 -0
  217. package/dist/migrations/1760444646328-ChatReadCursor.d.ts +6 -0
  218. package/dist/migrations/1760444646328-ChatReadCursor.js +18 -0
  219. package/dist/migrations/1760444646328-ChatReadCursor.js.map +1 -0
  220. package/dist/migrations/1761598291629-AddChatImages.d.ts +6 -0
  221. package/dist/migrations/1761598291629-AddChatImages.js +16 -0
  222. package/dist/migrations/1761598291629-AddChatImages.js.map +1 -0
  223. package/dist/migrations/1761648419807-ChatReactions.d.ts +6 -0
  224. package/dist/migrations/1761648419807-ChatReactions.js +18 -0
  225. package/dist/migrations/1761648419807-ChatReactions.js.map +1 -0
  226. package/dist/network/entities/network.entity.js +1 -4
  227. package/dist/network/entities/network.entity.js.map +1 -1
  228. package/dist/network/network.middleware.js +1 -1
  229. package/dist/network/network.middleware.js.map +1 -1
  230. package/dist/network/network.module.js +2 -1
  231. package/dist/network/network.module.js.map +1 -1
  232. package/dist/network/network.service.d.ts +5 -2
  233. package/dist/network/network.service.js +23 -6
  234. package/dist/network/network.service.js.map +1 -1
  235. package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
  236. package/dist/{common/entities/base.repository.js → notification/dto/delete-push-token.dto.js} +14 -20
  237. package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
  238. package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
  239. package/dist/notification/dto/register-push-token.dto.js +38 -0
  240. package/dist/notification/dto/register-push-token.dto.js.map +1 -0
  241. package/dist/notification/entities/push-token.entity.d.ts +11 -0
  242. package/dist/notification/entities/push-token.entity.js +60 -0
  243. package/dist/notification/entities/push-token.entity.js.map +1 -0
  244. package/dist/notification/enums/push-service.enum.d.ts +6 -0
  245. package/dist/notification/enums/push-service.enum.js +11 -0
  246. package/dist/notification/enums/push-service.enum.js.map +1 -0
  247. package/dist/notification/hook-listener.service.d.ts +13 -0
  248. package/dist/notification/hook-listener.service.js +58 -0
  249. package/dist/notification/hook-listener.service.js.map +1 -0
  250. package/dist/notification/notification.module.d.ts +2 -0
  251. package/dist/notification/notification.module.js +24 -0
  252. package/dist/notification/notification.module.js.map +1 -0
  253. package/dist/notification/push-notification.controller.d.ts +9 -0
  254. package/dist/notification/push-notification.controller.js +69 -0
  255. package/dist/notification/push-notification.controller.js.map +1 -0
  256. package/dist/notification/push-notification.module.d.ts +2 -0
  257. package/dist/notification/push-notification.module.js +27 -0
  258. package/dist/notification/push-notification.module.js.map +1 -0
  259. package/dist/notification/push-notification.service.d.ts +23 -0
  260. package/dist/notification/push-notification.service.js +86 -0
  261. package/dist/notification/push-notification.service.js.map +1 -0
  262. package/dist/post/entities/post.entity.js +3 -3
  263. package/dist/post/entities/post.entity.js.map +1 -1
  264. package/dist/post/post.controller.d.ts +3 -2
  265. package/dist/post/post.controller.js +28 -8
  266. package/dist/post/post.controller.js.map +1 -1
  267. package/dist/post/post.module.js +2 -0
  268. package/dist/post/post.module.js.map +1 -1
  269. package/dist/post/post.service.d.ts +7 -3
  270. package/dist/post/post.service.js +18 -8
  271. package/dist/post/post.service.js.map +1 -1
  272. package/dist/tsconfig.build.tsbuildinfo +1 -1
  273. package/dist/user/avatar/avatar.controller.d.ts +10 -0
  274. package/dist/user/avatar/avatar.controller.js +89 -0
  275. package/dist/user/avatar/avatar.controller.js.map +1 -0
  276. package/dist/user/avatar/avatar.service.d.ts +12 -0
  277. package/dist/user/avatar/avatar.service.js +72 -0
  278. package/dist/user/avatar/avatar.service.js.map +1 -0
  279. package/dist/user/constants.d.ts +1 -0
  280. package/dist/user/constants.js +5 -0
  281. package/dist/user/constants.js.map +1 -0
  282. package/dist/user/dto/update-profile.dto.d.ts +3 -0
  283. package/dist/user/dto/update-profile.dto.js +26 -0
  284. package/dist/user/dto/update-profile.dto.js.map +1 -0
  285. package/dist/user/dto/user-response.dto.d.ts +6 -0
  286. package/dist/user/dto/user-response.dto.js +37 -1
  287. package/dist/user/dto/user-response.dto.js.map +1 -1
  288. package/dist/user/dto/user.dto.d.ts +8 -0
  289. package/dist/user/dto/user.dto.js +21 -0
  290. package/dist/user/dto/user.dto.js.map +1 -0
  291. package/dist/user/entities/user.entity.d.ts +4 -0
  292. package/dist/user/entities/user.entity.js +19 -1
  293. package/dist/user/entities/user.entity.js.map +1 -1
  294. package/dist/user/follow/dto/follow-response.dto.d.ts +4 -0
  295. package/dist/user/follow/dto/follow-response.dto.js +38 -0
  296. package/dist/user/follow/dto/follow-response.dto.js.map +1 -0
  297. package/dist/user/follow/dto/follow.dto.d.ts +4 -0
  298. package/dist/user/follow/dto/follow.dto.js +26 -0
  299. package/dist/user/follow/dto/follow.dto.js.map +1 -0
  300. package/dist/user/follow/entities/follow.entity.d.ts +10 -0
  301. package/dist/user/follow/entities/follow.entity.js +60 -0
  302. package/dist/user/follow/entities/follow.entity.js.map +1 -0
  303. package/dist/user/follow/follow.controller.d.ts +9 -0
  304. package/dist/user/follow/follow.controller.js +56 -0
  305. package/dist/user/follow/follow.controller.js.map +1 -0
  306. package/dist/user/follow/follow.module.d.ts +2 -0
  307. package/dist/user/follow/follow.module.js +26 -0
  308. package/dist/user/follow/follow.module.js.map +1 -0
  309. package/dist/user/follow/follow.service.d.ts +11 -0
  310. package/dist/user/follow/follow.service.js +56 -0
  311. package/dist/user/follow/follow.service.js.map +1 -0
  312. package/dist/user/user.controller.d.ts +6 -2
  313. package/dist/user/user.controller.js +47 -8
  314. package/dist/user/user.controller.js.map +1 -1
  315. package/dist/user/user.module.js +12 -3
  316. package/dist/user/user.module.js.map +1 -1
  317. package/dist/user/user.service.d.ts +12 -5
  318. package/dist/user/user.service.js +49 -11
  319. package/dist/user/user.service.js.map +1 -1
  320. package/package.json +8 -3
  321. package/dist/1756201302119-migrations.d.ts +0 -6
  322. package/dist/1756201302119-migrations.js +0 -84
  323. package/dist/1756201302119-migrations.js.map +0 -1
  324. package/dist/auth/enums/auth-methods.enum.d.ts +0 -2
  325. package/dist/auth/enums/auth-methods.enum.js +0 -7
  326. package/dist/auth/enums/auth-methods.enum.js.map +0 -1
  327. package/dist/auth/session/auth.controller.d.ts +0 -10
  328. package/dist/auth/session/auth.controller.js +0 -92
  329. package/dist/auth/session/auth.controller.js.map +0 -1
  330. package/dist/auth/session/auth.service.d.ts +0 -12
  331. package/dist/auth/session/auth.service.js +0 -46
  332. package/dist/auth/session/auth.service.js.map +0 -1
  333. package/dist/common/constants.d.ts +0 -1
  334. package/dist/common/constants.js +0 -5
  335. package/dist/common/constants.js.map +0 -1
  336. package/dist/common/entities/base.repository.d.ts +0 -7
  337. package/dist/common/entities/base.repository.js.map +0 -1
  338. package/dist/core/plugin/plugin-hook.service.d.ts +0 -7
  339. package/dist/core/plugin/plugin-hook.service.js.map +0 -1
  340. package/dist/media/entities/post-media.entity.d.ts +0 -5
  341. package/dist/media/entities/post-media.entity.js.map +0 -1
  342. package/dist/user/dto/update-user.dto.d.ts +0 -5
  343. package/dist/user/dto/update-user.dto.js +0 -13
  344. package/dist/user/dto/update-user.dto.js.map +0 -1
@@ -20,6 +20,8 @@ const oidc_service_1 = require("./oidc.service");
20
20
  const class_transformer_1 = require("class-transformer");
21
21
  const responses_1 = require("./dto/responses");
22
22
  const session_service_1 = require("../session/session.service");
23
+ const requests_1 = require("./dto/requests");
24
+ const user_response_dto_1 = require("../../user/dto/user-response.dto");
23
25
  let OidcController = class OidcController {
24
26
  service;
25
27
  sessions;
@@ -32,16 +34,26 @@ let OidcController = class OidcController {
32
34
  .getProviders()
33
35
  .map((p) => (0, class_transformer_1.plainToInstance)(responses_1.OidcProviderResponseDto, p));
34
36
  }
35
- async login(id, res) {
37
+ async login(id, params, res) {
36
38
  const provider = this.service.getProviders()[0];
37
- const url = await this.service.getAuthorizationUrl(provider, 'todo');
39
+ const url = await this.service.getAuthorizationUrl(provider, 'todo', params);
38
40
  res.redirect(302, url);
39
41
  }
40
- async callback(code, res) {
42
+ async exchangeCode(dto, res) {
41
43
  const provider = this.service.getProviders()[0];
42
- const { accessToken } = await this.service.processAuthorizationCode(provider, code);
43
- this.sessions.setSessionCookie(accessToken, res);
44
- return 'Success. You can close this window';
44
+ const { authToken, user } = await this.service.processAuthorizationCode({
45
+ provider,
46
+ code: dto.code,
47
+ redirectUri: dto.redirectUri,
48
+ codeVerifier: dto.codeVerifier,
49
+ });
50
+ this.sessions.setSessionCookie(authToken, res);
51
+ return {
52
+ authToken,
53
+ user: (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, user, {
54
+ excludeExtraneousValues: true,
55
+ }),
56
+ };
45
57
  }
46
58
  };
47
59
  exports.OidcController = OidcController;
@@ -58,30 +70,32 @@ __decorate([
58
70
  ], OidcController.prototype, "listOidcProviders", null);
59
71
  __decorate([
60
72
  (0, swagger_1.ApiOperation)({
61
- summary: 'Initiates an oidc login flow',
73
+ summary: 'Initiates an oidc authorization flow',
62
74
  description: `This OIDC API method kicks off the login flow for a given provider.`,
63
75
  }),
64
- (0, common_1.Get)('auth.oidc.login'),
76
+ (0, common_1.Get)('auth.oidc.authorize'),
65
77
  openapi.ApiResponse({ status: 200 }),
66
78
  __param(0, (0, common_1.Query)('id')),
67
- __param(1, (0, common_1.Res)()),
79
+ __param(1, (0, common_1.Query)()),
80
+ __param(2, (0, common_1.Res)()),
68
81
  __metadata("design:type", Function),
69
- __metadata("design:paramtypes", [String, Object]),
82
+ __metadata("design:paramtypes", [String, Object, Object]),
70
83
  __metadata("design:returntype", Promise)
71
84
  ], OidcController.prototype, "login", null);
72
85
  __decorate([
73
86
  (0, swagger_1.ApiOperation)({
74
- summary: 'Callback to respond to OIDC events',
75
- description: `This OIDC API method is to be used as the redirect_uri in the OIDC auth flow.`,
87
+ summary: 'Exchange an OIDC Authorization Code for a Social.Dev session',
88
+ description: `This OIDC API method is to be used to exchange and OAuth2 Authorization Code, obtained from the OIDC authorization flow,
89
+ for a Social.Dev session.`,
76
90
  }),
77
- (0, common_1.Get)('auth.oidc.callback'),
78
- openapi.ApiResponse({ status: 200, type: String }),
79
- __param(0, (0, common_1.Query)('code')),
91
+ (0, common_1.Post)('auth.oidc.exchangeCode'),
92
+ openapi.ApiResponse({ status: 201 }),
93
+ __param(0, (0, common_1.Body)()),
80
94
  __param(1, (0, common_1.Res)({ passthrough: true })),
81
95
  __metadata("design:type", Function),
82
- __metadata("design:paramtypes", [String, Object]),
96
+ __metadata("design:paramtypes", [requests_1.OidcExchangeCodeDto, Object]),
83
97
  __metadata("design:returntype", Promise)
84
- ], OidcController.prototype, "callback", null);
98
+ ], OidcController.prototype, "exchangeCode", null);
85
99
  exports.OidcController = OidcController = __decorate([
86
100
  (0, common_1.Controller)(),
87
101
  (0, swagger_1.ApiTags)('Auth'),
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.controller.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAA6D;AAC7D,6CAAwD;AAExD,iDAA6C;AAC7C,yDAAqE;AACrE,+CAA0D;AAC1D,gEAA4D;AAIrD,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,OAAoB,EACpB,QAAwB;QADxB,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAgB;IAC/B,CAAC;IAOJ,iBAAiB;QACf,OAAO,IAAI,CAAC,OAAO;aAChB,YAAY,EAAE;aACd,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAuB,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAOK,AAAN,KAAK,CAAC,KAAK,CAAc,EAAU,EAAS,GAAa;QACvD,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAErE,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAOK,AAAN,KAAK,CAAC,QAAQ,CACG,IAAY,EACC,GAAa;QAEzC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,CACjE,QAAQ,EACR,IAAI,CACL,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;QAEjD,OAAO,oCAAoC,CAAC;IAC9C,CAAC;CACF,CAAA;AAhDY,wCAAc;AAWzB;IALC,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,qCAAqC;QAC9C,WAAW,EAAE,kFAAkF;KAChG,CAAC;IACD,IAAA,YAAG,EAAC,0BAA0B,CAAC;;;;;uDAK/B;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,8BAA8B;QACvC,WAAW,EAAE,qEAAqE;KACnF,CAAC;IACD,IAAA,YAAG,EAAC,iBAAiB,CAAC;;IACV,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;IAAc,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2CAK1C;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EAAE,+EAA+E;KAC7F,CAAC;IACD,IAAA,YAAG,EAAC,oBAAoB,CAAC;;IAEvB,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;IACb,WAAA,IAAA,YAAG,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;;;8CAW5B;yBA/CU,cAAc;IAF1B,IAAA,mBAAU,GAAE;IACZ,IAAA,iBAAO,EAAC,MAAM,CAAC;qCAGK,0BAAW;QACV,gCAAc;GAHvB,cAAc,CAgD1B"}
1
+ {"version":3,"file":"oidc.controller.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyE;AACzE,6CAAwD;AAExD,iDAA6C;AAC7C,yDAAoD;AACpD,+CAA0D;AAC1D,gEAA4D;AAC5D,6CAAqD;AACrD,wEAA+D;AAIxD,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,OAAoB,EACpB,QAAwB;QADxB,YAAO,GAAP,OAAO,CAAa;QACpB,aAAQ,GAAR,QAAQ,CAAgB;IAC/B,CAAC;IAOJ,iBAAiB;QACf,OAAO,IAAI,CAAC,OAAO;aAChB,YAAY,EAAE;aACd,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,mCAAe,EAAC,mCAAuB,EAAE,CAAC,CAAC,CAAC,CAAC;IAC7D,CAAC;IAOK,AAAN,KAAK,CAAC,KAAK,CACI,EAAU,EACd,MAA8B,EAChC,GAAa;QAGpB,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAChD,QAAQ,EACR,MAAM,EACN,MAAM,CACP,CAAC;QAEF,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAQK,AAAN,KAAK,CAAC,YAAY,CACR,GAAwB,EACJ,GAAa;QAEzC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC;QAChD,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC;YACtE,QAAQ;YACR,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,WAAW;YAC5B,YAAY,EAAE,GAAG,CAAC,YAAY;SAC/B,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAE/C,OAAO;YACL,SAAS;YACT,IAAI,EAAE,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,EAAE;gBAC3C,uBAAuB,EAAE,IAAI;aAC9B,CAAC;SACH,CAAC;IACJ,CAAC;CACF,CAAA;AAjEY,wCAAc;AAWzB;IALC,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,qCAAqC;QAC9C,WAAW,EAAE,kFAAkF;KAChG,CAAC;IACD,IAAA,YAAG,EAAC,0BAA0B,CAAC;;;;;uDAK/B;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,sCAAsC;QAC/C,WAAW,EAAE,qEAAqE;KACnF,CAAC;IACD,IAAA,YAAG,EAAC,qBAAqB,CAAC;;IAExB,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;IACX,WAAA,IAAA,cAAK,GAAE,CAAA;IACP,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2CAWP;AAQK;IANL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,8DAA8D;QACvE,WAAW,EAAE;8BACa;KAC3B,CAAC;IACD,IAAA,aAAI,EAAC,wBAAwB,CAAC;;IAE5B,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;qCADd,8BAAmB;;kDAmBjC;yBAhEU,cAAc;IAF1B,IAAA,mBAAU,GAAE;IACZ,IAAA,iBAAO,EAAC,MAAM,CAAC;qCAGK,0BAAW;QACV,gCAAc;GAHvB,cAAc,CAiE1B"}
@@ -15,6 +15,7 @@ const user_module_1 = require("../../user/user.module");
15
15
  const typeorm_1 = require("@nestjs/typeorm");
16
16
  const oidc_user_entity_1 = require("./entities/oidc-user.entity");
17
17
  const session_module_1 = require("../session/session.module");
18
+ const configs_module_1 = require("../../configs/configs.module");
18
19
  let OidcModule = class OidcModule {
19
20
  };
20
21
  exports.OidcModule = OidcModule;
@@ -25,6 +26,7 @@ exports.OidcModule = OidcModule = __decorate([
25
26
  axios_1.HttpModule,
26
27
  (0, common_1.forwardRef)(() => user_module_1.UserModule),
27
28
  session_module_1.SessionModule,
29
+ configs_module_1.ConfigsModule,
28
30
  ],
29
31
  providers: [oidc_service_1.OidcService],
30
32
  controllers: [oidc_controller_1.OidcController],
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.module.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,yCAA2C;AAC3C,wDAAgD;AAChD,6CAAgD;AAChD,kEAAuD;AACvD,8DAA0D;AAYnD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAVtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,2BAAQ,CAAC,CAAC;YACpC,kBAAU;YACV,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,8BAAa;SACd;QACD,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,WAAW,EAAE,CAAC,gCAAc,CAAC;KAC9B,CAAC;GACW,UAAU,CAAG"}
1
+ {"version":3,"file":"oidc.module.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAoD;AACpD,uDAAmD;AACnD,iDAA6C;AAC7C,yCAA2C;AAC3C,wDAAgD;AAChD,6CAAgD;AAChD,kEAAuD;AACvD,8DAA0D;AAC1D,iEAAyD;AAalD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IAXtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,2BAAQ,CAAC,CAAC;YACpC,kBAAU;YACV,IAAA,mBAAU,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;YAC5B,8BAAa;YACb,8BAAa;SACd;QACD,SAAS,EAAE,CAAC,0BAAW,CAAC;QACxB,WAAW,EAAE,CAAC,gCAAc,CAAC;KAC9B,CAAC;GACW,UAAU,CAAG"}
@@ -4,7 +4,8 @@ import { User } from '~/user/entities/user.entity';
4
4
  import { DataSource, Repository } from 'typeorm';
5
5
  import { OidcUser } from './entities/oidc-user.entity';
6
6
  import { SessionService } from '../session/session.service';
7
- type OidcProvider = {
7
+ import { ConfigsService } from '~/configs/configs.service';
8
+ export type OidcProvider = {
8
9
  id: string;
9
10
  name: string;
10
11
  issuer: string;
@@ -17,16 +18,21 @@ export declare class OidcService {
17
18
  private http;
18
19
  private users;
19
20
  private sessions;
20
- constructor(oidcUserRepository: Repository<OidcUser>, dataSource: DataSource, http: HttpService, users: UserService, sessions: SessionService);
21
+ private configs;
22
+ constructor(oidcUserRepository: Repository<OidcUser>, dataSource: DataSource, http: HttpService, users: UserService, sessions: SessionService, configs: ConfigsService);
21
23
  getProviders(): OidcProvider[];
22
- getAuthorizationUrl(provider: OidcProvider, stateToken: string): Promise<string>;
23
- processAuthorizationCode(provider: OidcProvider, code: string): Promise<{
24
- accessToken: string;
24
+ getAuthorizationUrl(provider: OidcProvider, stateToken: string, extraParams?: Record<string, string>): Promise<string>;
25
+ processAuthorizationCode({ provider, code, redirectUri, codeVerifier, }: {
26
+ provider: OidcProvider;
27
+ code: string;
28
+ redirectUri?: string;
29
+ codeVerifier?: string;
30
+ }): Promise<{
31
+ authToken: string;
25
32
  user: User;
26
33
  }>;
27
- getUserInfo(endpoint: string, accessToken: string): Promise<Object>;
34
+ getUserInfo(endpoint: string, authToken: string): Promise<Object>;
28
35
  getUserFromSub(provider: OidcProvider, sub: string): Promise<User | null>;
29
36
  private getOpenIdConfiguration;
30
37
  private getJwk;
31
38
  }
32
- export {};
@@ -25,60 +25,66 @@ const typeorm_1 = require("typeorm");
25
25
  const oidc_user_entity_1 = require("./entities/oidc-user.entity");
26
26
  const typeorm_2 = require("@nestjs/typeorm");
27
27
  const session_service_1 = require("../session/session.service");
28
+ const configs_service_1 = require("../../configs/configs.service");
28
29
  let OidcService = class OidcService {
29
30
  oidcUserRepository;
30
31
  dataSource;
31
32
  http;
32
33
  users;
33
34
  sessions;
34
- constructor(oidcUserRepository, dataSource, http, users, sessions) {
35
+ configs;
36
+ constructor(oidcUserRepository, dataSource, http, users, sessions, configs) {
35
37
  this.oidcUserRepository = oidcUserRepository;
36
38
  this.dataSource = dataSource;
37
39
  this.http = http;
38
40
  this.users = users;
39
41
  this.sessions = sessions;
42
+ this.configs = configs;
40
43
  }
41
44
  getProviders() {
42
- return [
43
- {
44
- id: 'test',
45
- name: 'Zitadel',
46
- issuer: 'https://minds-test-hlrirg.zitadel.cloud',
47
- clientId: '241850086068397974@minds-test',
48
- clientSecret: '2QzFBlXKXCUall4gbU706hLKyOgfLQANLIFao7agxR33tRRV4SIJcgZJrAQT2IGP',
49
- },
50
- ];
45
+ return this.configs.get('auth')?.oidc?.providers || [];
51
46
  }
52
- async getAuthorizationUrl(provider, stateToken) {
47
+ async getAuthorizationUrl(provider, stateToken, extraParams) {
53
48
  const openidConfig = await this.getOpenIdConfiguration(provider);
54
49
  const authUrl = openidConfig['authorization_endpoint'];
55
50
  const supportedScopes = openidConfig['scopes_supported'];
56
51
  const scopes = ['openid', 'profile', 'email'].filter((scope) => supportedScopes.includes(scope));
57
52
  const params = new URLSearchParams({
53
+ ...extraParams,
58
54
  response_type: 'code',
59
55
  client_id: provider.clientId,
60
56
  state: stateToken,
61
57
  scope: scopes.join(' '),
62
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
58
+ redirect_uri: extraParams?.redirect_uri ||
59
+ context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
63
60
  provider_id: provider.id,
64
61
  });
65
62
  return `${authUrl}?${params.toString()}`;
66
63
  }
67
- async processAuthorizationCode(provider, code) {
64
+ async processAuthorizationCode({ provider, code, redirectUri, codeVerifier, }) {
68
65
  const openidConfig = await this.getOpenIdConfiguration(provider);
69
66
  const tokenUrl = openidConfig['token_endpoint'];
70
- const res = await (0, rxjs_1.firstValueFrom)(this.http.post(tokenUrl, {
71
- code,
72
- client_id: provider.clientId,
73
- client_secret: provider.clientSecret,
74
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
75
- grant_type: 'authorization_code',
76
- }, {
77
- headers: {
78
- 'Content-Type': 'application/x-www-form-urlencoded',
79
- },
80
- }));
81
- const data = res.data;
67
+ let data;
68
+ try {
69
+ const res = await (0, rxjs_1.firstValueFrom)(this.http.post(tokenUrl, {
70
+ code,
71
+ client_id: provider.clientId,
72
+ client_secret: provider.clientSecret,
73
+ redirect_uri: redirectUri ||
74
+ context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
75
+ grant_type: 'authorization_code',
76
+ code_verifier: codeVerifier,
77
+ }, {
78
+ headers: {
79
+ 'Content-Type': 'application/x-www-form-urlencoded',
80
+ },
81
+ }));
82
+ data = res.data;
83
+ }
84
+ catch (err) {
85
+ console.log(err);
86
+ throw new common_1.InternalServerErrorException();
87
+ }
82
88
  const jwks = await this.getJwk(provider);
83
89
  if (!jwks) {
84
90
  throw new common_1.NotAcceptableException("The OIDC provider does not have JWK's");
@@ -93,6 +99,7 @@ let OidcService = class OidcService {
93
99
  let user = await this.getUserFromSub(provider, sub);
94
100
  if (!user) {
95
101
  let preferredUsername = userInfo['preferred_username'] ||
102
+ userInfo['nickname'] ||
96
103
  userInfo['name'].replace(' ', '');
97
104
  try {
98
105
  await this.users.verifyUsername(preferredUsername);
@@ -131,13 +138,13 @@ let OidcService = class OidcService {
131
138
  await queryRunner.commitTransaction();
132
139
  queryRunner.release();
133
140
  }
134
- const { accessToken } = await this.sessions.create(user);
135
- return { accessToken, user };
141
+ const { authToken } = await this.sessions.create(user);
142
+ return { authToken, user };
136
143
  }
137
- async getUserInfo(endpoint, accessToken) {
144
+ async getUserInfo(endpoint, authToken) {
138
145
  const res = await (0, rxjs_1.firstValueFrom)(this.http.get(endpoint, {
139
146
  headers: {
140
- Authorization: `Bearer ${accessToken}`,
147
+ Authorization: `Bearer ${authToken}`,
141
148
  },
142
149
  }));
143
150
  return res.data;
@@ -176,6 +183,7 @@ exports.OidcService = OidcService = __decorate([
176
183
  typeorm_1.DataSource,
177
184
  axios_1.HttpService,
178
185
  user_service_1.UserService,
179
- session_service_1.SessionService])
186
+ session_service_1.SessionService,
187
+ configs_service_1.ConfigsService])
180
188
  ], OidcService);
181
189
  //# sourceMappingURL=oidc.service.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"oidc.service.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.service.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"oidc.service.js","sourceRoot":"","sources":["../../../src/auth/oidc/oidc.service.ts"],"names":[],"mappings":"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"}
@@ -32,9 +32,14 @@ let SessionController = class SessionController {
32
32
  username: signInDto.username,
33
33
  password: signInDto.password,
34
34
  });
35
- const { accessToken } = await this.service.create(user);
36
- this.service.setSessionCookie(accessToken, res);
37
- res.send({ accessToken, user: (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, user) });
35
+ const { authToken } = await this.service.create(user);
36
+ this.service.setSessionCookie(authToken, res);
37
+ res.send({
38
+ authToken,
39
+ user: (0, class_transformer_1.plainToInstance)(user_response_dto_1.UserResponseDto, user, {
40
+ excludeExtraneousValues: true,
41
+ }),
42
+ });
38
43
  }
39
44
  async logout(res) {
40
45
  this.service.deleteSessionCookie(res);
@@ -1 +1 @@
1
- {"version":3,"file":"session.controller.js","sourceRoot":"","sources":["../../../src/auth/session/session.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAUwB;AAGxB,6CAA8E;AAC9E,yDAAoD;AACpD,wEAA+D;AAC/D,gDAA4C;AAC5C,gEAAmE;AACnE,8CAA0C;AAC1C,uDAAmD;AAI5C,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IACR;IAApB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAezC,AAAN,KAAK,CAAC,KAAK,CACD,SAAmB,EACM,GAAoB;QAErD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC;YAC1D,QAAQ,EAAE,SAAS,CAAC,QAAQ;YAC5B,QAAQ,EAAE,SAAS,CAAC,QAAQ;SAC7B,CAAC,CAAC;QAEH,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAExD,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;QAEhD,GAAG,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAC1E,CAAC;IASK,AAAN,KAAK,CAAC,MAAM,CAAkC,GAAoB;QAEhE,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEtC,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;IACnD,CAAC;CACF,CAAA;AA7CY,8CAAiB;AAgBtB;IAbL,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,sBAAY,EAAC;QACZ,OAAO,EACL,wEAAwE;QAC1E,WAAW,EAAE;oFACmE;KACjF,CAAC;IACD,IAAA,aAAI,EAAC,qBAAqB,CAAC;IAC3B,IAAA,qBAAW,EAAC;QACX,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,kBAAkB;QAC/B,IAAI,EAAE,2CAAuB;KAC9B,CAAC;kCAZQ,mBAAU,CAAC,EAAE;IAcpB,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,iBAAQ,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;qCADb,oBAAQ;;8CAa5B;AASK;IAPL,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,4DAA4D;QACrE,WAAW,EAAE,kGAAkG;KAChH,CAAC;IACD,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,aAAI,EAAC,qBAAqB,CAAC;kCANlB,mBAAU,CAAC,EAAE;IAOT,WAAA,IAAA,iBAAQ,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;;;+CAK5C;4BA5CU,iBAAiB;IAF7B,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAEkB,gCAAc;GADhC,iBAAiB,CA6C7B"}
1
+ {"version":3,"file":"session.controller.js","sourceRoot":"","sources":["../../../src/auth/session/session.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAUwB;AAGxB,6CAA8E;AAC9E,yDAAqE;AACrE,wEAA+D;AAC/D,gDAA4C;AAC5C,gEAAmE;AACnE,8CAA0C;AAC1C,uDAAmD;AAI5C,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IACR;IAApB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAG,CAAC;IAezC,AAAN,KAAK,CAAC,KAAK,CACD,SAAmB,EACM,GAAoB;QAErD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC;YAC1D,QAAQ,EAAE,SAAS,CAAC,QAAQ;YAC5B,QAAQ,EAAE,SAAS,CAAC,QAAQ;SAC7B,CAAC,CAAC;QAEH,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QAEtD,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;QAE9C,GAAG,CAAC,IAAI,CAAC;YACP,SAAS;YACT,IAAI,EAAE,IAAA,mCAAe,EAAC,mCAAe,EAAE,IAAI,EAAE;gBAC3C,uBAAuB,EAAE,IAAI;aAC9B,CAAC;SACH,CAAC,CAAC;IACL,CAAC;IASK,AAAN,KAAK,CAAC,MAAM,CAAkC,GAAoB;QAEhE,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC;QAEtC,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,yBAAyB,EAAE,CAAC,CAAC;IACnD,CAAC;CACF,CAAA;AAlDY,8CAAiB;AAgBtB;IAbL,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,sBAAY,EAAC;QACZ,OAAO,EACL,wEAAwE;QAC1E,WAAW,EAAE;oFACmE;KACjF,CAAC;IACD,IAAA,aAAI,EAAC,qBAAqB,CAAC;IAC3B,IAAA,qBAAW,EAAC;QACX,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,kBAAkB;QAC/B,IAAI,EAAE,2CAAuB;KAC9B,CAAC;kCAZQ,mBAAU,CAAC,EAAE;IAcpB,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,iBAAQ,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;qCADb,oBAAQ;;8CAkB5B;AASK;IAPL,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,4DAA4D;QACrE,WAAW,EAAE,kGAAkG;KAChH,CAAC;IACD,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,aAAI,EAAC,qBAAqB,CAAC;kCANlB,mBAAU,CAAC,EAAE;IAOT,WAAA,IAAA,iBAAQ,EAAC,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;;;;+CAK5C;4BAjDU,iBAAiB;IAF7B,IAAA,iBAAO,EAAC,MAAM,CAAC;IACf,IAAA,mBAAU,GAAE;qCAEkB,gCAAc;GADhC,iBAAiB,CAkD7B"}
@@ -7,9 +7,9 @@ export declare class SessionService {
7
7
  private jwtService;
8
8
  constructor(userService: UserService, jwtService: JwtService);
9
9
  create(user: User): Promise<{
10
- accessToken: string;
10
+ authToken: string;
11
11
  }>;
12
- setSessionCookie(accessToken: string, response: Response): void;
12
+ setSessionCookie(authToken: string, response: Response): void;
13
13
  deleteSessionCookie(response: Response): void;
14
14
  getUserFromUsernamePassword({ username, password, }: {
15
15
  username: string;
@@ -13,6 +13,7 @@ exports.SessionService = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
14
  const jwt_1 = require("@nestjs/jwt");
15
15
  const user_service_1 = require("../../user/user.service");
16
+ const argon2_1 = require("@node-rs/argon2");
16
17
  let SessionService = class SessionService {
17
18
  userService;
18
19
  jwtService;
@@ -26,13 +27,13 @@ let SessionService = class SessionService {
26
27
  sub: user.id,
27
28
  username: user.username,
28
29
  };
29
- const accessToken = await this.jwtService.signAsync(payload);
30
+ const authToken = await this.jwtService.signAsync(payload);
30
31
  return {
31
- accessToken,
32
+ authToken,
32
33
  };
33
34
  }
34
- setSessionCookie(accessToken, response) {
35
- response.cookie('sess', accessToken, {
35
+ setSessionCookie(authToken, response) {
36
+ response.cookie('sess', authToken, {
36
37
  httpOnly: true,
37
38
  secure: true,
38
39
  sameSite: 'strict',
@@ -47,7 +48,10 @@ let SessionService = class SessionService {
47
48
  }
48
49
  async getUserFromUsernamePassword({ username, password, }) {
49
50
  const user = await this.userService.findOneByUsername(username);
50
- if (user?.password !== password) {
51
+ if (!user) {
52
+ throw new common_1.UnauthorizedException();
53
+ }
54
+ if (!(await (0, argon2_1.verify)(user.password, password))) {
51
55
  throw new common_1.UnauthorizedException();
52
56
  }
53
57
  return user;
@@ -1 +1 @@
1
- {"version":3,"file":"session.service.js","sourceRoot":"","sources":["../../../src/auth/session/session.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AACnE,qCAAyC;AAGzC,0DAAkD;AAG3C,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,WAAwB,EACxB,UAAsB;QADtB,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAKJ,KAAK,CAAC,MAAM,CAAC,IAAU;QACrB,MAAM,OAAO,GAAG;YACd,GAAG,EAAE,CAAC;YACN,GAAG,EAAE,IAAI,CAAC,EAAE;YACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;QACF,MAAM,WAAW,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC7D,OAAO;YACL,WAAW;SACZ,CAAC;IACJ,CAAC;IAKD,gBAAgB,CAAC,WAAmB,EAAE,QAAkB;QACtD,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE;YACnC,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAKD,mBAAmB,CAAC,QAAkB;QACpC,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE;YAC3B,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAKD,KAAK,CAAC,2BAA2B,CAAC,EAChC,QAAQ,EACR,QAAQ,GAIT;QACC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAChE,IAAI,IAAI,EAAE,QAAQ,KAAK,QAAQ,EAAE,CAAC;YAChC,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA3DY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACZ,gBAAU;GAHrB,cAAc,CA2D1B"}
1
+ {"version":3,"file":"session.service.js","sourceRoot":"","sources":["../../../src/auth/session/session.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAmE;AACnE,qCAAyC;AAGzC,0DAAkD;AAClD,4CAAyC;AAGlC,IAAM,cAAc,GAApB,MAAM,cAAc;IAEf;IACA;IAFV,YACU,WAAwB,EACxB,UAAsB;QADtB,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAKJ,KAAK,CAAC,MAAM,CAAC,IAAU;QACrB,MAAM,OAAO,GAAG;YACd,GAAG,EAAE,CAAC;YACN,GAAG,EAAE,IAAI,CAAC,EAAE;YACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;QACF,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC3D,OAAO;YACL,SAAS;SACV,CAAC;IACJ,CAAC;IAKD,gBAAgB,CAAC,SAAiB,EAAE,QAAkB;QACpD,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,EAAE;YACjC,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAKD,mBAAmB,CAAC,QAAkB;QACpC,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE;YAC3B,QAAQ,EAAE,IAAI;YACd,MAAM,EAAE,IAAI;YACZ,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAKD,KAAK,CAAC,2BAA2B,CAAC,EAChC,QAAQ,EACR,QAAQ,GAIT;QACC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAEhE,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QAED,IAAI,CAAC,CAAC,MAAM,IAAA,eAAM,EAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC,EAAE,CAAC;YAC7C,MAAM,IAAI,8BAAqB,EAAE,CAAC;QACpC,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AAhEY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACZ,gBAAU;GAHrB,cAAc,CAgE1B"}
@@ -1 +1,2 @@
1
- export declare function bootstrap(): Promise<void>;
1
+ import { Configs } from './configs/configs.service';
2
+ export declare function bootstrap(configs: Configs): Promise<void>;
package/dist/bootstrap.js CHANGED
@@ -8,9 +8,15 @@ const core_1 = require("@nestjs/core");
8
8
  const swagger_1 = require("@nestjs/swagger");
9
9
  const app_module_1 = require("./app.module");
10
10
  const cookie_parser_1 = __importDefault(require("cookie-parser"));
11
- async function bootstrap() {
11
+ const configs_service_1 = require("./configs/configs.service");
12
+ const event_stream_processor_service_1 = require("./core/event-stream/event-stream-processor.service");
13
+ const common_1 = require("@nestjs/common");
14
+ async function bootstrap(configs) {
15
+ process.env.TZ = 'UTC';
16
+ configs_service_1.ConfigsService.init(configs);
12
17
  console.log('Environment check - SOCIAL_DEV_SERVER_PORT:', process.env.SOCIAL_DEV_SERVER_PORT);
13
18
  const app = await core_1.NestFactory.create(app_module_1.AppModule);
19
+ app.useGlobalPipes(new common_1.ValidationPipe());
14
20
  app.enableCors();
15
21
  const config = new swagger_1.DocumentBuilder()
16
22
  .setTitle('Social.dev')
@@ -28,5 +34,7 @@ async function bootstrap() {
28
34
  await app.listen(port, '0.0.0.0');
29
35
  console.log(`🚀 Server is running on http://localhost:${port}`);
30
36
  console.log(`📚 Swagger documentation available at http://localhost:${port}/schema`);
37
+ const eventStreamProcessors = app.get(event_stream_processor_service_1.EventStreamProcessorService);
38
+ eventStreamProcessors.setAppRef(app).processAll();
31
39
  }
32
40
  //# sourceMappingURL=bootstrap.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../src/bootstrap.ts"],"names":[],"mappings":";;;;;AAKA,8BA6BC;AAlCD,uCAA2C;AAC3C,6CAAiE;AACjE,6CAAyC;AACzC,kEAAyC;AAElC,KAAK,UAAU,SAAS;IAC7B,OAAO,CAAC,GAAG,CACT,6CAA6C,EAC7C,OAAO,CAAC,GAAG,CAAC,sBAAsB,CACnC,CAAC;IACF,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,sBAAS,CAAC,CAAC;IAEhD,GAAG,CAAC,UAAU,EAAE,CAAC;IAEjB,MAAM,MAAM,GAAG,IAAI,yBAAe,EAAE;SACjC,QAAQ,CAAC,YAAY,CAAC;SACtB,cAAc,CAAC,oBAAoB,CAAC;SACpC,UAAU,CAAC,KAAK,CAAC;SACjB,MAAM,CAAC,QAAQ,CAAC;SAChB,aAAa,EAAE;SACf,KAAK,EAAE,CAAC;IACX,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACxE,uBAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,eAAe,EAAE;QAClD,SAAS,EAAE,uCAAuC;KACnD,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,IAAA,uBAAY,GAAE,CAAC,CAAC;IAExB,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,MAAM,CAAC,CAAC;IACpE,MAAM,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAClC,OAAO,CAAC,GAAG,CAAC,4CAA4C,IAAI,EAAE,CAAC,CAAC;IAChE,OAAO,CAAC,GAAG,CACT,0DAA0D,IAAI,SAAS,CACxE,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../src/bootstrap.ts"],"names":[],"mappings":";;;;;AAQA,8BAyCC;AAjDD,uCAA2C;AAC3C,6CAAiE;AACjE,6CAAyC;AACzC,kEAAyC;AACzC,+DAAoE;AACpE,uGAAiG;AACjG,2CAAgD;AAEzC,KAAK,UAAU,SAAS,CAAC,OAAgB;IAC9C,OAAO,CAAC,GAAG,CAAC,EAAE,GAAG,KAAK,CAAC;IAGvB,gCAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAE7B,OAAO,CAAC,GAAG,CACT,6CAA6C,EAC7C,OAAO,CAAC,GAAG,CAAC,sBAAsB,CACnC,CAAC;IACF,MAAM,GAAG,GAAG,MAAM,kBAAW,CAAC,MAAM,CAAC,sBAAS,CAAC,CAAC;IAEhD,GAAG,CAAC,cAAc,CAAC,IAAI,uBAAc,EAAE,CAAC,CAAC;IACzC,GAAG,CAAC,UAAU,EAAE,CAAC;IAEjB,MAAM,MAAM,GAAG,IAAI,yBAAe,EAAE;SACjC,QAAQ,CAAC,YAAY,CAAC;SACtB,cAAc,CAAC,oBAAoB,CAAC;SACpC,UAAU,CAAC,KAAK,CAAC;SACjB,MAAM,CAAC,QAAQ,CAAC;SAChB,aAAa,EAAE;SACf,KAAK,EAAE,CAAC;IACX,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,uBAAa,CAAC,cAAc,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IACxE,uBAAa,CAAC,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,eAAe,EAAE;QAClD,SAAS,EAAE,uCAAuC;KACnD,CAAC,CAAC;IAEH,GAAG,CAAC,GAAG,CAAC,IAAA,uBAAY,GAAE,CAAC,CAAC;IAExB,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,MAAM,CAAC,CAAC;IACpE,MAAM,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAClC,OAAO,CAAC,GAAG,CAAC,4CAA4C,IAAI,EAAE,CAAC,CAAC;IAChE,OAAO,CAAC,GAAG,CACT,0DAA0D,IAAI,SAAS,CACxE,CAAC;IAKF,MAAM,qBAAqB,GAAG,GAAG,CAAC,GAAG,CAAC,4DAA2B,CAAC,CAAC;IACnE,qBAAqB,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,CAAC;AACpD,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare class ChatAclService {
2
+ registerRules(): void;
3
+ }
@@ -0,0 +1,50 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.ChatAclService = void 0;
10
+ const acl_factory_1 = require("../core/acl/acl.factory");
11
+ const conversation_entity_1 = require("./entities/conversation.entity");
12
+ const common_1 = require("@nestjs/common");
13
+ const conversation_type_enum_1 = require("./enums/conversation-type.enum");
14
+ const message_entity_1 = require("./entities/message.entity");
15
+ let ChatAclService = class ChatAclService {
16
+ registerRules() {
17
+ acl_factory_1.AclFactory.addRule(({ can, getAbility, user }) => {
18
+ return can(acl_factory_1.Action.Read, conversation_entity_1.ChatConversation, (conversation) => {
19
+ if (!user) {
20
+ return false;
21
+ }
22
+ if (conversation.type === conversation_type_enum_1.ConversationType.OneOnOne) {
23
+ if (conversation.members && Array.isArray(conversation.members)) {
24
+ return conversation.members.some((member) => member.userId === user.id);
25
+ }
26
+ return false;
27
+ }
28
+ if (conversation.type === conversation_type_enum_1.ConversationType.Community) {
29
+ return getAbility().can(acl_factory_1.Action.Read, conversation.community);
30
+ }
31
+ return false;
32
+ });
33
+ });
34
+ acl_factory_1.AclFactory.addRule(({ can }) => {
35
+ return can(acl_factory_1.Action.List, conversation_entity_1.ChatConversation, () => true);
36
+ });
37
+ acl_factory_1.AclFactory.addRule(({ can }) => can(acl_factory_1.Action.Create, conversation_entity_1.ChatConversation, () => true));
38
+ acl_factory_1.AclFactory.addRule(({ can, getAbility }) => can(acl_factory_1.Action.Read, message_entity_1.ChatMessage, (message) => {
39
+ if (message.conversation) {
40
+ return getAbility().can(acl_factory_1.Action.Read, message.conversation);
41
+ }
42
+ return false;
43
+ }));
44
+ }
45
+ };
46
+ exports.ChatAclService = ChatAclService;
47
+ exports.ChatAclService = ChatAclService = __decorate([
48
+ (0, common_1.Injectable)()
49
+ ], ChatAclService);
50
+ //# sourceMappingURL=chat.acl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chat.acl.js","sourceRoot":"","sources":["../../src/chat/chat.acl.ts"],"names":[],"mappings":";;;;;;;;;AAAA,yDAA0E;AAC1E,wEAAkE;AAClE,2CAA4C;AAC5C,2EAAkE;AAElE,8DAAwD;AAGjD,IAAM,cAAc,GAApB,MAAM,cAAc;IACzB,aAAa;QAEX,wBAAU,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,IAAI,EAAE,EAAE,EAAE;YAC/C,OAAO,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,sCAAgB,EAAE,CAAC,YAAY,EAAE,EAAE;gBACzD,IAAI,CAAC,IAAI,EAAE,CAAC;oBACV,OAAO,KAAK,CAAC;gBACf,CAAC;gBAED,IAAI,YAAY,CAAC,IAAI,KAAK,yCAAgB,CAAC,QAAQ,EAAE,CAAC;oBAGpD,IAAI,YAAY,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC;wBAChE,OAAO,YAAY,CAAC,OAAO,CAAC,IAAI,CAC9B,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,CACtC,CAAC;oBACJ,CAAC;oBAED,OAAO,KAAK,CAAC;gBACf,CAAC;gBAED,IAAI,YAAY,CAAC,IAAI,KAAK,yCAAgB,CAAC,SAAS,EAAE,CAAC;oBACrD,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC;gBAC/D,CAAC;gBAED,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QAGH,wBAAU,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;YAC7B,OAAO,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,sCAAgB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;QACxD,CAAC,CAAC,CAAC;QAGH,wBAAU,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAC7B,GAAG,CAAC,oBAAM,CAAC,MAAM,EAAE,sCAAgB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CACjD,CAAC;QAGF,wBAAU,CAAC,OAAO,CAAC,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,CACzC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,4BAAW,EAAE,CAAC,OAAO,EAAE,EAAE;YAExC,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;gBACzB,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;YAC7D,CAAC;YAID,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CACF,CAAA;AArDY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;GACA,cAAc,CAqD1B"}
@@ -1,18 +1,26 @@
1
1
  import { ChatService } from './chat.service';
2
2
  import { CreateConversationDto } from './dto/create-conversation.dto';
3
3
  import { PaginatedResponseDto } from '~/common/dto/paginated-response.dto';
4
- import { ChatConversationResponseDto, ChatMessageResponseDto } from './dto/responses.dto';
5
- import { ChatConversation } from './entities/conversation.entity';
4
+ import { ChatConversationResponseDto, ChatMessageResponseDto, ChatUnreadCountDto } from './dto/responses.dto';
6
5
  import { CreateMessageDto } from './dto/create-message.dto';
6
+ import { Community } from '~/community/entities/community.entity';
7
+ import { UpdateChatReadCursorDto } from './dto/update-cursor.dto';
8
+ import { ConversationType } from './enums/conversation-type.enum';
9
+ import { AddChatMessageReactionDto } from './dto/add-reaction.dto';
7
10
  export declare class ChatController {
8
11
  private service;
9
12
  constructor(service: ChatService);
10
13
  getConversation(conversationId: string): Promise<ChatConversationResponseDto>;
11
- listConversations(): Promise<PaginatedResponseDto<ChatConversationResponseDto>>;
12
- createConversation(dto: CreateConversationDto): Promise<ChatConversation>;
14
+ listConversations(type?: ConversationType, communityId?: Community['id'], limit?: number, offset?: number): Promise<PaginatedResponseDto<ChatConversationResponseDto>>;
15
+ createConversation(dto: CreateConversationDto): Promise<ChatConversationResponseDto>;
13
16
  deleteConversation(): void;
14
17
  getMessage(messageId: string): ChatMessageResponseDto;
15
- listMessages(conversationId: string): Promise<PaginatedResponseDto<ChatMessageResponseDto>>;
18
+ listMessages(conversationId: string, limit: number | undefined, cursor: any): Promise<PaginatedResponseDto<ChatMessageResponseDto>>;
16
19
  sendMessage(dto: CreateMessageDto): Promise<ChatMessageResponseDto>;
17
- deleteMessage(): void;
20
+ remove(id: string, req: any): Promise<void>;
21
+ addReaction(dto: AddChatMessageReactionDto): Promise<boolean>;
22
+ deleteReaction(dto: AddChatMessageReactionDto): Promise<boolean>;
23
+ updateReadCursor(dto: UpdateChatReadCursorDto): Promise<void>;
24
+ AddChatMessageReactionDto: any;
25
+ getUnreadCount(): Promise<ChatUnreadCountDto>;
18
26
  }