]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - server/lib/activitypub/videos.ts
Fix bad to/cc when undo dislike
[github/Chocobozzz/PeerTube.git] / server / lib / activitypub / videos.ts
index 9442448932c27e3071de9edf7db2d79a4dcb5889..6b82f12d56bf311d8d8249d1319cb466bfcba6ae 100644 (file)
@@ -1,9 +1,20 @@
 import { join } from 'path'
 import * as request from 'request'
+import { Transaction } from 'sequelize'
 import { ActivityIconObject } from '../../../shared/index'
 import { doRequest, doRequestAndSaveToFile } from '../../helpers/requests'
 import { CONFIG, REMOTE_SCHEME, STATIC_PATHS } from '../../initializers/constants'
+import { AccountInstance } from '../../models/account/account-interface'
 import { VideoInstance } from '../../models/video/video-interface'
+import { sendLikeToOrigin } from './index'
+import { sendCreateDislikeToOrigin, sendCreateDislikeToVideoFollowers } from './send/send-create'
+import { sendLikeToVideoFollowers } from './send/send-like'
+import {
+  sendUndoDislikeToOrigin,
+  sendUndoDislikeToVideoFollowers,
+  sendUndoLikeToOrigin,
+  sendUndoLikeToVideoFollowers
+} from './send/send-undo'
 
 function fetchRemoteVideoPreview (video: VideoInstance) {
   // FIXME: use url
@@ -37,8 +48,50 @@ function generateThumbnailFromUrl (video: VideoInstance, icon: ActivityIconObjec
   return doRequestAndSaveToFile(options, thumbnailPath)
 }
 
+async function sendVideoRateChangeToFollowers (
+  account: AccountInstance,
+  video: VideoInstance,
+  likes: number,
+  dislikes: number,
+  t: Transaction
+) {
+  // Keep the order: first we undo and then we create
+
+  // Undo Like
+  if (likes < 0) await sendUndoLikeToVideoFollowers(account, video, t)
+  // Undo Dislike
+  if (dislikes < 0) await sendUndoDislikeToVideoFollowers(account, video, t)
+
+  // Like
+  if (likes > 0) await sendLikeToVideoFollowers(account, video, t)
+  // Dislike
+  if (dislikes > 0) await sendCreateDislikeToVideoFollowers(account, video, t)
+}
+
+async function sendVideoRateChangeToOrigin (
+  account: AccountInstance,
+  video: VideoInstance,
+  likes: number,
+  dislikes: number,
+  t: Transaction
+) {
+  // Keep the order: first we undo and then we create
+
+  // Undo Like
+  if (likes < 0) await sendUndoLikeToOrigin(account, video, t)
+  // Undo Dislike
+  if (dislikes < 0) await sendUndoDislikeToOrigin(account, video, t)
+
+  // Like
+  if (likes > 0) await sendLikeToOrigin(account, video, t)
+  // Dislike
+  if (dislikes > 0) await sendCreateDislikeToOrigin(account, video, t)
+}
+
 export {
   fetchRemoteVideoPreview,
   fetchRemoteVideoDescription,
-  generateThumbnailFromUrl
+  generateThumbnailFromUrl,
+  sendVideoRateChangeToFollowers,
+  sendVideoRateChangeToOrigin
 }