aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/lib
diff options
context:
space:
mode:
Diffstat (limited to 'server/lib')
-rw-r--r--server/lib/activitypub/videos/shared/video-sync-attributes.ts87
1 files changed, 50 insertions, 37 deletions
diff --git a/server/lib/activitypub/videos/shared/video-sync-attributes.ts b/server/lib/activitypub/videos/shared/video-sync-attributes.ts
index 181893c68..c1318abf7 100644
--- a/server/lib/activitypub/videos/shared/video-sync-attributes.ts
+++ b/server/lib/activitypub/videos/shared/video-sync-attributes.ts
@@ -10,8 +10,6 @@ import { addVideoShares } from '../../share'
10import { addVideoComments } from '../../video-comments' 10import { addVideoComments } from '../../video-comments'
11import { createRates } from '../../video-rates' 11import { createRates } from '../../video-rates'
12 12
13import Bluebird = require('bluebird')
14
15type SyncParam = { 13type SyncParam = {
16 likes: boolean 14 likes: boolean
17 dislikes: boolean 15 dislikes: boolean
@@ -24,52 +22,67 @@ type SyncParam = {
24async function syncVideoExternalAttributes (video: MVideo, fetchedVideo: VideoObject, syncParam: SyncParam) { 22async function syncVideoExternalAttributes (video: MVideo, fetchedVideo: VideoObject, syncParam: SyncParam) {
25 logger.info('Adding likes/dislikes/shares/comments of video %s.', video.uuid) 23 logger.info('Adding likes/dislikes/shares/comments of video %s.', video.uuid)
26 24
27 const jobPayloads: ActivitypubHttpFetcherPayload[] = [] 25 await syncRates('like', video, fetchedVideo, syncParam.likes)
26 await syncRates('dislike', video, fetchedVideo, syncParam.dislikes)
28 27
29 if (syncParam.likes === true) { 28 await syncShares(video, fetchedVideo, syncParam.shares)
30 const handler = items => createRates(items, video, 'like')
31 const cleaner = crawlStartDate => AccountVideoRateModel.cleanOldRatesOf(video.id, 'like' as 'like', crawlStartDate)
32 29
33 await crawlCollectionPage<string>(fetchedVideo.likes, handler, cleaner) 30 await syncComments(video, fetchedVideo, syncParam.comments)
34 .catch(err => logger.error('Cannot add likes of video %s.', video.uuid, { err, rootUrl: fetchedVideo.likes })) 31}
35 } else {
36 jobPayloads.push({ uri: fetchedVideo.likes, videoId: video.id, type: 'video-likes' as 'video-likes' })
37 }
38 32
39 if (syncParam.dislikes === true) { 33// ---------------------------------------------------------------------------
40 const handler = items => createRates(items, video, 'dislike')
41 const cleaner = crawlStartDate => AccountVideoRateModel.cleanOldRatesOf(video.id, 'dislike' as 'dislike', crawlStartDate)
42 34
43 await crawlCollectionPage<string>(fetchedVideo.dislikes, handler, cleaner) 35export {
44 .catch(err => logger.error('Cannot add dislikes of video %s.', video.uuid, { err, rootUrl: fetchedVideo.dislikes })) 36 SyncParam,
45 } else { 37 syncVideoExternalAttributes
46 jobPayloads.push({ uri: fetchedVideo.dislikes, videoId: video.id, type: 'video-dislikes' as 'video-dislikes' }) 38}
47 } 39
40// ---------------------------------------------------------------------------
41
42function createJob (payload: ActivitypubHttpFetcherPayload) {
43 return JobQueue.Instance.createJobWithPromise({ type: 'activitypub-http-fetcher', payload })
44}
48 45
49 if (syncParam.shares === true) { 46function syncRates (type: 'like' | 'dislike', video: MVideo, fetchedVideo: VideoObject, isSync: boolean) {
50 const handler = items => addVideoShares(items, video) 47 const uri = type === 'like'
51 const cleaner = crawlStartDate => VideoShareModel.cleanOldSharesOf(video.id, crawlStartDate) 48 ? fetchedVideo.likes
49 : fetchedVideo.dislikes
52 50
53 await crawlCollectionPage<string>(fetchedVideo.shares, handler, cleaner) 51 if (!isSync) {
54 .catch(err => logger.error('Cannot add shares of video %s.', video.uuid, { err, rootUrl: fetchedVideo.shares })) 52 const jobType = type === 'like'
55 } else { 53 ? 'video-likes'
56 jobPayloads.push({ uri: fetchedVideo.shares, videoId: video.id, type: 'video-shares' as 'video-shares' }) 54 : 'video-dislikes'
55
56 return createJob({ uri, videoId: video.id, type: jobType })
57 } 57 }
58 58
59 if (syncParam.comments === true) { 59 const handler = items => createRates(items, video, type)
60 const handler = items => addVideoComments(items) 60 const cleaner = crawlStartDate => AccountVideoRateModel.cleanOldRatesOf(video.id, type, crawlStartDate)
61 const cleaner = crawlStartDate => VideoCommentModel.cleanOldCommentsOf(video.id, crawlStartDate) 61
62 return crawlCollectionPage<string>(uri, handler, cleaner)
63 .catch(err => logger.error('Cannot add rate of video %s.', video.uuid, { err, rootUrl: uri }))
64}
62 65
63 await crawlCollectionPage<string>(fetchedVideo.comments, handler, cleaner) 66function syncShares (video: MVideo, fetchedVideo: VideoObject, isSync: boolean) {
64 .catch(err => logger.error('Cannot add comments of video %s.', video.uuid, { err, rootUrl: fetchedVideo.comments })) 67 if (!isSync) {
65 } else { 68 return createJob({ uri: fetchedVideo.shares, videoId: video.id, type: 'video-shares' })
66 jobPayloads.push({ uri: fetchedVideo.comments, videoId: video.id, type: 'video-comments' as 'video-comments' })
67 } 69 }
68 70
69 await Bluebird.map(jobPayloads, payload => JobQueue.Instance.createJobWithPromise({ type: 'activitypub-http-fetcher', payload })) 71 const handler = items => addVideoShares(items, video)
72 const cleaner = crawlStartDate => VideoShareModel.cleanOldSharesOf(video.id, crawlStartDate)
73
74 return crawlCollectionPage<string>(fetchedVideo.shares, handler, cleaner)
75 .catch(err => logger.error('Cannot add shares of video %s.', video.uuid, { err, rootUrl: fetchedVideo.shares }))
70} 76}
71 77
72export { 78function syncComments (video: MVideo, fetchedVideo: VideoObject, isSync: boolean) {
73 SyncParam, 79 if (!isSync) {
74 syncVideoExternalAttributes 80 return createJob({ uri: fetchedVideo.comments, videoId: video.id, type: 'video-comments' })
81 }
82
83 const handler = items => addVideoComments(items)
84 const cleaner = crawlStartDate => VideoCommentModel.cleanOldCommentsOf(video.id, crawlStartDate)
85
86 return crawlCollectionPage<string>(fetchedVideo.comments, handler, cleaner)
87 .catch(err => logger.error('Cannot add comments of video %s.', video.uuid, { err, rootUrl: fetchedVideo.comments }))
75} 88}