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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (345) hide show
  1. package/README.md +696 -40
  2. package/dist/__mocks__/kafka.mock.d.ts +11 -0
  3. package/dist/__mocks__/kafka.mock.js +15 -0
  4. package/dist/__mocks__/kafka.mock.js.map +1 -0
  5. package/dist/app.module.d.ts +4 -4
  6. package/dist/app.module.js +17 -7
  7. package/dist/app.module.js.map +1 -1
  8. package/dist/auth/auth.controller.d.ts +7 -1
  9. package/dist/auth/auth.controller.js +28 -3
  10. package/dist/auth/auth.controller.js.map +1 -1
  11. package/dist/auth/auth.middleware.d.ts +3 -5
  12. package/dist/auth/auth.middleware.js +7 -15
  13. package/dist/auth/auth.middleware.js.map +1 -1
  14. package/dist/auth/auth.module.js +4 -1
  15. package/dist/auth/auth.module.js.map +1 -1
  16. package/dist/auth/auth.service.d.ts +9 -1
  17. package/dist/auth/auth.service.js +34 -2
  18. package/dist/auth/auth.service.js.map +1 -1
  19. package/dist/auth/constants.js +2 -1
  20. package/dist/auth/constants.js.map +1 -1
  21. package/dist/auth/dto/login-success.dto.d.ts +1 -1
  22. package/dist/auth/dto/login-success.dto.js +6 -3
  23. package/dist/auth/dto/login-success.dto.js.map +1 -1
  24. package/dist/auth/dto/register-success.dto.d.ts +3 -0
  25. package/dist/auth/dto/register-success.dto.js +12 -0
  26. package/dist/auth/dto/register-success.dto.js.map +1 -0
  27. package/dist/auth/dto/register.dto.d.ts +6 -0
  28. package/dist/auth/dto/register.dto.js +45 -0
  29. package/dist/auth/dto/register.dto.js.map +1 -0
  30. package/dist/auth/oidc/dto/requests.d.ts +6 -0
  31. package/dist/auth/oidc/dto/requests.js +47 -0
  32. package/dist/auth/oidc/dto/requests.js.map +1 -0
  33. package/dist/auth/oidc/dto/responses.js +1 -1
  34. package/dist/auth/oidc/oidc.controller.d.ts +7 -2
  35. package/dist/auth/oidc/oidc.controller.js +31 -17
  36. package/dist/auth/oidc/oidc.controller.js.map +1 -1
  37. package/dist/auth/oidc/oidc.service.d.ts +9 -4
  38. package/dist/auth/oidc/oidc.service.js +64 -38
  39. package/dist/auth/oidc/oidc.service.js.map +1 -1
  40. package/dist/auth/session/session.controller.js +8 -3
  41. package/dist/auth/session/session.controller.js.map +1 -1
  42. package/dist/auth/session/session.service.d.ts +2 -2
  43. package/dist/auth/session/session.service.js +14 -7
  44. package/dist/auth/session/session.service.js.map +1 -1
  45. package/dist/bootstrap.d.ts +2 -1
  46. package/dist/bootstrap.js +7 -1
  47. package/dist/bootstrap.js.map +1 -1
  48. package/dist/chat/chat.acl.d.ts +3 -0
  49. package/dist/chat/chat.acl.js +50 -0
  50. package/dist/chat/chat.acl.js.map +1 -0
  51. package/dist/chat/chat.controller.d.ts +15 -6
  52. package/dist/chat/chat.controller.js +153 -14
  53. package/dist/chat/chat.controller.js.map +1 -1
  54. package/dist/chat/chat.module.d.ts +3 -0
  55. package/dist/chat/chat.module.js +30 -4
  56. package/dist/chat/chat.module.js.map +1 -1
  57. package/dist/chat/chat.service.d.ts +63 -12
  58. package/dist/chat/chat.service.js +468 -36
  59. package/dist/chat/chat.service.js.map +1 -1
  60. package/dist/chat/dto/add-reaction.dto.d.ts +5 -0
  61. package/dist/chat/dto/add-reaction.dto.js +42 -0
  62. package/dist/chat/dto/add-reaction.dto.js.map +1 -0
  63. package/dist/chat/dto/create-message.dto.d.ts +4 -1
  64. package/dist/chat/dto/create-message.dto.js +23 -1
  65. package/dist/chat/dto/create-message.dto.js.map +1 -1
  66. package/dist/chat/dto/edit-message.dto.d.ts +5 -0
  67. package/dist/chat/dto/edit-message.dto.js +31 -0
  68. package/dist/chat/dto/edit-message.dto.js.map +1 -0
  69. package/dist/chat/dto/responses.dto.d.ts +27 -5
  70. package/dist/chat/dto/responses.dto.js +177 -18
  71. package/dist/chat/dto/responses.dto.js.map +1 -1
  72. package/dist/chat/dto/update-cursor.dto.d.ts +5 -0
  73. package/dist/chat/dto/update-cursor.dto.js +36 -0
  74. package/dist/chat/dto/update-cursor.dto.js.map +1 -0
  75. package/dist/chat/entities/conversation-member.entity.js +1 -1
  76. package/dist/chat/entities/conversation-member.entity.js.map +1 -1
  77. package/dist/chat/entities/conversation.entity.d.ts +4 -0
  78. package/dist/chat/entities/conversation.entity.js +13 -1
  79. package/dist/chat/entities/conversation.entity.js.map +1 -1
  80. package/dist/chat/entities/message.entity.d.ts +8 -0
  81. package/dist/chat/entities/message.entity.js +32 -2
  82. package/dist/chat/entities/message.entity.js.map +1 -1
  83. package/dist/chat/entities/reaction.entity.d.ts +10 -0
  84. package/dist/chat/entities/reaction.entity.js +62 -0
  85. package/dist/chat/entities/reaction.entity.js.map +1 -0
  86. package/dist/chat/entities/read-cursor.entity.d.ts +10 -0
  87. package/dist/chat/entities/read-cursor.entity.js +64 -0
  88. package/dist/chat/entities/read-cursor.entity.js.map +1 -0
  89. package/dist/chat/enums/conversation-type.enum.d.ts +2 -1
  90. package/dist/chat/enums/conversation-type.enum.js +1 -0
  91. package/dist/chat/enums/conversation-type.enum.js.map +1 -1
  92. package/dist/common/decorators/api-paginated-response.d.ts +1 -1
  93. package/dist/common/decorators/api-paginated-response.js +2 -2
  94. package/dist/common/decorators/api-paginated-response.js.map +1 -1
  95. package/dist/common/dto/paginated-response.dto.d.ts +2 -0
  96. package/dist/common/dto/paginated-response.dto.js +14 -3
  97. package/dist/common/dto/paginated-response.dto.js.map +1 -1
  98. package/dist/common/injection-tokens.d.ts +2 -0
  99. package/dist/common/injection-tokens.js +3 -1
  100. package/dist/common/injection-tokens.js.map +1 -1
  101. package/dist/common/utils/cursor.d.ts +2 -0
  102. package/dist/common/utils/cursor.js +12 -0
  103. package/dist/common/utils/cursor.js.map +1 -0
  104. package/dist/community/avatar/avatar.controller.d.ts +11 -0
  105. package/dist/community/avatar/avatar.controller.js +90 -0
  106. package/dist/community/avatar/avatar.controller.js.map +1 -0
  107. package/dist/community/avatar/avatar.service.d.ts +13 -0
  108. package/dist/community/avatar/avatar.service.js +78 -0
  109. package/dist/community/avatar/avatar.service.js.map +1 -0
  110. package/dist/community/community.acl.d.ts +6 -3
  111. package/dist/community/community.acl.js +58 -35
  112. package/dist/community/community.acl.js.map +1 -1
  113. package/dist/community/community.controller.d.ts +8 -5
  114. package/dist/community/community.controller.js +102 -17
  115. package/dist/community/community.controller.js.map +1 -1
  116. package/dist/community/community.module.d.ts +3 -0
  117. package/dist/community/community.module.js +17 -7
  118. package/dist/community/community.module.js.map +1 -1
  119. package/dist/community/community.service.d.ts +26 -6
  120. package/dist/community/community.service.js +152 -23
  121. package/dist/community/community.service.js.map +1 -1
  122. package/dist/community/dto/community-response.dto.d.ts +5 -1
  123. package/dist/community/dto/community-response.dto.js +30 -1
  124. package/dist/community/dto/community-response.dto.js.map +1 -1
  125. package/dist/community/dto/create-community.dto.d.ts +2 -0
  126. package/dist/community/dto/create-community.dto.js +14 -2
  127. package/dist/community/dto/create-community.dto.js.map +1 -1
  128. package/dist/community/dto/update-community.dto.d.ts +2 -0
  129. package/dist/community/dto/update-community.dto.js +15 -1
  130. package/dist/community/dto/update-community.dto.js.map +1 -1
  131. package/dist/community/entities/community-member.entity.js +1 -0
  132. package/dist/community/entities/community-member.entity.js.map +1 -1
  133. package/dist/community/entities/community.entity.d.ts +2 -0
  134. package/dist/community/entities/community.entity.js +11 -1
  135. package/dist/community/entities/community.entity.js.map +1 -1
  136. package/dist/configs/configs.service.d.ts +12 -2
  137. package/dist/configs/configs.service.js.map +1 -1
  138. package/dist/core/context/context.d.ts +3 -0
  139. package/dist/core/context/context.js +15 -0
  140. package/dist/core/context/context.js.map +1 -1
  141. package/dist/core/context/context.store.d.ts +2 -0
  142. package/dist/core/core.module.js +2 -1
  143. package/dist/core/core.module.js.map +1 -1
  144. package/dist/core/event-stream/event-stream-processor.interface.d.ts +8 -0
  145. package/dist/core/event-stream/event-stream-processor.interface.js +3 -0
  146. package/dist/core/event-stream/event-stream-processor.interface.js.map +1 -0
  147. package/dist/core/event-stream/event-stream-processor.service.d.ts +13 -0
  148. package/dist/core/event-stream/event-stream-processor.service.js +60 -0
  149. package/dist/core/event-stream/event-stream-processor.service.js.map +1 -0
  150. package/dist/core/event-stream/event-stream.module.d.ts +11 -0
  151. package/dist/core/event-stream/event-stream.module.js +50 -0
  152. package/dist/core/event-stream/event-stream.module.js.map +1 -0
  153. package/dist/core/event-stream/event-stream.service.d.ts +18 -0
  154. package/dist/core/event-stream/event-stream.service.js +107 -0
  155. package/dist/core/event-stream/event-stream.service.js.map +1 -0
  156. package/dist/core/event-stream/types.d.ts +3 -0
  157. package/dist/core/event-stream/types.js +3 -0
  158. package/dist/core/event-stream/types.js.map +1 -0
  159. package/dist/core/hook/hook.module.d.ts +4 -0
  160. package/dist/core/hook/hook.module.js +30 -0
  161. package/dist/core/hook/hook.module.js.map +1 -0
  162. package/dist/core/hook/hook.service.d.ts +7 -0
  163. package/dist/core/{plugin/plugin-hook.service.js → hook/hook.service.js} +10 -10
  164. package/dist/core/hook/hook.service.js.map +1 -0
  165. package/dist/core/plugin/plugin.module.js +5 -6
  166. package/dist/core/plugin/plugin.module.js.map +1 -1
  167. package/dist/core/websocket/gateway.service.d.ts +24 -0
  168. package/dist/core/websocket/gateway.service.js +150 -0
  169. package/dist/core/websocket/gateway.service.js.map +1 -0
  170. package/dist/core/websocket/websocket.module.d.ts +2 -0
  171. package/dist/core/websocket/websocket.module.js +24 -0
  172. package/dist/core/websocket/websocket.module.js.map +1 -0
  173. package/dist/db.js +2 -1
  174. package/dist/db.js.map +1 -1
  175. package/dist/file-storage/file-storage.service.d.ts +1 -1
  176. package/dist/file-storage/file-storage.service.js +6 -6
  177. package/dist/file-storage/file-storage.service.js.map +1 -1
  178. package/dist/file-storage/utils.d.ts +2 -0
  179. package/dist/file-storage/utils.js +9 -2
  180. package/dist/file-storage/utils.js.map +1 -1
  181. package/dist/index.d.ts +0 -1
  182. package/dist/index.js +1 -3
  183. package/dist/index.js.map +1 -1
  184. package/dist/manage-db.d.ts +1 -0
  185. package/dist/manage-db.js +10 -0
  186. package/dist/manage-db.js.map +1 -0
  187. package/dist/media/dto/media-response.dto.d.ts +2 -0
  188. package/dist/media/dto/media-response.dto.js +15 -2
  189. package/dist/media/dto/media-response.dto.js.map +1 -1
  190. package/dist/media/entities/audio.entity.d.ts +2 -2
  191. package/dist/media/entities/audio.entity.js +2 -2
  192. package/dist/media/entities/audio.entity.js.map +1 -1
  193. package/dist/media/entities/image.entity.d.ts +5 -0
  194. package/dist/media/entities/{post-media.entity.js → image.entity.js} +16 -12
  195. package/dist/media/entities/image.entity.js.map +1 -0
  196. package/dist/media/entities/media.entity.d.ts +6 -0
  197. package/dist/media/entities/media.entity.js +25 -2
  198. package/dist/media/entities/media.entity.js.map +1 -1
  199. package/dist/media/media.acl.d.ts +2 -4
  200. package/dist/media/media.acl.js +22 -1
  201. package/dist/media/media.acl.js.map +1 -1
  202. package/dist/media/media.controller.d.ts +2 -0
  203. package/dist/media/media.controller.js +58 -0
  204. package/dist/media/media.controller.js.map +1 -1
  205. package/dist/media/media.module.js +2 -1
  206. package/dist/media/media.module.js.map +1 -1
  207. package/dist/media/media.service.d.ts +6 -3
  208. package/dist/media/media.service.js +118 -19
  209. package/dist/media/media.service.js.map +1 -1
  210. package/dist/migrations/1757061785934-PushNotificationTokens.d.ts +6 -0
  211. package/dist/migrations/1757061785934-PushNotificationTokens.js +20 -0
  212. package/dist/migrations/1757061785934-PushNotificationTokens.js.map +1 -0
  213. package/dist/migrations/1758623241397-AddUserTimestamps.d.ts +6 -0
  214. package/dist/migrations/1758623241397-AddUserTimestamps.js +16 -0
  215. package/dist/migrations/1758623241397-AddUserTimestamps.js.map +1 -0
  216. package/dist/migrations/1758704603161-UserFollows.d.ts +6 -0
  217. package/dist/migrations/1758704603161-UserFollows.js +18 -0
  218. package/dist/migrations/1758704603161-UserFollows.js.map +1 -0
  219. package/dist/migrations/1759757532702-UpdateCommunityCascades.d.ts +6 -0
  220. package/dist/migrations/1759757532702-UpdateCommunityCascades.js +20 -0
  221. package/dist/migrations/1759757532702-UpdateCommunityCascades.js.map +1 -0
  222. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.d.ts +6 -0
  223. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js +16 -0
  224. package/dist/migrations/1759766474808-UpdateCommunityTimestamps.js.map +1 -0
  225. package/dist/migrations/1759919335188-CommunityChats.d.ts +6 -0
  226. package/dist/migrations/1759919335188-CommunityChats.js +28 -0
  227. package/dist/migrations/1759919335188-CommunityChats.js.map +1 -0
  228. package/dist/migrations/1760363804673-ChatVoiceNotes.d.ts +6 -0
  229. package/dist/migrations/1760363804673-ChatVoiceNotes.js +24 -0
  230. package/dist/migrations/1760363804673-ChatVoiceNotes.js.map +1 -0
  231. package/dist/migrations/1760444646328-ChatReadCursor.d.ts +6 -0
  232. package/dist/migrations/1760444646328-ChatReadCursor.js +18 -0
  233. package/dist/migrations/1760444646328-ChatReadCursor.js.map +1 -0
  234. package/dist/migrations/1761598291629-AddChatImages.d.ts +6 -0
  235. package/dist/migrations/1761598291629-AddChatImages.js +16 -0
  236. package/dist/migrations/1761598291629-AddChatImages.js.map +1 -0
  237. package/dist/migrations/1761648419807-ChatReactions.d.ts +6 -0
  238. package/dist/migrations/1761648419807-ChatReactions.js +18 -0
  239. package/dist/migrations/1761648419807-ChatReactions.js.map +1 -0
  240. package/dist/migrations/1762953835109-AddChatReplies.d.ts +6 -0
  241. package/dist/migrations/1762953835109-AddChatReplies.js +22 -0
  242. package/dist/migrations/1762953835109-AddChatReplies.js.map +1 -0
  243. package/dist/network/entities/network.entity.js +1 -3
  244. package/dist/network/entities/network.entity.js.map +1 -1
  245. package/dist/network/network.middleware.d.ts +3 -1
  246. package/dist/network/network.middleware.js +12 -4
  247. package/dist/network/network.middleware.js.map +1 -1
  248. package/dist/network/network.module.js +2 -1
  249. package/dist/network/network.module.js.map +1 -1
  250. package/dist/network/network.service.d.ts +4 -2
  251. package/dist/network/network.service.js +16 -6
  252. package/dist/network/network.service.js.map +1 -1
  253. package/dist/notification/dto/delete-push-token.dto.d.ts +3 -0
  254. package/dist/notification/dto/delete-push-token.dto.js +26 -0
  255. package/dist/notification/dto/delete-push-token.dto.js.map +1 -0
  256. package/dist/notification/dto/register-push-token.dto.d.ts +5 -0
  257. package/dist/notification/dto/register-push-token.dto.js +38 -0
  258. package/dist/notification/dto/register-push-token.dto.js.map +1 -0
  259. package/dist/notification/entities/push-token.entity.d.ts +11 -0
  260. package/dist/notification/entities/push-token.entity.js +60 -0
  261. package/dist/notification/entities/push-token.entity.js.map +1 -0
  262. package/dist/notification/enums/push-service.enum.d.ts +6 -0
  263. package/dist/notification/enums/push-service.enum.js +11 -0
  264. package/dist/notification/enums/push-service.enum.js.map +1 -0
  265. package/dist/notification/hook-listener.service.d.ts +13 -0
  266. package/dist/notification/hook-listener.service.js +58 -0
  267. package/dist/notification/hook-listener.service.js.map +1 -0
  268. package/dist/notification/notification.module.d.ts +2 -0
  269. package/dist/notification/notification.module.js +24 -0
  270. package/dist/notification/notification.module.js.map +1 -0
  271. package/dist/notification/push-notification.controller.d.ts +9 -0
  272. package/dist/notification/push-notification.controller.js +69 -0
  273. package/dist/notification/push-notification.controller.js.map +1 -0
  274. package/dist/notification/push-notification.module.d.ts +2 -0
  275. package/dist/notification/push-notification.module.js +27 -0
  276. package/dist/notification/push-notification.module.js.map +1 -0
  277. package/dist/notification/push-notification.service.d.ts +23 -0
  278. package/dist/notification/push-notification.service.js +89 -0
  279. package/dist/notification/push-notification.service.js.map +1 -0
  280. package/dist/post/entities/post.entity.js +3 -3
  281. package/dist/post/entities/post.entity.js.map +1 -1
  282. package/dist/post/post.controller.d.ts +3 -2
  283. package/dist/post/post.controller.js +28 -8
  284. package/dist/post/post.controller.js.map +1 -1
  285. package/dist/post/post.module.js +2 -0
  286. package/dist/post/post.module.js.map +1 -1
  287. package/dist/post/post.service.d.ts +7 -3
  288. package/dist/post/post.service.js +18 -8
  289. package/dist/post/post.service.js.map +1 -1
  290. package/dist/tsconfig.build.tsbuildinfo +1 -1
  291. package/dist/user/avatar/avatar.controller.d.ts +10 -0
  292. package/dist/user/avatar/avatar.controller.js +89 -0
  293. package/dist/user/avatar/avatar.controller.js.map +1 -0
  294. package/dist/user/avatar/avatar.service.d.ts +12 -0
  295. package/dist/user/avatar/avatar.service.js +72 -0
  296. package/dist/user/avatar/avatar.service.js.map +1 -0
  297. package/dist/user/constants.d.ts +1 -0
  298. package/dist/user/constants.js +5 -0
  299. package/dist/user/constants.js.map +1 -0
  300. package/dist/user/dto/update-profile.dto.d.ts +3 -0
  301. package/dist/user/dto/update-profile.dto.js +26 -0
  302. package/dist/user/dto/update-profile.dto.js.map +1 -0
  303. package/dist/user/dto/user-response.dto.d.ts +6 -0
  304. package/dist/user/dto/user-response.dto.js +37 -1
  305. package/dist/user/dto/user-response.dto.js.map +1 -1
  306. package/dist/user/dto/user.dto.d.ts +8 -0
  307. package/dist/user/dto/user.dto.js +21 -0
  308. package/dist/user/dto/user.dto.js.map +1 -0
  309. package/dist/user/entities/user.entity.d.ts +4 -0
  310. package/dist/user/entities/user.entity.js +19 -1
  311. package/dist/user/entities/user.entity.js.map +1 -1
  312. package/dist/user/follow/dto/follow-response.dto.d.ts +4 -0
  313. package/dist/user/follow/dto/follow-response.dto.js +38 -0
  314. package/dist/user/follow/dto/follow-response.dto.js.map +1 -0
  315. package/dist/user/follow/dto/follow.dto.d.ts +4 -0
  316. package/dist/user/follow/dto/follow.dto.js +26 -0
  317. package/dist/user/follow/dto/follow.dto.js.map +1 -0
  318. package/dist/user/follow/entities/follow.entity.d.ts +10 -0
  319. package/dist/user/follow/entities/follow.entity.js +60 -0
  320. package/dist/user/follow/entities/follow.entity.js.map +1 -0
  321. package/dist/user/follow/follow.controller.d.ts +9 -0
  322. package/dist/user/follow/follow.controller.js +56 -0
  323. package/dist/user/follow/follow.controller.js.map +1 -0
  324. package/dist/user/follow/follow.module.d.ts +2 -0
  325. package/dist/user/follow/follow.module.js +26 -0
  326. package/dist/user/follow/follow.module.js.map +1 -0
  327. package/dist/user/follow/follow.service.d.ts +11 -0
  328. package/dist/user/follow/follow.service.js +56 -0
  329. package/dist/user/follow/follow.service.js.map +1 -0
  330. package/dist/user/user.controller.d.ts +4 -1
  331. package/dist/user/user.controller.js +38 -4
  332. package/dist/user/user.controller.js.map +1 -1
  333. package/dist/user/user.module.js +12 -3
  334. package/dist/user/user.module.js.map +1 -1
  335. package/dist/user/user.service.d.ts +12 -5
  336. package/dist/user/user.service.js +49 -11
  337. package/dist/user/user.service.js.map +1 -1
  338. package/package.json +16 -5
  339. package/dist/core/plugin/plugin-hook.service.d.ts +0 -7
  340. package/dist/core/plugin/plugin-hook.service.js.map +0 -1
  341. package/dist/media/entities/post-media.entity.d.ts +0 -5
  342. package/dist/media/entities/post-media.entity.js.map +0 -1
  343. package/dist/user/dto/update-user.dto.d.ts +0 -5
  344. package/dist/user/dto/update-user.dto.js +0 -13
  345. package/dist/user/dto/update-user.dto.js.map +0 -1
