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

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 +49 -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
@@ -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"}
@@ -21,12 +21,17 @@ export declare class OidcService {
21
21
  private configs;
22
22
  constructor(oidcUserRepository: Repository<OidcUser>, dataSource: DataSource, http: HttpService, users: UserService, sessions: SessionService, configs: ConfigsService);
23
23
  getProviders(): OidcProvider[];
24
- getAuthorizationUrl(provider: OidcProvider, stateToken: string): Promise<string>;
25
- processAuthorizationCode(provider: OidcProvider, code: string): Promise<{
26
- 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;
27
32
  user: User;
28
33
  }>;
29
- getUserInfo(endpoint: string, accessToken: string): Promise<Object>;
34
+ getUserInfo(endpoint: string, authToken: string): Promise<Object>;
30
35
  getUserFromSub(provider: OidcProvider, sub: string): Promise<User | null>;
31
36
  private getOpenIdConfiguration;
32
37
  private getJwk;
@@ -44,36 +44,47 @@ let OidcService = class OidcService {
44
44
  getProviders() {
45
45
  return this.configs.get('auth')?.oidc?.providers || [];
46
46
  }
47
- async getAuthorizationUrl(provider, stateToken) {
47
+ async getAuthorizationUrl(provider, stateToken, extraParams) {
48
48
  const openidConfig = await this.getOpenIdConfiguration(provider);
49
49
  const authUrl = openidConfig['authorization_endpoint'];
50
50
  const supportedScopes = openidConfig['scopes_supported'];
51
51
  const scopes = ['openid', 'profile', 'email'].filter((scope) => supportedScopes.includes(scope));
52
52
  const params = new URLSearchParams({
53
+ ...extraParams,
53
54
  response_type: 'code',
54
55
  client_id: provider.clientId,
55
56
  state: stateToken,
56
57
  scope: scopes.join(' '),
57
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
58
+ redirect_uri: extraParams?.redirect_uri ||
59
+ context_1.Context.getNetwork().getBaseUrl() + 'auth.oidc.callback',
58
60
  provider_id: provider.id,
59
61
  });
60
62
  return `${authUrl}?${params.toString()}`;
61
63
  }
62
- async processAuthorizationCode(provider, code) {
64
+ async processAuthorizationCode({ provider, code, redirectUri, codeVerifier, }) {
63
65
  const openidConfig = await this.getOpenIdConfiguration(provider);
64
66
  const tokenUrl = openidConfig['token_endpoint'];
65
- const res = await (0, rxjs_1.firstValueFrom)(this.http.post(tokenUrl, {
66
- code,
67
- client_id: provider.clientId,
68
- client_secret: provider.clientSecret,
69
- redirect_uri: context_1.Context.getNetwork().getBaseUrl() + 'api/auth.oidc.callback',
70
- grant_type: 'authorization_code',
71
- }, {
72
- headers: {
73
- 'Content-Type': 'application/x-www-form-urlencoded',
74
- },
75
- }));
76
- 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() + '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
+ }
77
88
  const jwks = await this.getJwk(provider);
78
89
  if (!jwks) {
79
90
  throw new common_1.NotAcceptableException("The OIDC provider does not have JWK's");
@@ -88,6 +99,7 @@ let OidcService = class OidcService {
88
99
  let user = await this.getUserFromSub(provider, sub);
89
100
  if (!user) {
90
101
  let preferredUsername = userInfo['preferred_username'] ||
102
+ userInfo['nickname'] ||
91
103
  userInfo['name'].replace(' ', '');
92
104
  try {
93
105
  await this.users.verifyUsername(preferredUsername);
@@ -102,37 +114,51 @@ let OidcService = class OidcService {
102
114
  .digest('hex');
103
115
  }
104
116
  else {
117
+ console.error(err);
118
+ console.error(userInfo);
105
119
  throw err;
106
120
  }
107
121
  }
108
122
  const queryRunner = this.dataSource.createQueryRunner();
109
- await queryRunner.connect();
110
- await queryRunner.startTransaction();
111
- user = await this.users.create({
112
- username: preferredUsername,
113
- name: userInfo['name'] || preferredUsername,
114
- email: userInfo['email'],
115
- verified: true,
116
- }, queryRunner);
117
- console.log(user);
118
- const oidcUser = queryRunner.manager.create(oidc_user_entity_1.OidcUser, {
119
- network: context_1.Context.getNetwork(),
120
- providerId: provider.id,
121
- user,
122
- sub,
123
- });
124
- console.log(oidcUser);
125
- await queryRunner.manager.insert(oidc_user_entity_1.OidcUser, oidcUser);
126
- await queryRunner.commitTransaction();
127
- queryRunner.release();
123
+ try {
124
+ await queryRunner.connect();
125
+ await queryRunner.startTransaction();
126
+ user = await this.users.create({
127
+ username: preferredUsername,
128
+ name: userInfo['name'] || preferredUsername,
129
+ email: userInfo['email'],
130
+ verified: true,
131
+ }, queryRunner);
132
+ console.log(user);
133
+ const oidcUser = queryRunner.manager.create(oidc_user_entity_1.OidcUser, {
134
+ network: context_1.Context.getNetwork(),
135
+ providerId: provider.id,
136
+ user,
137
+ sub,
138
+ });
139
+ console.log(oidcUser);
140
+ await queryRunner.manager.insert(oidc_user_entity_1.OidcUser, oidcUser);
141
+ await queryRunner.commitTransaction();
142
+ }
143
+ catch (err) {
144
+ console.log(userInfo, preferredUsername);
145
+ console.log(err);
146
+ await queryRunner.rollbackTransaction();
147
+ }
148
+ finally {
149
+ await queryRunner.release();
150
+ }
151
+ }
152
+ if (!user) {
153
+ throw new common_1.InternalServerErrorException('User not found after OIDC lookup');
128
154
  }
129
- const { accessToken } = await this.sessions.create(user);
130
- return { accessToken, user };
155
+ const { authToken } = await this.sessions.create(user);
156
+ return { authToken, user };
131
157
  }
132
- async getUserInfo(endpoint, accessToken) {
158
+ async getUserInfo(endpoint, authToken) {
133
159
  const res = await (0, rxjs_1.firstValueFrom)(this.http.get(endpoint, {
134
160
  headers: {
135
- Authorization: `Bearer ${accessToken}`,
161
+ Authorization: `Bearer ${authToken}`,
136
162
  },
137
163
  }));
138
164
  return res.data;
@@ -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,16 +27,19 @@ 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
+ console.log(process.env.SOCIAL_DEV_ENV);
37
+ response.cookie('sess', authToken, {
36
38
  httpOnly: true,
37
- secure: true,
38
- sameSite: 'strict',
39
+ secure: process.env.SOCIAL_DEV_SESSION_COOKIE_SECURE === 'true' ||
40
+ (process.env.SOCIAL_DEV_ENV === 'development' ? false : true),
41
+ sameSite: process.env.SOCIAL_DEV_SESSION_COOKIE_SAMESITE ||
42
+ (process.env.SOCIAL_DEV_ENV === 'development' ? undefined : 'strict'),
39
43
  });
40
44
  }
41
45
  deleteSessionCookie(response) {
@@ -47,7 +51,10 @@ let SessionService = class SessionService {
47
51
  }
48
52
  async getUserFromUsernamePassword({ username, password, }) {
49
53
  const user = await this.userService.findOneByUsername(username);
50
- if (user?.password !== password) {
54
+ if (!user) {
55
+ throw new common_1.UnauthorizedException();
56
+ }
57
+ if (!(await (0, argon2_1.verify)(user.password, password))) {
51
58
  throw new common_1.UnauthorizedException();
52
59
  }
53
60
  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,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QACxC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,EAAE;YACjC,QAAQ,EAAE,IAAI;YACd,MAAM,EACJ,OAAO,CAAC,GAAG,CAAC,gCAAgC,KAAK,MAAM;gBACvD,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,KAAK,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;YAC/D,QAAQ,EACL,OAAO,CAAC,GAAG,CAAC,kCAGF;gBACX,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,KAAK,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;SACxE,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;AAxEY,wCAAc;yBAAd,cAAc;IAD1B,IAAA,mBAAU,GAAE;qCAGY,0BAAW;QACZ,gBAAU;GAHrB,cAAc,CAwE1B"}
@@ -1 +1,2 @@
1
- export declare function bootstrap(configs: Object): Promise<void>;
1
+ import { Configs } from './configs/configs.service';
2
+ export declare function bootstrap(configs: Configs): Promise<void>;
package/dist/bootstrap.js CHANGED
@@ -9,11 +9,15 @@ 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
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");
12
14
  async function bootstrap(configs) {
15
+ process.env.TZ = 'UTC';
13
16
  configs_service_1.ConfigsService.init(configs);
14
17
  console.log('Environment check - SOCIAL_DEV_SERVER_PORT:', process.env.SOCIAL_DEV_SERVER_PORT);
15
18
  const app = await core_1.NestFactory.create(app_module_1.AppModule);
16
- app.enableCors();
19
+ app.useGlobalPipes(new common_1.ValidationPipe());
20
+ app.enableCors(configs.cors);
17
21
  const config = new swagger_1.DocumentBuilder()
18
22
  .setTitle('Social.dev')
19
23
  .setDescription('The social.dev API')
@@ -30,5 +34,7 @@ async function bootstrap(configs) {
30
34
  await app.listen(port, '0.0.0.0');
31
35
  console.log(`🚀 Server is running on http://localhost:${port}`);
32
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();
33
39
  }
34
40
  //# sourceMappingURL=bootstrap.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"bootstrap.js","sourceRoot":"","sources":["../src/bootstrap.ts"],"names":[],"mappings":";;;;;AAMA,8BAgCC;AAtCD,uCAA2C;AAC3C,6CAAiE;AACjE,6CAAyC;AACzC,kEAAyC;AACzC,+DAA2D;AAEpD,KAAK,UAAU,SAAS,CAAC,OAAe;IAE7C,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,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,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAE7B,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,27 @@
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';
10
+ import { EditMessageDto } from './dto/edit-message.dto';
7
11
  export declare class ChatController {
8
12
  private service;
9
13
  constructor(service: ChatService);
10
14
  getConversation(conversationId: string): Promise<ChatConversationResponseDto>;
11
- listConversations(): Promise<PaginatedResponseDto<ChatConversationResponseDto>>;
12
- createConversation(dto: CreateConversationDto): Promise<ChatConversation>;
15
+ listConversations(type?: ConversationType, communityId?: Community['id'], limit?: number, offset?: number): Promise<PaginatedResponseDto<ChatConversationResponseDto>>;
16
+ createConversation(dto: CreateConversationDto): Promise<ChatConversationResponseDto>;
13
17
  deleteConversation(): void;
14
18
  getMessage(messageId: string): ChatMessageResponseDto;
15
- listMessages(conversationId: string): Promise<PaginatedResponseDto<ChatMessageResponseDto>>;
19
+ listMessages(conversationId: string, limit: number | undefined, cursor: any): Promise<PaginatedResponseDto<ChatMessageResponseDto>>;
16
20
  sendMessage(dto: CreateMessageDto): Promise<ChatMessageResponseDto>;
17
- deleteMessage(): void;
21
+ remove(id: string, req: any): Promise<void>;
22
+ addReaction(dto: AddChatMessageReactionDto): Promise<boolean>;
23
+ deleteReaction(dto: AddChatMessageReactionDto): Promise<boolean>;
24
+ editMessage(dto: EditMessageDto): Promise<ChatMessageResponseDto>;
25
+ updateReadCursor(dto: UpdateChatReadCursorDto): Promise<void>;
26
+ getUnreadCount(): Promise<ChatUnreadCountDto>;
18
27
  }