@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
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.ChatMessageReaction = void 0;
13
+ const openapi = require("@nestjs/swagger");
14
+ const typeorm_1 = require("typeorm");
15
+ const user_entity_1 = require("../../user/entities/user.entity");
16
+ const message_entity_1 = require("./message.entity");
17
+ let ChatMessageReaction = class ChatMessageReaction {
18
+ messageId;
19
+ message;
20
+ userId;
21
+ user;
22
+ emoji;
23
+ createdAt;
24
+ static _OPENAPI_METADATA_FACTORY() {
25
+ return { messageId: { required: true, type: () => Number }, message: { required: true, type: () => require("./message.entity").ChatMessage }, userId: { required: true, type: () => Number }, user: { required: true, type: () => require("../../user/entities/user.entity").User }, emoji: { required: true, type: () => String }, createdAt: { required: true, type: () => Date } };
26
+ }
27
+ };
28
+ exports.ChatMessageReaction = ChatMessageReaction;
29
+ __decorate([
30
+ (0, typeorm_1.PrimaryColumn)(),
31
+ __metadata("design:type", Object)
32
+ ], ChatMessageReaction.prototype, "messageId", void 0);
33
+ __decorate([
34
+ (0, typeorm_1.ManyToOne)(() => message_entity_1.ChatMessage, (message) => message.reactions, {
35
+ cascade: true,
36
+ }),
37
+ (0, typeorm_1.JoinColumn)({ name: 'messageId' }),
38
+ __metadata("design:type", message_entity_1.ChatMessage)
39
+ ], ChatMessageReaction.prototype, "message", void 0);
40
+ __decorate([
41
+ (0, typeorm_1.PrimaryColumn)(),
42
+ __metadata("design:type", Object)
43
+ ], ChatMessageReaction.prototype, "userId", void 0);
44
+ __decorate([
45
+ (0, typeorm_1.ManyToOne)(() => user_entity_1.User, (user) => user.chats, {
46
+ cascade: true,
47
+ }),
48
+ (0, typeorm_1.JoinColumn)({ name: 'userId' }),
49
+ __metadata("design:type", user_entity_1.User)
50
+ ], ChatMessageReaction.prototype, "user", void 0);
51
+ __decorate([
52
+ (0, typeorm_1.Column)(),
53
+ __metadata("design:type", String)
54
+ ], ChatMessageReaction.prototype, "emoji", void 0);
55
+ __decorate([
56
+ (0, typeorm_1.CreateDateColumn)(),
57
+ __metadata("design:type", Date)
58
+ ], ChatMessageReaction.prototype, "createdAt", void 0);
59
+ exports.ChatMessageReaction = ChatMessageReaction = __decorate([
60
+ (0, typeorm_1.Entity)()
61
+ ], ChatMessageReaction);
62
+ //# sourceMappingURL=reaction.entity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reaction.entity.js","sourceRoot":"","sources":["../../../src/chat/entities/reaction.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAOiB;AACjB,iEAAmD;AAEnD,qDAA+C;AAGxC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAKrB,SAAS,CAAoB;IAStC,OAAO,CAAc;IAMZ,MAAM,CAAa;IAS5B,IAAI,CAAO;IAMX,KAAK,CAAS;IAGd,SAAS,CAAO;;;;CACjB,CAAA;AAvCY,kDAAmB;AAKrB;IADR,IAAA,uBAAa,GAAE;;sDACsB;AAStC;IAJC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,4BAAW,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE;QAC5D,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;8BACzB,4BAAW;oDAAC;AAMZ;IADR,IAAA,uBAAa,GAAE;;mDACY;AAS5B;IAJC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;QAC3C,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BACzB,kBAAI;iDAAC;AAMX;IADC,IAAA,gBAAM,GAAE;;kDACK;AAGd;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;sDAAC;8BAtCL,mBAAmB;IAD/B,IAAA,gBAAM,GAAE;GACI,mBAAmB,CAuC/B"}
@@ -0,0 +1,10 @@
1
+ import { ChatConversation } from './conversation.entity';
2
+ import { User } from '~/user/entities/user.entity';
3
+ export declare class ChatReadCursor {
4
+ readonly conversationId: ChatConversation['id'];
5
+ conversation: ChatConversation;
6
+ readonly userId: User['id'];
7
+ user: User;
8
+ ts: Date;
9
+ updatedAt: Date;
10
+ }
@@ -0,0 +1,64 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.ChatReadCursor = void 0;
13
+ const openapi = require("@nestjs/swagger");
14
+ const typeorm_1 = require("typeorm");
15
+ const conversation_entity_1 = require("./conversation.entity");
16
+ const user_entity_1 = require("../../user/entities/user.entity");
17
+ let ChatReadCursor = class ChatReadCursor {
18
+ conversationId;
19
+ conversation;
20
+ userId;
21
+ user;
22
+ ts;
23
+ updatedAt;
24
+ static _OPENAPI_METADATA_FACTORY() {
25
+ return { conversationId: { required: true, type: () => Number }, conversation: { required: true, type: () => require("./conversation.entity").ChatConversation }, userId: { required: true, type: () => Number }, user: { required: true, type: () => require("../../user/entities/user.entity").User }, ts: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
26
+ }
27
+ };
28
+ exports.ChatReadCursor = ChatReadCursor;
29
+ __decorate([
30
+ (0, typeorm_1.PrimaryColumn)(),
31
+ __metadata("design:type", Object)
32
+ ], ChatReadCursor.prototype, "conversationId", void 0);
33
+ __decorate([
34
+ (0, typeorm_1.ManyToOne)(() => conversation_entity_1.ChatConversation, (conversation) => conversation.members, {
35
+ eager: true,
36
+ cascade: true,
37
+ }),
38
+ (0, typeorm_1.JoinColumn)({ name: 'conversationId' }),
39
+ __metadata("design:type", conversation_entity_1.ChatConversation)
40
+ ], ChatReadCursor.prototype, "conversation", void 0);
41
+ __decorate([
42
+ (0, typeorm_1.PrimaryColumn)(),
43
+ __metadata("design:type", Object)
44
+ ], ChatReadCursor.prototype, "userId", void 0);
45
+ __decorate([
46
+ (0, typeorm_1.ManyToOne)(() => user_entity_1.User, (user) => user.chats, {
47
+ eager: true,
48
+ cascade: true,
49
+ }),
50
+ (0, typeorm_1.JoinColumn)({ name: 'userId' }),
51
+ __metadata("design:type", user_entity_1.User)
52
+ ], ChatReadCursor.prototype, "user", void 0);
53
+ __decorate([
54
+ (0, typeorm_1.Column)(),
55
+ __metadata("design:type", Date)
56
+ ], ChatReadCursor.prototype, "ts", void 0);
57
+ __decorate([
58
+ (0, typeorm_1.UpdateDateColumn)(),
59
+ __metadata("design:type", Date)
60
+ ], ChatReadCursor.prototype, "updatedAt", void 0);
61
+ exports.ChatReadCursor = ChatReadCursor = __decorate([
62
+ (0, typeorm_1.Entity)()
63
+ ], ChatReadCursor);
64
+ //# sourceMappingURL=read-cursor.entity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"read-cursor.entity.js","sourceRoot":"","sources":["../../../src/chat/entities/read-cursor.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAQiB;AACjB,+DAAyD;AACzD,iEAAmD;AAG5C,IAAM,cAAc,GAApB,MAAM,cAAc;IAKhB,cAAc,CAAyB;IAUhD,YAAY,CAAmB;IAMtB,MAAM,CAAa;IAU5B,IAAI,CAAO;IAGX,EAAE,CAAO;IAGT,SAAS,CAAO;;;;CACjB,CAAA;AAtCY,wCAAc;AAKhB;IADR,IAAA,uBAAa,GAAE;;sDACgC;AAUhD;IALC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,sCAAgB,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE;QACzE,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,CAAC;8BACzB,sCAAgB;oDAAC;AAMtB;IADR,IAAA,uBAAa,GAAE;;8CACY;AAU5B;IALC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE;QAC3C,KAAK,EAAE,IAAI;QACX,OAAO,EAAE,IAAI;KACd,CAAC;IACD,IAAA,oBAAU,EAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;8BACzB,kBAAI;4CAAC;AAGX;IADC,IAAA,gBAAM,GAAE;8BACL,IAAI;0CAAC;AAGT;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;iDAAC;yBArCL,cAAc;IAD1B,IAAA,gBAAM,GAAE;GACI,cAAc,CAsC1B"}
@@ -1,3 +1,4 @@
1
1
  export declare enum ConversationType {
2
- OneOnOne = "ONE_ON_ONE"
2
+ OneOnOne = "ONE_ON_ONE",
3
+ Community = "COMMUNITY"
3
4
  }
@@ -4,5 +4,6 @@ exports.ConversationType = void 0;
4
4
  var ConversationType;
5
5
  (function (ConversationType) {
6
6
  ConversationType["OneOnOne"] = "ONE_ON_ONE";
7
+ ConversationType["Community"] = "COMMUNITY";
7
8
  })(ConversationType || (exports.ConversationType = ConversationType = {}));
8
9
  //# sourceMappingURL=conversation-type.enum.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"conversation-type.enum.js","sourceRoot":"","sources":["../../../src/chat/enums/conversation-type.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,gBAKX;AALD,WAAY,gBAAgB;IAI1B,2CAAuB,CAAA;AACzB,CAAC,EALW,gBAAgB,gCAAhB,gBAAgB,QAK3B"}
1
+ {"version":3,"file":"conversation-type.enum.js","sourceRoot":"","sources":["../../../src/chat/enums/conversation-type.enum.ts"],"names":[],"mappings":";;;AAAA,IAAY,gBAMX;AAND,WAAY,gBAAgB;IAI1B,2CAAuB,CAAA;IACvB,2CAAuB,CAAA;AACzB,CAAC,EANW,gBAAgB,gCAAhB,gBAAgB,QAM3B"}
@@ -1,2 +1,2 @@
1
1
  import { Type } from '@nestjs/common';
2
- export declare const ApiPaginatedResponse: <TDto extends Type<any>>(dto: TDto) => <TFunction extends Function, Y>(target: TFunction | object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
2
+ export declare const ApiPaginatedResponse: <TDto extends Type<unknown>>(dto: TDto) => <TFunction extends Function, Y>(target: TFunction | object, propertyKey?: string | symbol, descriptor?: TypedPropertyDescriptor<Y>) => void;
@@ -5,11 +5,11 @@ const common_1 = require("@nestjs/common");
5
5
  const swagger_1 = require("@nestjs/swagger");
6
6
  const paginated_response_dto_1 = require("../dto/paginated-response.dto");
7
7
  const ApiPaginatedResponse = (dto) => {
8
- return (0, common_1.applyDecorators)((0, swagger_1.ApiExtraModels)(paginated_response_dto_1.PaginatedResponseDto), (0, swagger_1.ApiOkResponse)({
8
+ return (0, common_1.applyDecorators)((0, swagger_1.ApiExtraModels)(paginated_response_dto_1.PaginatedResponseDto, dto), (0, swagger_1.ApiOkResponse)({
9
9
  description: 'Successfully received paginated list of ' + dto.name,
10
10
  schema: {
11
11
  allOf: [
12
- { $ref: (0, swagger_1.getSchemaPath)((paginated_response_dto_1.PaginatedResponseDto)) },
12
+ { $ref: (0, swagger_1.getSchemaPath)(paginated_response_dto_1.PaginatedResponseDto) },
13
13
  {
14
14
  properties: {
15
15
  result: {
@@ -1 +1 @@
1
- {"version":3,"file":"api-paginated-response.js","sourceRoot":"","sources":["../../../src/common/decorators/api-paginated-response.ts"],"names":[],"mappings":";;;AAAA,2CAAuD;AACvD,6CAA+E;AAC/E,0EAAqE;AAE9D,MAAM,oBAAoB,GAAG,CAAyB,GAAS,EAAE,EAAE;IACxE,OAAO,IAAA,wBAAe,EACpB,IAAA,wBAAc,EAAC,6CAAoB,CAAC,EACpC,IAAA,uBAAa,EAAC;QACZ,WAAW,EAAE,0CAA0C,GAAG,GAAG,CAAC,IAAI;QAClE,MAAM,EAAE;YACN,KAAK,EAAE;gBACL,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,CAAA,6CAA0B,CAAA,CAAC,EAAE;gBACnD;oBACE,UAAU,EAAE;wBACV,MAAM,EAAE;4BACN,IAAI,EAAE,OAAO;4BACb,KAAK,EAAE,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,GAAG,CAAC,EAAE;yBACpC;qBACF;iBACF;aACF;SACF;KACF,CAAC,CACH,CAAC;AACJ,CAAC,CAAC;AApBW,QAAA,oBAAoB,wBAoB/B"}
1
+ {"version":3,"file":"api-paginated-response.js","sourceRoot":"","sources":["../../../src/common/decorators/api-paginated-response.ts"],"names":[],"mappings":";;;AAAA,2CAAuD;AACvD,6CAA+E;AAC/E,0EAAqE;AAE9D,MAAM,oBAAoB,GAAG,CAA6B,GAAS,EAAE,EAAE;IAC5E,OAAO,IAAA,wBAAe,EACpB,IAAA,wBAAc,EAAC,6CAAoB,EAAE,GAAG,CAAC,EACzC,IAAA,uBAAa,EAAC;QACZ,WAAW,EAAE,0CAA0C,GAAG,GAAG,CAAC,IAAI;QAClE,MAAM,EAAE;YACN,KAAK,EAAE;gBACL,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,6CAAoB,CAAC,EAAE;gBAC7C;oBACE,UAAU,EAAE;wBACV,MAAM,EAAE;4BACN,IAAI,EAAE,OAAO;4BACb,KAAK,EAAE,EAAE,IAAI,EAAE,IAAA,uBAAa,EAAC,GAAG,CAAC,EAAE;yBACpC;qBACF;iBACF;aACF;SACF;KACF,CAAC,CACH,CAAC;AACJ,CAAC,CAAC;AApBW,QAAA,oBAAoB,wBAoB/B"}
@@ -1,4 +1,6 @@
1
1
  export declare class PaginatedResponseDto<T> {
2
2
  result: T[];
3
3
  count: number;
4
+ next?: string;
5
+ previous?: string;
4
6
  }
@@ -16,19 +16,30 @@ const class_transformer_1 = require("class-transformer");
16
16
  class PaginatedResponseDto {
17
17
  result;
18
18
  count;
19
+ next;
20
+ previous;
19
21
  static _OPENAPI_METADATA_FACTORY() {
20
- return { result: { required: true }, count: { required: true, type: () => Number } };
22
+ return { result: { required: true }, count: { required: true, type: () => Number }, next: { required: false, type: () => String }, previous: { required: false, type: () => String } };
21
23
  }
22
24
  }
23
25
  exports.PaginatedResponseDto = PaginatedResponseDto;
24
26
  __decorate([
25
- (0, swagger_1.ApiProperty)({ description: 'The results', isArray: true }),
27
+ (0, swagger_1.ApiProperty)({ description: 'Results', isArray: true }),
26
28
  (0, class_transformer_1.Expose)(),
27
29
  __metadata("design:type", Array)
28
30
  ], PaginatedResponseDto.prototype, "result", void 0);
29
31
  __decorate([
30
- (0, swagger_1.ApiProperty)({ description: 'The total number available' }),
32
+ (0, swagger_1.ApiProperty)({ description: 'Total number available' }),
31
33
  (0, class_transformer_1.Expose)(),
32
34
  __metadata("design:type", Number)
33
35
  ], PaginatedResponseDto.prototype, "count", void 0);
36
+ __decorate([
37
+ (0, swagger_1.ApiProperty)({ description: 'Cursor to use for the next page' }),
38
+ (0, class_transformer_1.Expose)(),
39
+ __metadata("design:type", String)
40
+ ], PaginatedResponseDto.prototype, "next", void 0);
41
+ __decorate([
42
+ (0, swagger_1.ApiProperty)({ description: 'Cursor to use for the previous page' }),
43
+ __metadata("design:type", String)
44
+ ], PaginatedResponseDto.prototype, "previous", void 0);
34
45
  //# sourceMappingURL=paginated-response.dto.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"paginated-response.dto.js","sourceRoot":"","sources":["../../../src/common/dto/paginated-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAiD;AAEjD,MAAa,oBAAoB;IAG/B,MAAM,CAAM;IAIZ,KAAK,CAAS;;;;CACf;AARD,oDAQC;AALC;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,aAAa,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC1D,IAAA,0BAAM,GAAE;;oDACG;AAIZ;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,4BAA4B,EAAE,CAAC;IAC1D,IAAA,0BAAM,GAAE;;mDACK"}
1
+ {"version":3,"file":"paginated-response.dto.js","sourceRoot":"","sources":["../../../src/common/dto/paginated-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,6CAA8C;AAC9C,yDAAiD;AAEjD,MAAa,oBAAoB;IAG/B,MAAM,CAAM;IAIZ,KAAK,CAAS;IAId,IAAI,CAAU;IAGd,QAAQ,CAAU;;;;CACnB;AAfD,oDAeC;AAZC;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACtD,IAAA,0BAAM,GAAE;;oDACG;AAIZ;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,wBAAwB,EAAE,CAAC;IACtD,IAAA,0BAAM,GAAE;;mDACK;AAId;IAFC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,iCAAiC,EAAE,CAAC;IAC/D,IAAA,0BAAM,GAAE;;kDACK;AAGd;IADC,IAAA,qBAAW,EAAC,EAAE,WAAW,EAAE,qCAAqC,EAAE,CAAC;;sDAClD"}
@@ -1,2 +1,4 @@
1
+ export declare const SCHEME = "scheme";
1
2
  export declare const HOST = "host";
3
+ export declare const BASE_URL = "baseUrl";
2
4
  export declare const NETWORK = "network";
@@ -1,6 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.NETWORK = exports.HOST = void 0;
3
+ exports.NETWORK = exports.BASE_URL = exports.HOST = exports.SCHEME = void 0;
4
+ exports.SCHEME = 'scheme';
4
5
  exports.HOST = 'host';
6
+ exports.BASE_URL = 'baseUrl';
5
7
  exports.NETWORK = 'network';
6
8
  //# sourceMappingURL=injection-tokens.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"injection-tokens.js","sourceRoot":"","sources":["../../src/common/injection-tokens.ts"],"names":[],"mappings":";;;AAAa,QAAA,IAAI,GAAG,MAAM,CAAC;AACd,QAAA,OAAO,GAAG,SAAS,CAAC"}
1
+ {"version":3,"file":"injection-tokens.js","sourceRoot":"","sources":["../../src/common/injection-tokens.ts"],"names":[],"mappings":";;;AAAa,QAAA,MAAM,GAAG,QAAQ,CAAC;AAClB,QAAA,IAAI,GAAG,MAAM,CAAC;AACd,QAAA,QAAQ,GAAG,SAAS,CAAC;AACrB,QAAA,OAAO,GAAG,SAAS,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const createCursor: (field: string, op: "gt" | "lt", value: string | number) => string;
2
+ export declare const decodeCursor: (cursor: string) => [string, "gt" | "lt", string | number];
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.decodeCursor = exports.createCursor = void 0;
4
+ const createCursor = (field, op, value) => {
5
+ return Buffer.from(JSON.stringify([field, op, value]), 'utf8').toString('base64');
6
+ };
7
+ exports.createCursor = createCursor;
8
+ const decodeCursor = (cursor) => {
9
+ return JSON.parse(Buffer.from(cursor, 'base64').toString());
10
+ };
11
+ exports.decodeCursor = decodeCursor;
12
+ //# sourceMappingURL=cursor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cursor.js","sourceRoot":"","sources":["../../../src/common/utils/cursor.ts"],"names":[],"mappings":";;;AAGO,MAAM,YAAY,GAAG,CAC1B,KAAa,EACb,EAAe,EACf,KAAsB,EACd,EAAE;IACV,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,QAAQ,CACrE,QAAQ,CACT,CAAC;AACJ,CAAC,CAAC;AARW,QAAA,YAAY,gBAQvB;AAMK,MAAM,YAAY,GAAG,CAC1B,MAAc,EAC0B,EAAE;IAC1C,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;AAC9D,CAAC,CAAC;AAJW,QAAA,YAAY,gBAIvB"}
@@ -0,0 +1,11 @@
1
+ import { StreamableFile } from '@nestjs/common';
2
+ import { User } from '~/user/entities/user.entity';
3
+ import { CommunityResponseDto } from '../dto/community-response.dto';
4
+ import { CommunityAvatarService } from './avatar.service';
5
+ import { CommunityIdDto } from '../dto';
6
+ export declare class CommunityAvatarController {
7
+ private service;
8
+ constructor(service: CommunityAvatarService);
9
+ uploadAvatar(dto: CommunityIdDto, file: Express.Multer.File): Promise<CommunityResponseDto>;
10
+ downloadAvatar(userId: User['id'], filename: any): Promise<StreamableFile>;
11
+ }
@@ -0,0 +1,90 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.CommunityAvatarController = void 0;
16
+ const openapi = require("@nestjs/swagger");
17
+ const common_1 = require("@nestjs/common");
18
+ const platform_express_1 = require("@nestjs/platform-express");
19
+ const swagger_1 = require("@nestjs/swagger");
20
+ const auth_guard_1 = require("../../auth/auth.guard");
21
+ const class_transformer_1 = require("class-transformer");
22
+ const community_response_dto_1 = require("../dto/community-response.dto");
23
+ const avatar_service_1 = require("./avatar.service");
24
+ const dto_1 = require("../dto");
25
+ let CommunityAvatarController = class CommunityAvatarController {
26
+ service;
27
+ constructor(service) {
28
+ this.service = service;
29
+ }
30
+ async uploadAvatar(dto, file) {
31
+ const community = await this.service.uploadAvatar(+dto.community, file);
32
+ return (0, class_transformer_1.plainToInstance)(community_response_dto_1.CommunityResponseDto, community);
33
+ }
34
+ async downloadAvatar(userId, filename) {
35
+ const stream = await this.service.downloadAvatar(userId, filename);
36
+ const { Readable } = await import('stream');
37
+ const nodeStream = Readable.fromWeb(stream);
38
+ return new common_1.StreamableFile(nodeStream, {
39
+ type: 'image/jpeg',
40
+ });
41
+ }
42
+ };
43
+ exports.CommunityAvatarController = CommunityAvatarController;
44
+ __decorate([
45
+ (0, swagger_1.ApiOperation)({
46
+ summary: 'Upload an avatar to your profile',
47
+ description: 'This Community API method uploads and stores and image to be used as a profile avatar.',
48
+ }),
49
+ (0, common_1.UseGuards)(auth_guard_1.AuthGuard),
50
+ (0, swagger_1.ApiConsumes)('multipart/form-data'),
51
+ (0, swagger_1.ApiBody)({
52
+ schema: {
53
+ type: 'object',
54
+ properties: {
55
+ file: {
56
+ type: 'string',
57
+ format: 'binary',
58
+ },
59
+ },
60
+ },
61
+ }),
62
+ (0, common_1.UseInterceptors)((0, platform_express_1.FileInterceptor)('file')),
63
+ (0, common_1.Post)('community.uploadAvatar'),
64
+ openapi.ApiResponse({ status: 201, type: require("../dto/community-response.dto").CommunityResponseDto }),
65
+ __param(0, (0, common_1.Body)()),
66
+ __param(1, (0, common_1.UploadedFile)()),
67
+ __metadata("design:type", Function),
68
+ __metadata("design:paramtypes", [dto_1.CommunityIdDto, Object]),
69
+ __metadata("design:returntype", Promise)
70
+ ], CommunityAvatarController.prototype, "uploadAvatar", null);
71
+ __decorate([
72
+ (0, swagger_1.ApiTags)('Assets'),
73
+ (0, swagger_1.ApiOperation)({
74
+ summary: 'Download an avatar for a community',
75
+ description: 'This Community API method displays an avatar. If one if not available, a default avatar is generated.',
76
+ }),
77
+ (0, common_1.Get)('assets/community/avatars/:communityId/:timestamp/:filename'),
78
+ openapi.ApiResponse({ status: 200 }),
79
+ __param(0, (0, common_1.Param)('communityId')),
80
+ __param(1, (0, common_1.Param)('filename')),
81
+ __metadata("design:type", Function),
82
+ __metadata("design:paramtypes", [Object, Object]),
83
+ __metadata("design:returntype", Promise)
84
+ ], CommunityAvatarController.prototype, "downloadAvatar", null);
85
+ exports.CommunityAvatarController = CommunityAvatarController = __decorate([
86
+ (0, swagger_1.ApiTags)('Community'),
87
+ (0, common_1.Controller)(),
88
+ __metadata("design:paramtypes", [avatar_service_1.CommunityAvatarService])
89
+ ], CommunityAvatarController);
90
+ //# sourceMappingURL=avatar.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"avatar.controller.js","sourceRoot":"","sources":["../../../src/community/avatar/avatar.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAWwB;AACxB,+DAA2D;AAC3D,6CAA8E;AAC9E,sDAA8C;AAG9C,yDAAoD;AACpD,0EAAqE;AACrE,qDAA0D;AAC1D,gCAAwC;AAIjC,IAAM,yBAAyB,GAA/B,MAAM,yBAAyB;IAChB;IAApB,YAAoB,OAA+B;QAA/B,YAAO,GAAP,OAAO,CAAwB;IAAG,CAAC;IAsBjD,AAAN,KAAK,CAAC,YAAY,CACR,GAAmB,EACX,IAAyB;QAEzC,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QACxE,OAAO,IAAA,mCAAe,EAAC,6CAAoB,EAAE,SAAS,CAAC,CAAC;IAC1D,CAAC;IASK,AAAN,KAAK,CAAC,cAAc,CACI,MAAkB,EACrB,QAAQ;QAE3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QAEnE,MAAM,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,MAAa,CAAC,CAAC;QAEnD,OAAO,IAAI,uBAAc,CAAC,UAAU,EAAE;YACpC,IAAI,EAAE,YAAY;SACnB,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AAnDY,8DAAyB;AAuB9B;IApBL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,kCAAkC;QAC3C,WAAW,EACT,wFAAwF;KAC3F,CAAC;IACD,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,qBAAW,EAAC,qBAAqB,CAAC;IAClC,IAAA,iBAAO,EAAC;QACP,MAAM,EAAE;YACN,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAQ;oBACd,MAAM,EAAE,QAAQ;iBACjB;aACF;SACF;KACF,CAAC;IACD,IAAA,wBAAe,EAAC,IAAA,kCAAe,EAAC,MAAM,CAAC,CAAC;IACxC,IAAA,aAAI,EAAC,wBAAwB,CAAC;;IAE5B,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,qBAAY,GAAE,CAAA;;qCADF,oBAAc;;6DAK5B;AASK;IAPL,IAAA,iBAAO,EAAC,QAAQ,CAAC;IACjB,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,oCAAoC;QAC7C,WAAW,EACT,uGAAuG;KAC1G,CAAC;IACD,IAAA,YAAG,EAAC,4DAA4D,CAAC;;IAE/D,WAAA,IAAA,cAAK,EAAC,aAAa,CAAC,CAAA;IACpB,WAAA,IAAA,cAAK,EAAC,UAAU,CAAC,CAAA;;;;+DAUnB;oCAlDU,yBAAyB;IAFrC,IAAA,iBAAO,EAAC,WAAW,CAAC;IACpB,IAAA,mBAAU,GAAE;qCAEkB,uCAAsB;GADxC,yBAAyB,CAmDrC"}
@@ -0,0 +1,13 @@
1
+ import { NotFoundException } from '@nestjs/common';
2
+ import { FileStorageService } from '~/file-storage/file-storage.service';
3
+ import { CommunityService } from '../community.service';
4
+ import { Community } from '../entities/community.entity';
5
+ import { AclFactory } from '~/core/acl/acl.factory';
6
+ export declare class CommunityAvatarService {
7
+ private fileStorage;
8
+ private communityService;
9
+ private aclFactory;
10
+ constructor(fileStorage: FileStorageService, communityService: CommunityService, aclFactory: AclFactory);
11
+ uploadAvatar(id: Community['id'], file: Express.Multer.File): Promise<boolean>;
12
+ downloadAvatar(id: Community['id'], filename: string): Promise<ReadableStream<any> | NotFoundException | undefined>;
13
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.CommunityAvatarService = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const context_1 = require("../../core/context/context");
18
+ const file_storage_service_1 = require("../../file-storage/file-storage.service");
19
+ const utils_1 = require("../../file-storage/utils");
20
+ const sharp_1 = __importDefault(require("sharp"));
21
+ const client_s3_1 = require("@aws-sdk/client-s3");
22
+ const community_service_1 = require("../community.service");
23
+ const acl_factory_1 = require("../../core/acl/acl.factory");
24
+ const avatar_service_1 = require("../../user/avatar/avatar.service");
25
+ let CommunityAvatarService = class CommunityAvatarService {
26
+ fileStorage;
27
+ communityService;
28
+ aclFactory;
29
+ constructor(fileStorage, communityService, aclFactory) {
30
+ this.fileStorage = fileStorage;
31
+ this.communityService = communityService;
32
+ this.aclFactory = aclFactory;
33
+ }
34
+ async uploadAvatar(id, file) {
35
+ const community = await this.communityService.findOne(id);
36
+ if (!community ||
37
+ !this.aclFactory.withUser(context_1.Context.getUser()).can(acl_factory_1.Action.Update, community)) {
38
+ throw new common_1.ForbiddenException();
39
+ }
40
+ console.log(this.aclFactory
41
+ .withUser(context_1.Context.getUser())
42
+ .relevantRuleFor('foofoo', community));
43
+ const dir = (0, utils_1.getCommunityDir)(community) + 'avatar';
44
+ await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().toBuffer(), dir + `/master.jpeg`, 'image/jpeg');
45
+ for (const size of avatar_service_1.AVATAR_SIZES) {
46
+ await this.fileStorage.putFile(await (0, sharp_1.default)(file.buffer).jpeg().resize(size).toBuffer(), dir + `/${size}.jpeg`, 'image/jpeg');
47
+ }
48
+ return true;
49
+ }
50
+ async downloadAvatar(id, filename) {
51
+ const community = await this.communityService.findOne(id);
52
+ if (!community) {
53
+ return new common_1.NotFoundException();
54
+ }
55
+ const dir = (0, utils_1.getCommunityDir)(community) + 'avatar';
56
+ try {
57
+ console.log(`${dir}/${filename}`);
58
+ return await this.fileStorage.getFile(`${dir}/${filename}`);
59
+ }
60
+ catch (err) {
61
+ console.log(err);
62
+ if (err instanceof client_s3_1.NoSuchKey) {
63
+ throw new common_1.NotFoundException();
64
+ }
65
+ else {
66
+ throw err;
67
+ }
68
+ }
69
+ }
70
+ };
71
+ exports.CommunityAvatarService = CommunityAvatarService;
72
+ exports.CommunityAvatarService = CommunityAvatarService = __decorate([
73
+ (0, common_1.Injectable)(),
74
+ __metadata("design:paramtypes", [file_storage_service_1.FileStorageService,
75
+ community_service_1.CommunityService,
76
+ acl_factory_1.AclFactory])
77
+ ], CommunityAvatarService);
78
+ //# sourceMappingURL=avatar.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"avatar.service.js","sourceRoot":"","sources":["../../../src/community/avatar/avatar.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAIwB;AACxB,wDAAiD;AACjD,kFAAyE;AACzE,oDAAuD;AACvD,kDAA0B;AAC1B,kDAA+C;AAC/C,4DAAwD;AAExD,4DAA4D;AAC5D,qEAA4D;AAGrD,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAEvB;IACA;IACA;IAHV,YACU,WAA+B,EAC/B,gBAAkC,EAClC,UAAsB;QAFtB,gBAAW,GAAX,WAAW,CAAoB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,eAAU,GAAV,UAAU,CAAY;IAC7B,CAAC;IAKJ,KAAK,CAAC,YAAY,CAChB,EAAmB,EACnB,IAAyB;QAEzB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAE1D,IACE,CAAC,SAAS;YACV,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,iBAAO,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,oBAAM,CAAC,MAAM,EAAE,SAAS,CAAC,EAC1E,CAAC;YACD,MAAM,IAAI,2BAAkB,EAAE,CAAC;QACjC,CAAC;QACD,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,UAAU;aACZ,QAAQ,CAAC,iBAAO,CAAC,OAAO,EAAE,CAAC;aAC3B,eAAe,CAAC,QAAQ,EAAE,SAAS,CAAC,CACxC,CAAC;QAEF,MAAM,GAAG,GAAG,IAAA,uBAAe,EAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;QAGlD,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAC5B,MAAM,IAAA,eAAK,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,QAAQ,EAAE,EAC1C,GAAG,GAAG,cAAc,EACpB,YAAY,CACb,CAAC;QAEF,KAAK,MAAM,IAAI,IAAI,6BAAY,EAAE,CAAC;YAChC,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAC5B,MAAM,IAAA,eAAK,EAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EACvD,GAAG,GAAG,IAAI,IAAI,OAAO,EACrB,YAAY,CACb,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAKD,KAAK,CAAC,cAAc,CAAC,EAAmB,EAAE,QAAgB;QACxD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAE1D,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,IAAI,0BAAiB,EAAE,CAAC;QACjC,CAAC;QAED,MAAM,GAAG,GAAG,IAAA,uBAAe,EAAC,SAAS,CAAC,GAAG,QAAQ,CAAC;QAClD,IAAI,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,GAAG,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC;YAClC,OAAO,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YACjB,IAAI,GAAG,YAAY,qBAAS,EAAE,CAAC;gBAC7B,MAAM,IAAI,0BAAiB,EAAE,CAAC;YAChC,CAAC;iBAAM,CAAC;gBACN,MAAM,GAAG,CAAC;YACZ,CAAC;QACH,CAAC;IACH,CAAC;CACF,CAAA;AAvEY,wDAAsB;iCAAtB,sBAAsB;IADlC,IAAA,mBAAU,GAAE;qCAGY,yCAAkB;QACb,oCAAgB;QACtB,wBAAU;GAJrB,sBAAsB,CAuElC"}
@@ -1,3 +1,6 @@
1
- import { RuleCallback } from '~/core/acl/acl.factory';
2
- declare const CommunityAclRules: RuleCallback[];
3
- export default CommunityAclRules;
1
+ import { CommunityService } from './community.service';
2
+ export declare class CommunityAclService {
3
+ private communityService;
4
+ constructor(communityService: CommunityService);
5
+ }
6
+ export default CommunityAclService;
@@ -1,49 +1,72 @@
1
1
  "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
2
11
  var __importDefault = (this && this.__importDefault) || function (mod) {
3
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
13
  };
5
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.CommunityAclService = void 0;
6
16
  const acl_factory_1 = require("../core/acl/acl.factory");
7
17
  const community_entity_1 = require("./entities/community.entity");
8
18
  const community_status_enum_1 = __importDefault(require("./enums/community-status.enum"));
9
19
  const community_member_entity_1 = require("./entities/community-member.entity");
10
20
  const community_role_enum_1 = __importDefault(require("./enums/community-role.enum"));
11
- const getMembershipForCommunity = (user, community) => {
12
- for (let membership of user.communities) {
13
- if (membership.community.id === community.id) {
14
- return membership;
21
+ const community_service_1 = require("./community.service");
22
+ const common_1 = require("@nestjs/common");
23
+ let CommunityAclService = class CommunityAclService {
24
+ communityService;
25
+ constructor(communityService) {
26
+ this.communityService = communityService;
27
+ const CommunityAclRules = [
28
+ ({ can, user }) => can(acl_factory_1.Action.Read, community_entity_1.Community, (community) => {
29
+ if (!user) {
30
+ return false;
31
+ }
32
+ const membership = this.communityService.getMembership(user, community);
33
+ if (membership?.status === community_status_enum_1.default.Active) {
34
+ return true;
35
+ }
36
+ return false;
37
+ }),
38
+ ({ can, user }) => can(acl_factory_1.Action.Update, community_entity_1.Community, (community) => {
39
+ console.log('Action.Update', community);
40
+ return false;
41
+ }),
42
+ ({ can, user }) => can(acl_factory_1.Action.Manage, community_entity_1.Community, (community) => {
43
+ if (!user) {
44
+ return false;
45
+ }
46
+ const membership = this.communityService.getMembership(user, community);
47
+ return (membership?.status === community_status_enum_1.default.Active &&
48
+ (membership.role === community_role_enum_1.default.Admin ||
49
+ membership.role === community_role_enum_1.default.Owner));
50
+ }),
51
+ ({ can, user }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
52
+ return membership.user.id === user?.id;
53
+ }),
54
+ ({ can, getAbility }) => can(acl_factory_1.Action.Manage, community_member_entity_1.CommunityMember, (membership) => {
55
+ return getAbility().can(acl_factory_1.Action.Manage, membership.community);
56
+ }),
57
+ ({ can, getAbility }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
58
+ return getAbility().can(acl_factory_1.Action.Manage, membership.community);
59
+ }),
60
+ ];
61
+ for (let rule of CommunityAclRules) {
62
+ acl_factory_1.AclFactory.addRule(rule.bind(this));
15
63
  }
16
64
  }
17
65
  };
18
- const CommunityAclRules = [
19
- ({ can, user }) => can(acl_factory_1.Action.Read, community_entity_1.Community, (community) => {
20
- if (!user) {
21
- return false;
22
- }
23
- const membership = getMembershipForCommunity(user, community);
24
- if (membership?.status === community_status_enum_1.default.Active) {
25
- return true;
26
- }
27
- return false;
28
- }),
29
- ({ can, user }) => can(acl_factory_1.Action.Manage, community_entity_1.Community, (community) => {
30
- if (!user) {
31
- return false;
32
- }
33
- const membership = getMembershipForCommunity(user, community);
34
- return (membership?.status === community_status_enum_1.default.Active &&
35
- (membership.role === community_role_enum_1.default.Admin ||
36
- membership.role === community_role_enum_1.default.Owner));
37
- }),
38
- ({ can, user }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
39
- return membership.user.id === user?.id;
40
- }),
41
- ({ can, getAbility }) => can(acl_factory_1.Action.Manage, community_member_entity_1.CommunityMember, (membership) => {
42
- return getAbility().can(acl_factory_1.Action.Manage, membership.community);
43
- }),
44
- ({ can, getAbility }) => can(acl_factory_1.Action.Delete, community_member_entity_1.CommunityMember, (membership) => {
45
- return getAbility().can(acl_factory_1.Action.Manage, membership.community);
46
- }),
47
- ];
48
- exports.default = CommunityAclRules;
66
+ exports.CommunityAclService = CommunityAclService;
67
+ exports.CommunityAclService = CommunityAclService = __decorate([
68
+ (0, common_1.Injectable)(),
69
+ __metadata("design:paramtypes", [community_service_1.CommunityService])
70
+ ], CommunityAclService);
71
+ exports.default = CommunityAclService;
49
72
  //# sourceMappingURL=community.acl.js.map