@@ -0,0 +1,24 @@
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.WebsocketModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const gateway_service_1 = require("./gateway.service");
12
+ const auth_module_1 = require("../../auth/auth.module");
13
+ const context_module_1 = require("../context/context.module");
14
+ let WebsocketModule = class WebsocketModule {
15
+ };
16
+ exports.WebsocketModule = WebsocketModule;
17
+ exports.WebsocketModule = WebsocketModule = __decorate([
18
+ (0, common_1.Module)({
19
+ imports: [auth_module_1.AuthModule, context_module_1.ContextModule],
20
+ providers: [gateway_service_1.WebsocketGatewayService],
21
+ exports: [gateway_service_1.WebsocketGatewayService],
22
+ })
23
+ ], WebsocketModule);
24
+ //# sourceMappingURL=websocket.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"websocket.module.js","sourceRoot":"","sources":["../../../src/core/websocket/websocket.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,uDAA4D;AAC5D,wDAAgD;AAChD,8DAA0D;AAOnD,IAAM,eAAe,GAArB,MAAM,eAAe;CAAG,CAAA;AAAlB,0CAAe;0BAAf,eAAe;IAL3B,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,wBAAU,EAAE,8BAAa,CAAC;QACpC,SAAS,EAAE,CAAC,yCAAuB,CAAC;QACpC,OAAO,EAAE,CAAC,yCAAuB,CAAC;KACnC,CAAC;GACW,eAAe,CAAG"}
package/dist/db.js CHANGED
@@ -7,6 +7,7 @@ const typeorm_1 = require("typeorm");
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const opts = {
9
9
  type: 'postgres',
10
+ url: process.env.POSTGRES_URL,
10
11
  host: process.env.POSTGRES_HOST || 'localhost',
11
12
  port: parseInt(process.env.POSTGRES_PORT || '') || 5432,
12
13
  username: process.env.POSTGRES_USER || 'root',
@@ -14,7 +15,7 @@ const opts = {
14
15
  database: process.env.POSTGRES_DB || 'socialdev',
15
16
  entities: [node_path_1.default.join(__dirname, '**/*.entity.js')],
16
17
  migrationsTableName: 'social_dev_migrations',
17
- migrations: ['dist/migrations/*.js'],
18
+ migrations: [node_path_1.default.join(__dirname, 'migrations/*.js')],
18
19
  migrationsRun: true,
19
20
  synchronize: process.env.SOCIAL_DEV_DEVMODE === 'true',
20
21
  };
package/dist/db.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"db.js","sourceRoot":"","sources":["../src/db.ts"],"names":[],"mappings":";;;;;AAAA,qCAAwD;AACxD,0DAA6B;AAE7B,MAAM,IAAI,GAAsB;IAC9B,IAAI,EAAE,UAAU;IAChB,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,WAAW;IAC9C,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,EAAE,CAAC,IAAI,IAAI;IACvD,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,MAAM;IAC7C,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,MAAM;IACjD,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,WAAW;IAChD,QAAQ,EAAE,CAAC,mBAAI,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;IAClD,mBAAmB,EAAE,uBAAuB;IAC5C,UAAU,EAAE,CAAC,sBAAsB,CAAC;IACpC,aAAa,EAAE,IAAI;IACnB,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,KAAK,MAAM;CACvD,CAAC;AAEF,kBAAe,IAAI,oBAAU,CAAC,IAAI,CAAC,CAAC"}
1
+ {"version":3,"file":"db.js","sourceRoot":"","sources":["../src/db.ts"],"names":[],"mappings":";;;;;AAAA,qCAAwD;AACxD,0DAA6B;AAE7B,MAAM,IAAI,GAAsB;IAC9B,IAAI,EAAE,UAAU;IAChB,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,YAAY;IAC7B,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,WAAW;IAC9C,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,EAAE,CAAC,IAAI,IAAI;IACvD,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,MAAM;IAC7C,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,MAAM;IACjD,QAAQ,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,WAAW;IAChD,QAAQ,EAAE,CAAC,mBAAI,CAAC,IAAI,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;IAClD,mBAAmB,EAAE,uBAAuB;IAC5C,UAAU,EAAE,CAAC,mBAAI,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC;IACrD,aAAa,EAAE,IAAI;IACnB,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,kBAAkB,KAAK,MAAM;CACvD,CAAC;AAEF,kBAAe,IAAI,oBAAU,CAAC,IAAI,CAAC,CAAC"}
@@ -4,5 +4,5 @@ export declare class FileStorageService {
4
4
  get s3Client(): S3Client;
5
5
  get bucketName(): string;
6
6
  getFile(key: string): Promise<ReadableStream<any> | undefined>;
7
- putFile(body: string | Uint8Array | Buffer | Readable, key?: string, contentType?: string): void;
7
+ putFile(body: string | Uint8Array | Buffer | Readable, key?: string, contentType?: string): Promise<void>;
8
8
  }
