-function generateThumbnailFromUrl (video: VideoInstance, 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)
-}
-
-async function shareVideoChannelByServer (videoChannel: VideoChannelInstance, t: Sequelize.Transaction) {
- const serverAccount = await getServerAccount()
-
- await db.VideoChannelShare.create({
- accountId: serverAccount.id,
- videoChannelId: videoChannel.id
- }, { transaction: t })
-
- return sendVideoChannelAnnounce(serverAccount, videoChannel, t)
-}
-
-async function shareVideoByServer (video: VideoInstance, t: Sequelize.Transaction) {
- const serverAccount = await getServerAccount()
-
- await db.VideoShare.create({
- accountId: serverAccount.id,
- videoId: video.id
- }, { transaction: t })
-
- return sendVideoAnnounce(serverAccount, video, t)
-}
-
-function getActivityPubUrl (type: 'video' | 'videoChannel' | 'account' | 'videoAbuse', id: string) {
- if (type === 'video') return CONFIG.WEBSERVER.URL + '/videos/watch/' + id
- else if (type === 'videoChannel') return CONFIG.WEBSERVER.URL + '/video-channels/' + id
- else if (type === 'account') return CONFIG.WEBSERVER.URL + '/account/' + id
- else if (type === 'videoAbuse') return CONFIG.WEBSERVER.URL + '/admin/video-abuses/' + id
-
- return ''
-}
-
-async function getOrCreateAccount (accountUrl: string) {
- let account = await db.Account.loadByUrl(accountUrl)
-
- // We don't have this account in our database, fetch it on remote
- if (!account) {
- const res = await fetchRemoteAccountAndCreateServer(accountUrl)
- if (res === undefined) throw new Error('Cannot fetch remote account.')
-
- // Save our new account in database
- account = await res.account.save()
- }
-
- return account
-}
-
-async function getOrCreateVideoChannel (ownerAccount: AccountInstance, videoChannelUrl: string) {
- let videoChannel = await db.VideoChannel.loadByUrl(videoChannelUrl)
-
- // We don't have this account in our database, fetch it on remote
- if (!videoChannel) {
- videoChannel = await fetchRemoteVideoChannel(ownerAccount, videoChannelUrl)
- if (videoChannel === undefined) throw new Error('Cannot fetch remote video channel.')
-
- // Save our new video channel in database
- await videoChannel.save()
- }
-
- return videoChannel
+function activityPubContextify <T> (data: T) {
+ return Object.assign(data, {
+ '@context': [
+ 'https://www.w3.org/ns/activitystreams',
+ 'https://w3id.org/security/v1',
+ {
+ RsaSignature2017: 'https://w3id.org/security#RsaSignature2017',
+ Hashtag: 'as:Hashtag',
+ uuid: 'http://schema.org/identifier',
+ category: 'http://schema.org/category',
+ licence: 'http://schema.org/license',
+ subtitleLanguage: 'http://schema.org/subtitleLanguage',
+ sensitive: 'as:sensitive',
+ language: 'http://schema.org/inLanguage',
+ views: 'http://schema.org/Number',
+ stats: 'http://schema.org/Number',
+ size: 'http://schema.org/Number',
+ fps: 'http://schema.org/Number',
+ commentsEnabled: 'http://schema.org/Boolean',
+ waitTranscoding: 'http://schema.org/Boolean',
+ support: 'http://schema.org/Text'
+ },
+ {
+ likes: {
+ '@id': 'as:likes',
+ '@type': '@id'
+ },
+ dislikes: {
+ '@id': 'as:dislikes',
+ '@type': '@id'
+ },
+ shares: {
+ '@id': 'as:shares',
+ '@type': '@id'
+ },
+ comments: {
+ '@id': 'as:comments',
+ '@type': '@id'
+ }
+ }
+ ]
+ })