PeerTube/server/lib/activitypub/videos.ts

99 lines
2.8 KiB
TypeScript
Raw Normal View History

import { join } from 'path'
import * as request from 'request'
2017-11-23 14:19:55 +01:00
import { Transaction } from 'sequelize'
import { ActivityIconObject } from '../../../shared/index'
2017-12-12 17:53:50 +01:00
import { doRequest, doRequestAndSaveToFile } from '../../helpers'
import { CONFIG, REMOTE_SCHEME, STATIC_PATHS } from '../../initializers'
import { AccountModel } from '../../models/account/account'
import { VideoModel } from '../../models/video/video'
2017-11-23 14:19:55 +01:00
import {
2017-12-12 17:53:50 +01:00
sendCreateDislikeToOrigin,
sendCreateDislikeToVideoFollowers,
sendLikeToOrigin,
sendLikeToVideoFollowers,
2017-11-23 14:19:55 +01:00
sendUndoDislikeToOrigin,
sendUndoDislikeToVideoFollowers,
sendUndoLikeToOrigin,
sendUndoLikeToVideoFollowers
2017-12-12 17:53:50 +01:00
} from './send'
2017-12-12 17:53:50 +01:00
function fetchRemoteVideoPreview (video: VideoModel) {
// FIXME: use url
const host = video.VideoChannel.Account.Server.host
const path = join(STATIC_PATHS.PREVIEWS, video.getPreviewName())
return request.get(REMOTE_SCHEME.HTTP + '://' + host + path)
}
2017-12-12 17:53:50 +01:00
async function fetchRemoteVideoDescription (video: VideoModel) {
// FIXME: use url
const host = video.VideoChannel.Account.Server.host
const path = video.getDescriptionPath()
const options = {
uri: REMOTE_SCHEME.HTTP + '://' + host + path,
json: true
}
const { body } = await doRequest(options)
return body.description ? body.description : ''
}
2017-12-12 17:53:50 +01:00
function generateThumbnailFromUrl (video: VideoModel, icon: ActivityIconObject) {
const thumbnailName = video.getThumbnailName()
const thumbnailPath = join(CONFIG.STORAGE.THUMBNAILS_DIR, thumbnailName)
const options = {
method: 'GET',
uri: icon.url
}
return doRequestAndSaveToFile(options, thumbnailPath)
}
2017-11-30 13:51:53 +01:00
async function sendVideoRateChangeToFollowers (
2017-12-12 17:53:50 +01:00
account: AccountModel,
video: VideoModel,
2017-11-30 13:51:53 +01:00
likes: number,
dislikes: number,
t: Transaction
) {
// Keep the order: first we undo and then we create
2017-11-23 14:19:55 +01:00
// Undo Like
2017-11-30 13:51:53 +01:00
if (likes < 0) await sendUndoLikeToVideoFollowers(account, video, t)
2017-11-23 14:19:55 +01:00
// Undo Dislike
2017-11-30 13:51:53 +01:00
if (dislikes < 0) await sendUndoDislikeToVideoFollowers(account, video, t)
2017-11-23 14:19:55 +01:00
2017-11-30 13:51:53 +01:00
// Like
if (likes > 0) await sendLikeToVideoFollowers(account, video, t)
// Dislike
if (dislikes > 0) await sendCreateDislikeToVideoFollowers(account, video, t)
2017-11-23 14:19:55 +01:00
}
2017-11-30 13:51:53 +01:00
async function sendVideoRateChangeToOrigin (
2017-12-12 17:53:50 +01:00
account: AccountModel,
video: VideoModel,
2017-11-30 13:51:53 +01:00
likes: number,
dislikes: number,
t: Transaction
) {
// Keep the order: first we undo and then we create
2017-11-23 14:19:55 +01:00
// Undo Like
2017-11-30 13:51:53 +01:00
if (likes < 0) await sendUndoLikeToOrigin(account, video, t)
2017-11-23 14:19:55 +01:00
// Undo Dislike
2017-11-30 13:51:53 +01:00
if (dislikes < 0) await sendUndoDislikeToOrigin(account, video, t)
2017-11-23 14:19:55 +01:00
2017-11-30 13:51:53 +01:00
// Like
if (likes > 0) await sendLikeToOrigin(account, video, t)
// Dislike
if (dislikes > 0) await sendCreateDislikeToOrigin(account, video, t)
2017-11-23 14:19:55 +01:00
}
export {
fetchRemoteVideoPreview,
fetchRemoteVideoDescription,
2017-11-23 14:19:55 +01:00
generateThumbnailFromUrl,
sendVideoRateChangeToFollowers,
sendVideoRateChangeToOrigin
}