@@ -12,12 +12,12 @@ const client_s3_1 = require("@aws-sdk/client-s3");
12
12
  let FileStorageService = class FileStorageService {
13
13
  get s3Client() {
14
14
  return new client_s3_1.S3Client({
15
- endpoint: 'http://localhost:9000',
15
+ endpoint: process.env.SOCIAL_DEV_FILE_STORAGE_ENDPOINT || 'http://localhost:9000',
16
16
  credentials: {
17
- accessKeyId: 'minioadmin',
18
- secretAccessKey: 'minioadmin',
17
+ accessKeyId: process.env.SOCIAL_DEV_FILE_STORAGE_ACCESS_KEY_ID || 'minioadmin',
18
+ secretAccessKey: process.env.SOCIAL_DEV_FILE_STORAGE_ACCESS_KEY_SECRET || 'minioadmin',
19
19
  },
20
- region: 'us-east-1',
20
+ region: process.env.SOCIAL_DEV_FILE_STORAGE_REGION || 'us-east-1',
21
21
  forcePathStyle: true,
22
22
  });
23
23
  }
@@ -32,7 +32,7 @@ let FileStorageService = class FileStorageService {
32
32
  const data = await this.s3Client.send(command);
33
33
  return data.Body?.transformToWebStream();
34
34
  }
35
- putFile(body, key = '', contentType) {
35
+ async putFile(body, key = '', contentType) {
36
36
  const putObjectCommand = new client_s3_1.PutObjectCommand({
37
37
  Bucket: this.bucketName,
38
38
  Body: body,
@@ -40,7 +40,7 @@ let FileStorageService = class FileStorageService {
40
40
  ContentDisposition: `inline; ${key}`,
41
41
  ContentType: contentType,
42
42
  });
43
- this.s3Client.send(putObjectCommand);
43
+ await this.s3Client.send(putObjectCommand);
44
44
  }
45
45
  };
46
46
  exports.FileStorageService = FileStorageService;
@@ -1 +1 @@
1
- {"version":3,"file":"file-storage.service.js","sourceRoot":"","sources":["../../src/file-storage/file-storage.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,kDAQ4B;AAQrB,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAI7B,IAAI,QAAQ;QACV,OAAO,IAAI,oBAAQ,CAAC;YAClB,QAAQ,EAAE,uBAAuB;YACjC,WAAW,EAAE;gBACX,WAAW,EAAE,YAAY;gBACzB,eAAe,EAAE,YAAY;aAC9B;YACD,MAAM,EAAE,WAAW;YACnB,cAAc,EAAE,IAAI;SACrB,CAAC,CAAC;IACL,CAAC;IAOD,IAAI,UAAU;QACZ,OAAO,OAAO,CAAC,GAAG,CAAC,mCAAmC,IAAI,UAAU,CAAC;IACvE,CAAC;IAKD,KAAK,CAAC,OAAO,CAAC,GAAW;QAEvB,MAAM,OAAO,GAAG,IAAI,4BAAgB,CAAC;YACnC,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,GAAG,EAAE,GAAG;SACT,CAAC,CAAC;QAEH,MAAM,IAAI,GAA2B,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvE,OAAO,IAAI,CAAC,IAAI,EAAE,oBAAoB,EAAE,CAAC;IAC3C,CAAC;IAKD,OAAO,CACL,IAA6C,EAC7C,MAAc,EAAE,EAChB,WAAoB;QAEpB,MAAM,gBAAgB,GAAG,IAAI,4BAAgB,CAAC;YAC5C,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,IAAI,EAAE,IAAI;YACV,GAAG,EAAE,GAAG;YACR,kBAAkB,EAAE,WAAW,GAAG,EAAE;YACpC,WAAW,EAAE,WAAW;SACzB,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IACvC,CAAC;CACF,CAAA;AAzDY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;GACA,kBAAkB,CAyD9B"}
1
+ {"version":3,"file":"file-storage.service.js","sourceRoot":"","sources":["../../src/file-storage/file-storage.service.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAA4C;AAC5C,kDAQ4B;AAQrB,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IAI7B,IAAI,QAAQ;QACV,OAAO,IAAI,oBAAQ,CAAC;YAClB,QAAQ,EACN,OAAO,CAAC,GAAG,CAAC,gCAAgC,IAAI,uBAAuB;YACzE,WAAW,EAAE;gBACX,WAAW,EACT,OAAO,CAAC,GAAG,CAAC,qCAAqC,IAAI,YAAY;gBACnE,eAAe,EACb,OAAO,CAAC,GAAG,CAAC,yCAAyC,IAAI,YAAY;aACxE;YACD,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,8BAA8B,IAAI,WAAW;YACjE,cAAc,EAAE,IAAI;SACrB,CAAC,CAAC;IACL,CAAC;IAOD,IAAI,UAAU;QACZ,OAAO,OAAO,CAAC,GAAG,CAAC,mCAAmC,IAAI,UAAU,CAAC;IACvE,CAAC;IAKD,KAAK,CAAC,OAAO,CAAC,GAAW;QAEvB,MAAM,OAAO,GAAG,IAAI,4BAAgB,CAAC;YACnC,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,GAAG,EAAE,GAAG;SACT,CAAC,CAAC;QAEH,MAAM,IAAI,GAA2B,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEvE,OAAO,IAAI,CAAC,IAAI,EAAE,oBAAoB,EAAE,CAAC;IAC3C,CAAC;IAKD,KAAK,CAAC,OAAO,CACX,IAA6C,EAC7C,MAAc,EAAE,EAChB,WAAoB;QAEpB,MAAM,gBAAgB,GAAG,IAAI,4BAAgB,CAAC;YAC5C,MAAM,EAAE,IAAI,CAAC,UAAU;YACvB,IAAI,EAAE,IAAI;YACV,GAAG,EAAE,GAAG;YACR,kBAAkB,EAAE,WAAW,GAAG,EAAE;YACpC,WAAW,EAAE,WAAW;SACzB,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC7C,CAAC;CACF,CAAA;AA7DY,gDAAkB;6BAAlB,kBAAkB;IAD9B,IAAA,mBAAU,GAAE;GACA,kBAAkB,CA6D9B"}
@@ -1,2 +1,4 @@
1
+ import { Community } from '~/community/entities/community.entity';
1
2
  import { User } from '~/user/entities/user.entity';
2
3
  export declare const getUserDir: (user: User) => string;
4
+ export declare const getCommunityDir: (community: Community) => string;
@@ -1,8 +1,15 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getUserDir = void 0;
3
+ exports.getCommunityDir = exports.getUserDir = void 0;
4
+ const context_1 = require("../core/context/context");
4
5
  const getUserDir = (user) => {
5
- return `/network/${user.network.id}/user/${user.id}/`;
6
+ const network = context_1.Context.getNetwork();
7
+ return `network/${network.id}/user/${user.id}/`;
6
8
  };
7
9
  exports.getUserDir = getUserDir;
10
+ const getCommunityDir = (community) => {
11
+ const network = context_1.Context.getNetwork();
12
+ return `network/${network.id}/community/${community.id}/`;
13
+ };
14
+ exports.getCommunityDir = getCommunityDir;
8
15
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/file-storage/utils.ts"],"names":[],"mappings":";;;AAKO,MAAM,UAAU,GAAG,CAAC,IAAU,EAAU,EAAE;IAC/C,OAAO,YAAY,IAAI,CAAC,OAAO,CAAC,EAAE,SAAS,IAAI,CAAC,EAAE,GAAG,CAAC;AACxD,CAAC,CAAC;AAFW,QAAA,UAAU,cAErB"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/file-storage/utils.ts"],"names":[],"mappings":";;;AACA,qDAAiD;AAM1C,MAAM,UAAU,GAAG,CAAC,IAAU,EAAU,EAAE;IAC/C,MAAM,OAAO,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC;IACrC,OAAO,WAAW,OAAO,CAAC,EAAE,SAAS,IAAI,CAAC,EAAE,GAAG,CAAC;AAClD,CAAC,CAAC;AAHW,QAAA,UAAU,cAGrB;AAKK,MAAM,eAAe,GAAG,CAAC,SAAoB,EAAU,EAAE;IAC9D,MAAM,OAAO,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC;IACrC,OAAO,WAAW,OAAO,CAAC,EAAE,cAAc,SAAS,CAAC,EAAE,GAAG,CAAC;AAC5D,CAAC,CAAC;AAHW,QAAA,eAAe,mBAG1B"}
package/dist/index.d.ts CHANGED
@@ -2,5 +2,4 @@ export * as TypeOrm from '@nestjs/typeorm';
2
2
  export * from '~/core/acl/acl.module';
3
3
  export * from '~/community/community.module';
4
4
  export * from '~/user/user.module';
5
- export { PluginHookService } from '~/core/plugin/plugin-hook.service';
6
5
  export * as Common from '@nestjs/common';
package/dist/index.js CHANGED
@@ -36,12 +36,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
36
36
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
37
37
  };
38
38
  Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.Common = exports.PluginHookService = exports.TypeOrm = void 0;
39
+ exports.Common = exports.TypeOrm = void 0;
40
40
  exports.TypeOrm = __importStar(require("@nestjs/typeorm"));
41
41
  __exportStar(require("./core/acl/acl.module"), exports);
42
42
  __exportStar(require("./community/community.module"), exports);
43
43
  __exportStar(require("./user/user.module"), exports);
44
- var plugin_hook_service_1 = require("./core/plugin/plugin-hook.service");
45
- Object.defineProperty(exports, "PluginHookService", { enumerable: true, get: function () { return plugin_hook_service_1.PluginHookService; } });
46
44
  exports.Common = __importStar(require("@nestjs/common"));
47
45
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2DAA2C;AAE3C,wDAAsC;AACtC,+DAA6C;AAC7C,qDAAmC;AAEnC,yEAAsE;AAA7D,wHAAA,iBAAiB,OAAA;AAE1B,yDAAyC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2DAA2C;AAE3C,wDAAsC;AACtC,+DAA6C;AAC7C,qDAAmC;AAEnC,yDAAyC"}
@@ -0,0 +1 @@
1
+ export { default } from './db';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.default = void 0;
7
+ process.loadEnvFile('../../.env');
8
+ var db_1 = require("./db");
9
+ Object.defineProperty(exports, "default", { enumerable: true, get: function () { return __importDefault(db_1).default; } });
10
+ //# sourceMappingURL=manage-db.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"manage-db.js","sourceRoot":"","sources":["../src/manage-db.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;AAElC,2BAA+B;AAAtB,8GAAA,OAAO,OAAA"}
@@ -4,4 +4,6 @@ export declare class MediaResponseDto {
4
4
  durationSecs: number;
5
5
  type: string;
6
6
  url: string;
7
+ widthPx: number;
8
+ heightPx: number;
7
9
  }
@@ -19,8 +19,10 @@ class MediaResponseDto {
19
19
  durationSecs;
20
20
  type;
21
21
  url;
22
+ widthPx;
23
+ heightPx;
22
24
  static _OPENAPI_METADATA_FACTORY() {
23
- return { id: { required: true, type: () => Number }, sizeBytes: { required: true, type: () => Number }, durationSecs: { required: true, type: () => Number }, type: { required: true, type: () => String }, url: { required: true, type: () => String } };
25
+ return { id: { required: true, type: () => Number }, sizeBytes: { required: true, type: () => Number }, durationSecs: { required: true, type: () => Number }, type: { required: true, type: () => String }, url: { required: true, type: () => String }, widthPx: { required: true, type: () => Number }, heightPx: { required: true, type: () => Number } };
24
26
  }
25
27
  }
26
28
  exports.MediaResponseDto = MediaResponseDto;
@@ -45,13 +47,24 @@ __decorate([
45
47
  ], MediaResponseDto.prototype, "type", void 0);
46
48
  __decorate([
47
49
  (0, class_transformer_1.Transform)(({ obj }) => {
48
- const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'api/media';
50
+ const baseUrl = context_1.Context.getNetwork().getBaseUrl() + 'media';
49
51
  if (obj.type == 'Audio') {
50
52
  return baseUrl + '.audio.download?audio=' + obj.id;
51
53
  }
54
+ if (obj.type == 'Image') {
55
+ return baseUrl + '.image.download?image=' + obj.id;
56
+ }
52
57
  return baseUrl + '.download?media=' + obj.id;
53
58
  }),
54
59
  (0, class_transformer_1.Expose)(),
55
60
  __metadata("design:type", String)
56
61
  ], MediaResponseDto.prototype, "url", void 0);
62
+ __decorate([
63
+ (0, class_transformer_1.Expose)(),
64
+ __metadata("design:type", Number)
65
+ ], MediaResponseDto.prototype, "widthPx", void 0);
66
+ __decorate([
67
+ (0, class_transformer_1.Expose)(),
68
+ __metadata("design:type", Number)
69
+ ], MediaResponseDto.prototype, "heightPx", void 0);
57
70
  //# sourceMappingURL=media-response.dto.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"media-response.dto.js","sourceRoot":"","sources":["../../../src/media/dto/media-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,yDAA4D;AAC5D,wDAAiD;AAEjD,MAAa,gBAAgB;IAE3B,EAAE,CAAS;IAGX,SAAS,CAAS;IAGlB,YAAY,CAAS;IAMrB,IAAI,CAAS;IAYb,GAAG,CAAS;;;;CACb;AA3BD,4CA2BC;AAzBC;IADC,IAAA,0BAAM,GAAE;;4CACE;AAGX;IADC,IAAA,0BAAM,GAAE;;mDACS;AAGlB;IADC,IAAA,0BAAM,GAAE;;sDACY;AAMrB;IAJC,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE;QAC5B,OAAO,KAAK,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC;IACvC,CAAC,CAAC;IACD,IAAA,0BAAM,GAAE;;8CACI;AAYb;IAVC,IAAA,6BAAS,EAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QACrB,MAAM,OAAO,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC,UAAU,EAAE,GAAG,WAAW,CAAC;QAEhE,IAAI,GAAG,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;YACxB,OAAO,OAAO,GAAG,wBAAwB,GAAG,GAAG,CAAC,EAAE,CAAC;QACrD,CAAC;QAED,OAAO,OAAO,GAAG,kBAAkB,GAAG,GAAG,CAAC,EAAE,CAAC;IAC/C,CAAC,CAAC;IACD,IAAA,0BAAM,GAAE;;6CACG"}
1
+ {"version":3,"file":"media-response.dto.js","sourceRoot":"","sources":["../../../src/media/dto/media-response.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,yDAA4D;AAC5D,wDAAiD;AAEjD,MAAa,gBAAgB;IAE3B,EAAE,CAAS;IAGX,SAAS,CAAS;IAGlB,YAAY,CAAS;IAMrB,IAAI,CAAS;IAgBb,GAAG,CAAS;IAGZ,OAAO,CAAS;IAGhB,QAAQ,CAAS;;;;CAClB;AArCD,4CAqCC;AAnCC;IADC,IAAA,0BAAM,GAAE;;4CACE;AAGX;IADC,IAAA,0BAAM,GAAE;;mDACS;AAGlB;IADC,IAAA,0BAAM,GAAE;;sDACY;AAMrB;IAJC,IAAA,6BAAS,EAAC,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE;QAC5B,OAAO,KAAK,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC;IACvC,CAAC,CAAC;IACD,IAAA,0BAAM,GAAE;;8CACI;AAgBb;IAdC,IAAA,6BAAS,EAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;QACrB,MAAM,OAAO,GAAG,iBAAO,CAAC,UAAU,EAAE,CAAC,UAAU,EAAE,GAAG,OAAO,CAAC;QAE5D,IAAI,GAAG,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;YACxB,OAAO,OAAO,GAAG,wBAAwB,GAAG,GAAG,CAAC,EAAE,CAAC;QACrD,CAAC;QAED,IAAI,GAAG,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;YACxB,OAAO,OAAO,GAAG,wBAAwB,GAAG,GAAG,CAAC,EAAE,CAAC;QACrD,CAAC;QAED,OAAO,OAAO,GAAG,kBAAkB,GAAG,GAAG,CAAC,EAAE,CAAC;IAC/C,CAAC,CAAC;IACD,IAAA,0BAAM,GAAE;;6CACG;AAGZ;IADC,IAAA,0BAAM,GAAE;;iDACO;AAGhB;IADC,IAAA,0BAAM,GAAE;;kDACQ"}
@@ -1,4 +1,4 @@
1
- import { PostMedia } from './post-media.entity';
2
- export declare class Audio extends PostMedia {
1
+ import { Media } from './media.entity';
2
+ export declare class Audio extends Media {
3
3
  durationSecs: number;
4
4
  }
@@ -12,8 +12,8 @@ Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.Audio = void 0;
13
13
  const openapi = require("@nestjs/swagger");
14
14
  const typeorm_1 = require("typeorm");
15
- const post_media_entity_1 = require("./post-media.entity");
16
- let Audio = class Audio extends post_media_entity_1.PostMedia {
15
+ const media_entity_1 = require("./media.entity");
16
+ let Audio = class Audio extends media_entity_1.Media {
17
17
  durationSecs;
18
18
  static _OPENAPI_METADATA_FACTORY() {
19
19
  return { durationSecs: { required: true, type: () => Number } };
@@ -1 +1 @@
1
- {"version":3,"file":"audio.entity.js","sourceRoot":"","sources":["../../../src/media/entities/audio.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAAuE;AACvE,2DAAgD;AAGzC,IAAM,KAAK,GAAX,MAAM,KAAM,SAAQ,6BAAS;IAKlC,YAAY,CAAS;;;;CACtB,CAAA;AANY,sBAAK;AAKhB;IADC,IAAA,gBAAM,GAAE;;2CACY;gBALV,KAAK;IADjB,IAAA,qBAAW,GAAE;GACD,KAAK,CAMjB"}
1
+ {"version":3,"file":"audio.entity.js","sourceRoot":"","sources":["../../../src/media/entities/audio.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAAuE;AACvE,iDAAuC;AAGhC,IAAM,KAAK,GAAX,MAAM,KAAM,SAAQ,oBAAK;IAK9B,YAAY,CAAS;;;;CACtB,CAAA;AANY,sBAAK;AAKhB;IADC,IAAA,gBAAM,GAAE;;2CACY;gBALV,KAAK;IADjB,IAAA,qBAAW,GAAE;GACD,KAAK,CAMjB"}
@@ -0,0 +1,5 @@
1
+ import { Media } from './media.entity';
2
+ export declare class Image extends Media {
3
+ widthPx: number;
4
+ heightPx: number;
5
+ }
@@ -9,23 +9,27 @@ var __metadata = (this && this.__metadata) || function (k, v) {
9
9
  if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.PostMedia = void 0;
12
+ exports.Image = void 0;
13
13
  const openapi = require("@nestjs/swagger");
14
14
  const typeorm_1 = require("typeorm");
15
15
  const media_entity_1 = require("./media.entity");
16
- const post_entity_1 = require("../../post/entities/post.entity");
17
- let PostMedia = class PostMedia extends media_entity_1.Media {
18
- post;
16
+ let Image = class Image extends media_entity_1.Media {
17
+ widthPx;
18
+ heightPx;
19
19
  static _OPENAPI_METADATA_FACTORY() {
20
- return { post: { required: true, type: () => require("../../post/entities/post.entity").Post } };
20
+ return { widthPx: { required: true, type: () => Number }, heightPx: { required: true, type: () => Number } };
21
21
  }
22
22
  };
23
- exports.PostMedia = PostMedia;
23
+ exports.Image = Image;
24
24
  __decorate([
25
- (0, typeorm_1.ManyToOne)(() => post_entity_1.Post, { eager: true }),
26
- __metadata("design:type", post_entity_1.Post)
27
- ], PostMedia.prototype, "post", void 0);
28
- exports.PostMedia = PostMedia = __decorate([
25
+ (0, typeorm_1.Column)({ nullable: true }),
26
+ __metadata("design:type", Number)
27
+ ], Image.prototype, "widthPx", void 0);
28
+ __decorate([
29
+ (0, typeorm_1.Column)({ nullable: true }),
30
+ __metadata("design:type", Number)
31
+ ], Image.prototype, "heightPx", void 0);
32
+ exports.Image = Image = __decorate([
29
33
  (0, typeorm_1.ChildEntity)()
30
- ], PostMedia);
31
- //# sourceMappingURL=post-media.entity.js.map
34
+ ], Image);
35
+ //# sourceMappingURL=image.entity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"image.entity.js","sourceRoot":"","sources":["../../../src/media/entities/image.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAA8C;AAC9C,iDAAuC;AAGhC,IAAM,KAAK,GAAX,MAAM,KAAM,SAAQ,oBAAK;IAK9B,OAAO,CAAS;IAMhB,QAAQ,CAAS;;;;CAClB,CAAA;AAZY,sBAAK;AAKhB;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;sCACX;AAMhB;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACV;gBAXN,KAAK;IADjB,IAAA,qBAAW,GAAE;GACD,KAAK,CAYjB"}
@@ -1,5 +1,7 @@
1
1
  import { Network } from '~/network/entities/network.entity';
2
2
  import { User } from '~/user/entities/user.entity';
3
+ import { Post } from '~/post/entities/post.entity';
4
+ import { ChatMessage } from '~/chat/entities/message.entity';
3
5
  export declare abstract class Media {
4
6
  id: number;
5
7
  network: Network;
@@ -7,4 +9,8 @@ export declare abstract class Media {
7
9
  pathname: string;
8
10
  sizeBytes: number;
9
11
  deleted: boolean;
12
+ post: Post;
13
+ chatMessage: ChatMessage;
14
+ createdAt: Date;
15
+ updatedAt: Date;
10
16
  }
@@ -14,6 +14,8 @@ const openapi = require("@nestjs/swagger");
14
14
  const typeorm_1 = require("typeorm");
15
15
  const network_entity_1 = require("../../network/entities/network.entity");
16
16
  const user_entity_1 = require("../../user/entities/user.entity");
17
+ const post_entity_1 = require("../../post/entities/post.entity");
18
+ const message_entity_1 = require("../../chat/entities/message.entity");
17
19
  let Media = class Media {
18
20
  id;
19
21
  network;
@@ -21,8 +23,12 @@ let Media = class Media {
21
23
  pathname;
22
24
  sizeBytes;
23
25
  deleted = false;
26
+ post;
27
+ chatMessage;
28
+ createdAt;
29
+ updatedAt;
24
30
  static _OPENAPI_METADATA_FACTORY() {
25
- return { id: { required: true, type: () => Number }, network: { required: true, type: () => require("../../network/entities/network.entity").Network }, owner: { required: true, type: () => require("../../user/entities/user.entity").User }, pathname: { required: true, type: () => String }, sizeBytes: { required: true, type: () => Number }, deleted: { required: true, type: () => Boolean, default: false } };
31
+ return { id: { required: true, type: () => Number }, network: { required: true, type: () => require("../../network/entities/network.entity").Network }, owner: { required: true, type: () => require("../../user/entities/user.entity").User }, pathname: { required: true, type: () => String }, sizeBytes: { required: true, type: () => Number }, deleted: { required: true, type: () => Boolean, default: false }, post: { required: true, type: () => require("../../post/entities/post.entity").Post }, chatMessage: { required: true, type: () => require("../../chat/entities/message.entity").ChatMessage }, createdAt: { required: true, type: () => Date }, updatedAt: { required: true, type: () => Date } };
26
32
  }
27
33
  };
28
34
  exports.Media = Media;
@@ -35,7 +41,7 @@ __decorate([
35
41
  __metadata("design:type", network_entity_1.Network)
36
42
  ], Media.prototype, "network", void 0);
37
43
  __decorate([
38
- (0, typeorm_1.ManyToOne)(() => user_entity_1.User, { onDelete: 'RESTRICT', nullable: false }),
44
+ (0, typeorm_1.ManyToOne)(() => user_entity_1.User, { onDelete: 'RESTRICT', nullable: false, eager: true }),
39
45
  __metadata("design:type", user_entity_1.User)
40
46
  ], Media.prototype, "owner", void 0);
41
47
  __decorate([
@@ -50,6 +56,23 @@ __decorate([
50
56
  (0, typeorm_1.Column)(),
51
57
  __metadata("design:type", Boolean)
52
58
  ], Media.prototype, "deleted", void 0);
59
+ __decorate([
60
+ (0, typeorm_1.ManyToOne)(() => post_entity_1.Post, { eager: true }),
61
+ __metadata("design:type", post_entity_1.Post)
62
+ ], Media.prototype, "post", void 0);
63
+ __decorate([
64
+ (0, typeorm_1.OneToOne)(() => message_entity_1.ChatMessage, { eager: true }),
65
+ (0, typeorm_1.JoinColumn)(),
66
+ __metadata("design:type", message_entity_1.ChatMessage)
67
+ ], Media.prototype, "chatMessage", void 0);
68
+ __decorate([
69
+ (0, typeorm_1.CreateDateColumn)(),
70
+ __metadata("design:type", Date)
71
+ ], Media.prototype, "createdAt", void 0);
72
+ __decorate([
73
+ (0, typeorm_1.UpdateDateColumn)(),
74
+ __metadata("design:type", Date)
75
+ ], Media.prototype, "updatedAt", void 0);
53
76
  exports.Media = Media = __decorate([
54
77
  (0, typeorm_1.Entity)(),
55
78
  (0, typeorm_1.TableInheritance)({ column: { type: 'varchar', name: 'type' } })
@@ -1 +1 @@
1
- {"version":3,"file":"media.entity.js","sourceRoot":"","sources":["../../../src/media/entities/media.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAOiB;AACjB,0EAA4D;AAC5D,iEAAmD;AAI5C,IAAe,KAAK,GAApB,MAAe,KAAK;IAEzB,EAAE,CAAS;IAQX,OAAO,CAAU;IAQjB,KAAK,CAAO;IAMZ,QAAQ,CAAS;IAMjB,SAAS,CAAS;IAMlB,OAAO,GAAY,KAAK,CAAC;;sZAAN,KAAK;;CACzB,CAAA;AArCqB,sBAAK;AAEzB;IADC,IAAA,gCAAsB,GAAE;;iCACd;AAQX;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,wBAAO,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;8BAC3D,wBAAO;sCAAC;AAQjB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;8BAC1D,kBAAI;oCAAC;AAMZ;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACV;AAMjB;IADC,IAAA,gBAAM,GAAE;;wCACS;AAMlB;IADC,IAAA,gBAAM,GAAE;;sCACgB;gBApCL,KAAK;IAF1B,IAAA,gBAAM,GAAE;IACR,IAAA,0BAAgB,EAAC,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC;GAC1C,KAAK,CAqC1B"}
1
+ {"version":3,"file":"media.entity.js","sourceRoot":"","sources":["../../../src/media/entities/media.entity.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qCAUiB;AACjB,0EAA4D;AAC5D,iEAAmD;AACnD,iEAAmD;AACnD,uEAA6D;AAItD,IAAe,KAAK,GAApB,MAAe,KAAK;IAEzB,EAAE,CAAS;IAQX,OAAO,CAAU;IAQjB,KAAK,CAAO;IAMZ,QAAQ,CAAS;IAMjB,SAAS,CAAS;IAMlB,OAAO,GAAY,KAAK,CAAC;IAGlB,IAAI,CAAO;IAIX,WAAW,CAAc;IAMhC,SAAS,CAAO;IAMhB,SAAS,CAAO;;sZAnBG,KAAK;;CAoBzB,CAAA;AAxDqB,sBAAK;AAEzB;IADC,IAAA,gCAAsB,GAAE;;iCACd;AAQX;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,wBAAO,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;8BAC3D,wBAAO;sCAAC;AAQjB;IADC,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;8BACvE,kBAAI;oCAAC;AAMZ;IADC,IAAA,gBAAM,EAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;;uCACV;AAMjB;IADC,IAAA,gBAAM,GAAE;;wCACS;AAMlB;IADC,IAAA,gBAAM,GAAE;;sCACgB;AAGlB;IADN,IAAA,mBAAS,EAAC,GAAG,EAAE,CAAC,kBAAI,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;8BAC1B,kBAAI;mCAAC;AAIX;IAFN,IAAA,kBAAQ,EAAC,GAAG,EAAE,CAAC,4BAAW,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC;IAC5C,IAAA,oBAAU,GAAE;8BACO,4BAAW;0CAAC;AAMhC;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;wCAAC;AAMhB;IADC,IAAA,0BAAgB,GAAE;8BACR,IAAI;wCAAC;gBAvDI,KAAK;IAF1B,IAAA,gBAAM,GAAE;IACR,IAAA,0BAAgB,EAAC,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC;GAC1C,KAAK,CAwD1B"}
@@ -1,5 +1,3 @@
1
- declare const MediaAcl: (({ can, getAbility }: {
2
- can: any;
3
- getAbility: any;
4
- }) => any)[];
1
+ import { RuleCallback } from '~/core/acl/acl.factory';
2
+ declare const MediaAcl: RuleCallback[];
5
3
  export default MediaAcl;
@@ -2,9 +2,30 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const acl_factory_1 = require("../core/acl/acl.factory");
4
4
  const audio_entity_1 = require("./entities/audio.entity");
5
+ const image_entity_1 = require("./entities/image.entity");
5
6
  const MediaAcl = [
6
7
  ({ can, getAbility }) => can(acl_factory_1.Action.Read, audio_entity_1.Audio, (audio) => {
7
- return getAbility().can(acl_factory_1.Action.Read, audio.post);
8
+ if (audio.post) {
9
+ return getAbility().can(acl_factory_1.Action.Read, audio.post);
10
+ }
11
+ else if (audio.chatMessage) {
12
+ return getAbility().can(acl_factory_1.Action.Read, audio.chatMessage);
13
+ }
14
+ else {
15
+ return false;
16
+ }
17
+ }),
18
+ ({ can, user }) => can(acl_factory_1.Action.Read, audio_entity_1.Audio, (audio) => {
19
+ return audio.owner.id === user?.id;
20
+ }),
21
+ ({ can, getAbility }) => can(acl_factory_1.Action.Read, image_entity_1.Image, (image) => {
22
+ if (image.chatMessage) {
23
+ return getAbility().can(acl_factory_1.Action.Read, image.chatMessage);
24
+ }
25
+ return false;
26
+ }),
27
+ ({ can, user }) => can(acl_factory_1.Action.Read, image_entity_1.Image, (image) => {
28
+ return image.owner.id === user?.id;
8
29
  }),
9
30
  ];
10
31
  exports.default = MediaAcl;
@@ -1 +1 @@
1
- {"version":3,"file":"media.acl.js","sourceRoot":"","sources":["../../src/media/media.acl.ts"],"names":[],"mappings":";;AAAA,yDAAgD;AAChD,0DAAgD;AAEhD,MAAM,QAAQ,GAAG;IAEf,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,CACtB,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,oBAAK,EAAE,CAAC,KAAY,EAAE,EAAE;QACvC,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC,CAAC;CACL,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
1
+ {"version":3,"file":"media.acl.js","sourceRoot":"","sources":["../../src/media/media.acl.ts"],"names":[],"mappings":";;AAAA,yDAA8D;AAC9D,0DAAgD;AAChD,0DAAgD;AAEhD,MAAM,QAAQ,GAAmB;IAE/B,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,CACtB,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,oBAAK,EAAE,CAAC,KAAY,EAAE,EAAE;QACvC,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACf,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACnD,CAAC;aAAM,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YAC7B,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;QAC1D,CAAC;aAAM,CAAC;YACN,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC,CAAC;IAEJ,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,CAChB,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,oBAAK,EAAE,CAAC,KAAY,EAAE,EAAE;QACvC,OAAO,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,EAAE,EAAE,CAAC;IACrC,CAAC,CAAC;IAEJ,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,CACtB,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,oBAAK,EAAE,CAAC,KAAY,EAAE,EAAE;QAEvC,IAAI,KAAK,CAAC,WAAW,EAAE,CAAC;YACtB,OAAO,UAAU,EAAE,CAAC,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;QAC1D,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC;IAEJ,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,CAChB,GAAG,CAAC,oBAAM,CAAC,IAAI,EAAE,oBAAK,EAAE,CAAC,KAAY,EAAE,EAAE;QACvC,OAAO,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,IAAI,EAAE,EAAE,CAAC;IACrC,CAAC,CAAC;CACL,CAAC;AAEF,kBAAe,QAAQ,CAAC"}
@@ -6,4 +6,6 @@ export declare class MediaController {
6
6
  constructor(mediaService: MediaService);
7
7
  uploadAudio(file: Express.Multer.File): Promise<MediaResponseDto>;
8
8
  downloadMedia(id: string): Promise<StreamableFile>;
9
+ uploadImage(file: Express.Multer.File): Promise<MediaResponseDto>;
10
+ downloadImage(id: string): Promise<StreamableFile>;
9
11
  }
@@ -23,6 +23,7 @@ const media_response_dto_1 = require("./dto/media-response.dto");
23
23
  const class_transformer_1 = require("class-transformer");
24
24
  const context_1 = require("../core/context/context");
25
25
  const audio_entity_1 = require("./entities/audio.entity");
26
+ const image_entity_1 = require("./entities/image.entity");
26
27
  let MediaController = class MediaController {
27
28
  mediaService;
28
29
  constructor(mediaService) {
@@ -48,6 +49,25 @@ let MediaController = class MediaController {
48
49
  disposition: `attachment; filename="${audio.id}.mp3"`,
49
50
  });
50
51
  }
52
+ async uploadImage(file) {
53
+ const image = await this.mediaService.uploadImageFile(file, context_1.Context.getUser());
54
+ return (0, class_transformer_1.plainToInstance)(media_response_dto_1.MediaResponseDto, image);
55
+ }
56
+ async downloadImage(id) {
57
+ const image = await this.mediaService.findOne(+id, image_entity_1.Image);
58
+ if (!image) {
59
+ throw new common_1.NotFoundException('Image file not found');
60
+ }
61
+ const stream = await this.mediaService.downloadFile(image);
62
+ if (!stream) {
63
+ throw new common_1.NotFoundException('Image file stream not found');
64
+ }
65
+ const { Readable } = await import('stream');
66
+ const nodeStream = Readable.fromWeb(stream);
67
+ return new common_1.StreamableFile(nodeStream, {
68
+ type: 'image/jpeg',
69
+ });
70
+ }
51
71
  };
52
72
  exports.MediaController = MediaController;
53
73
  __decorate([
@@ -88,6 +108,44 @@ __decorate([
88
108
  __metadata("design:paramtypes", [String]),
89
109
  __metadata("design:returntype", Promise)
90
110
  ], MediaController.prototype, "downloadMedia", null);
111
+ __decorate([
112
+ (0, swagger_1.ApiOperation)({
113
+ summary: 'Upload & create an image file ',
114
+ description: 'This Media API method creates and stores an image file. If successful, a media entity is returned.',
115
+ }),
116
+ (0, common_1.UseGuards)(auth_guard_1.AuthGuard),
117
+ (0, common_1.Post)('media.image.upload'),
118
+ (0, swagger_1.ApiConsumes)('multipart/form-data'),
119
+ (0, swagger_1.ApiBody)({
120
+ schema: {
121
+ type: 'object',
122
+ properties: {
123
+ file: {
124
+ type: 'string',
125
+ format: 'binary',
126
+ },
127
+ },
128
+ },
129
+ }),
130
+ (0, common_1.UseInterceptors)((0, platform_express_1.FileInterceptor)('file')),
131
+ openapi.ApiResponse({ status: 201, type: require("./dto/media-response.dto").MediaResponseDto }),
132
+ __param(0, (0, common_1.UploadedFile)()),
133
+ __metadata("design:type", Function),
134
+ __metadata("design:paramtypes", [Object]),
135
+ __metadata("design:returntype", Promise)
136
+ ], MediaController.prototype, "uploadImage", null);
137
+ __decorate([
138
+ (0, swagger_1.ApiOperation)({
139
+ summary: 'Downloads an image file',
140
+ description: 'This Media API method will download an image file',
141
+ }),
142
+ (0, common_1.Get)('media.image.download'),
143
+ openapi.ApiResponse({ status: 200 }),
144
+ __param(0, (0, common_1.Query)('image')),
145
+ __metadata("design:type", Function),
146
+ __metadata("design:paramtypes", [String]),
147
+ __metadata("design:returntype", Promise)
148
+ ], MediaController.prototype, "downloadImage", null);
91
149
  exports.MediaController = MediaController = __decorate([
92
150
  (0, common_1.Controller)(),
93
151
  __metadata("design:paramtypes", [media_service_1.MediaService])
@@ -1 +1 @@
1
- {"version":3,"file":"media.controller.js","sourceRoot":"","sources":["../../src/media/media.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAawB;AACxB,mDAA8C;AAC9C,mDAA+C;AAC/C,+DAA2D;AAE3D,6CAAqE;AACrE,iEAA4D;AAC5D,yDAAoD;AACpD,qDAAiD;AACjD,0DAAgD;AAGzC,IAAM,eAAe,GAArB,MAAM,eAAe;IACG;IAA7B,YAA6B,YAA0B;QAA1B,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAsBrD,AAAN,KAAK,CAAC,WAAW,CACC,IAAyB;QAEzC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,eAAe,CACnD,IAAI,EACJ,iBAAO,CAAC,OAAO,EAAU,CAC1B,CAAC;QAEF,OAAO,IAAA,mCAAe,EAAC,qCAAgB,EAAE,KAAK,CAAC,CAAC;IAClD,CAAC;IAOK,AAAN,KAAK,CAAC,aAAa,CAAiB,EAAU;QAC5C,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,oBAAK,CAAC,CAAC;QAE1D,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,MAAM,IAAI,0BAAiB,CAAC,sBAAsB,CAAC,CAAC;QACtD,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAE3D,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,0BAAiB,CAAC,6BAA6B,CAAC,CAAC;QAC7D,CAAC;QAGD,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;YAClB,WAAW,EAAE,yBAAyB,KAAK,CAAC,EAAE,OAAO;SACtD,CAAC,CAAC;IACL,CAAC;CACF,CAAA;AA7DY,0CAAe;AAuBpB;IApBL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,gCAAgC;QACzC,WAAW,EACT,oGAAoG;KACvG,CAAC;IACD,IAAA,kBAAS,EAAC,sBAAS,CAAC;IACpB,IAAA,aAAI,EAAC,oBAAoB,CAAC;IAC1B,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;;IAEtC,WAAA,IAAA,qBAAY,GAAE,CAAA;;;;kDAQhB;AAOK;IALL,IAAA,sBAAY,EAAC;QACZ,OAAO,EAAE,yBAAyB;QAClC,WAAW,EAAE,mDAAmD;KACjE,CAAC;IACD,IAAA,YAAG,EAAC,sBAAsB,CAAC;;IACP,WAAA,IAAA,cAAK,EAAC,OAAO,CAAC,CAAA;;;;oDAqBlC;0BA5DU,eAAe;IAD3B,IAAA,mBAAU,GAAE;qCAEgC,4BAAY;GAD5C,eAAe,CA6D3B"}
1
+ {"version":3,"file":"media.controller.js","sourceRoot":"","sources":["../../src/media/media.controller.ts"],"names":[],"mappings":"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"}
@@ -13,6 +13,7 @@ exports.MediaModule = void 0;
13
13
  const common_1 = require("@nestjs/common");
14
14
  const typeorm_1 = require("@nestjs/typeorm");
15
15
  const audio_entity_1 = require("./entities/audio.entity");
16
+ const image_entity_1 = require("./entities/image.entity");
16
17
  const media_entity_1 = require("./entities/media.entity");
17
18
  const media_service_1 = require("./media.service");
18
19
  const media_controller_1 = require("./media.controller");
@@ -26,7 +27,7 @@ exports.MediaModule = MediaModule;
26
27
  exports.MediaModule = MediaModule = __decorate([
27
28
  (0, common_1.Module)({
28
29
  imports: [
29
- typeorm_1.TypeOrmModule.forFeature([audio_entity_1.Audio, media_entity_1.Media]),
30
+ typeorm_1.TypeOrmModule.forFeature([audio_entity_1.Audio, image_entity_1.Image, media_entity_1.Media]),
30
31
  file_storage_module_1.FileStorageModule,
31
32
  network_module_1.NetworkModule,
32
33
  acl_module_1.AclModule.forChild(media_acl_1.default),
@@ -1 +1 @@
1
- {"version":3,"file":"media.module.js","sourceRoot":"","sources":["../../src/media/media.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,0DAAgD;AAChD,0DAAgD;AAChD,mDAA+C;AAC/C,yDAAqD;AACrD,6EAAwE;AACxE,8DAAyD;AACzD,uDAAkD;AAClD,4DAAmC;AAa5B,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IAXvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,oBAAK,EAAE,oBAAK,CAAC,CAAC;YACxC,uCAAiB;YACjB,8BAAa;YACb,sBAAS,CAAC,QAAQ,CAAC,mBAAQ,CAAC;SAC7B;QACD,WAAW,EAAE,CAAC,kCAAe,CAAC;QAC9B,SAAS,EAAE,CAAC,4BAAY,CAAC;QACzB,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
1
+ {"version":3,"file":"media.module.js","sourceRoot":"","sources":["../../src/media/media.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAAwC;AACxC,6CAAgD;AAChD,0DAAgD;AAChD,0DAAgD;AAChD,0DAAgD;AAChD,mDAA+C;AAC/C,yDAAqD;AACrD,6EAAwE;AACxE,8DAAyD;AACzD,uDAAkD;AAClD,4DAAmC;AAa5B,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IAXvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,uBAAa,CAAC,UAAU,CAAC,CAAC,oBAAK,EAAE,oBAAK,EAAE,oBAAK,CAAC,CAAC;YAC/C,uCAAiB;YACjB,8BAAa;YACb,sBAAS,CAAC,QAAQ,CAAC,mBAAQ,CAAC;SAC7B;QACD,WAAW,EAAE,CAAC,kCAAe,CAAC;QAC9B,SAAS,EAAE,CAAC,4BAAY,CAAC;QACzB,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
@@ -1,18 +1,21 @@
1
1
  import { Repository } from 'typeorm';
2
2
  import { Media } from './entities/media.entity';
3
3
  import { Audio } from './entities/audio.entity';
4
+ import { Image } from './entities/image.entity';
4
5
  import { FileStorageService } from '../file-storage/file-storage.service';
5
6
  import { User } from '~/user/entities/user.entity';
6
7
  import { AclFactory } from '~/core/acl/acl.factory';
7
8
  export declare class MediaService {
8
9
  private readonly audioRepository;
10
+ private readonly imageRepository;
9
11
  private readonly fileStorage;
10
12
  private readonly aclFactory;
11
- constructor(audioRepository: Repository<Audio>, fileStorage: FileStorageService, aclFactory: AclFactory);
13
+ constructor(audioRepository: Repository<Audio>, imageRepository: Repository<Image>, fileStorage: FileStorageService, aclFactory: AclFactory);
12
14
  uploadAudioFile(file: Express.Multer.File, owner: User): Promise<Audio>;
13
- downloadFile(media: Media | Audio): Promise<ReadableStream<any> | undefined>;
15
+ uploadImageFile(file: Express.Multer.File, owner: User): Promise<Image>;
16
+ downloadFile(media: Media | Audio | Image): Promise<ReadableStream<any> | undefined>;
14
17
  findAll(postId: number): Promise<Media[]>;
15
- findOne(id: number, type: typeof Audio): Promise<Audio | null | undefined>;
18
+ findOne(id: number, type: typeof Audio | typeof Image): Promise<Audio | Image | null>;
16
19
  update(id: number): string;
17
20
  remove(id: number): string;
18
21
  }