@include miniature-rows;
padding-top: 0 !important;
+
+ .section-title {
+ align-items: center;
+ }
}
-import { UserRight, VideoConstant, VideoDetails as VideoDetailsServerModel, VideoFile, VideoState } from '../../../../../shared'
-import { AuthUser } from '../../core'
+import { VideoConstant, VideoDetails as VideoDetailsServerModel, VideoFile, VideoState } from '../../../../../shared'
import { Video } from '../../shared/video/video.model'
import { Account } from '@app/shared/account/account.model'
import { VideoChannel } from '@app/shared/video-channel/video-channel.model'
account: {
id: number
- uuid: string
name: string
displayName: string
url: string
channel: {
id: number
- uuid: string
name: string
displayName: string
url: string
if (!comment) return
if (typeof comment.url !== 'string') {
- comment.url = comment.url.href || comment.url.url
+ if (typeof comment.url === 'object') comment.url = comment.url.href || comment.url.url
+ else comment.url = comment.id
}
return
let i = 0
let nextLink = firstBody.first
while (nextLink && i < limit) {
- // Don't crawl ourselves
- const remoteHost = parse(nextLink).host
- if (remoteHost === WEBSERVER.HOST) continue
+ let body: any
- options.uri = nextLink
+ if (typeof nextLink === 'string') {
+ // Don't crawl ourselves
+ const remoteHost = parse(nextLink).host
+ if (remoteHost === WEBSERVER.HOST) continue
+
+ options.uri = nextLink
+
+ const res = await doRequest<ActivityPubOrderedCollection<T>>(options)
+ body = res.body
+ } else {
+ // nextLink is already the object we want
+ body = nextLink
+ }
- const { body } = await doRequest<ActivityPubOrderedCollection<T>>(options)
nextLink = body.next
i++
import { VideoShareModel } from '../../../models/video/video-share'
import { forwardVideoRelatedActivity } from '../send/utils'
import { getOrCreateVideoAndAccountAndChannel } from '../videos'
-import { VideoPrivacy } from '../../../../shared/models/videos'
import { Notifier } from '../../notifier'
+import { VideoModel } from '../../../models/video/video'
+import { logger } from '../../../helpers/logger'
async function processAnnounceActivity (activity: ActivityAnnounce, actorAnnouncer: ActorModel) {
return retryTransactionWrapper(processVideoShare, actorAnnouncer, activity)
async function processVideoShare (actorAnnouncer: ActorModel, activity: ActivityAnnounce) {
const objectUri = typeof activity.object === 'string' ? activity.object : activity.object.id
- const { video, created: videoCreated } = await getOrCreateVideoAndAccountAndChannel({ videoObject: objectUri })
+ let video: VideoModel
+ let videoCreated: boolean
+
+ try {
+ const result = await getOrCreateVideoAndAccountAndChannel({ videoObject: objectUri })
+ video = result.video
+ videoCreated = result.created
+ } catch (err) {
+ logger.debug('Cannot process share of %s. Maybe this is not a video object, so just skipping.', objectUri, { err })
+ return
+ }
await sequelizeTypescript.transaction(async t => {
// Add share entry
import { processFlagActivity } from './process-flag'
import { PlaylistObject } from '../../../../shared/models/activitypub/objects/playlist-object'
import { createOrUpdateVideoPlaylist } from '../playlist'
+import { VideoModel } from '../../../models/video/video'
async function processCreateActivity (activity: ActivityCreate, byActor: ActorModel) {
const activityObject = activity.object
if (!byAccount) throw new Error('Cannot create video comment with the non account actor ' + byActor.url)
- const { video } = await resolveThread(commentObject.inReplyTo)
+ let video: VideoModel
+ try {
+ const resolveThreadResult = await resolveThread(commentObject.inReplyTo)
+ video = resolveThreadResult.video
+ } catch (err) {
+ logger.debug(
+ 'Cannot process video comment because we could not resolve thread %s. Maybe it was not a video thread, so skip it.',
+ commentObject.inReplyTo,
+ { err }
+ )
+ }
const { comment, created } = await addVideoComment(video, commentObject.id)
return { comment, created }
}
-async function resolveThread (url: string, comments: VideoCommentModel[] = []) {
+type ResolveThreadResult = Promise<{ video: VideoModel, parents: VideoCommentModel[] }>
+async function resolveThread (url: string, comments: VideoCommentModel[] = []): ResolveThreadResult {
// Already have this comment?
const commentFromDatabase = await VideoCommentModel.loadByUrlAndPopulateReplyAndVideo(url)
if (commentFromDatabase) {
return resolveThread(body.inReplyTo, comments.concat([ comment ]))
}
-
}
export {