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
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
}