X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Factivitypub.ts;h=e0754b501b2ce39729997c298942c20a81f9fb89;hb=71de85be3beb5f5181e6338b1a7154c8cf65afd4;hp=239d8291d8ef9936b4cb183f020eec0c45f44546;hpb=fbc77eb648bda9add4634c08dbb6af48c3670b5d;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/activitypub.ts b/server/helpers/activitypub.ts index 239d8291d..e0754b501 100644 --- a/server/helpers/activitypub.ts +++ b/server/helpers/activitypub.ts @@ -1,22 +1,35 @@ import * as Bluebird from 'bluebird' +import { URL } from 'url' import validator from 'validator' +import { ContextType } from '@shared/models/activitypub/context' import { ResultList } from '../../shared/models' -import { Activity } from '../../shared/models/activitypub' -import { ACTIVITY_PUB } from '../initializers/constants' -import { signJsonLDObject } from './peertube-crypto' +import { ACTIVITY_PUB, REMOTE_SCHEME } from '../initializers/constants' +import { MActor, MVideoWithHost } from '../types/models' import { pageToStartAndCount } from './core-utils' -import { parse } from 'url' -import { MActor } from '../typings/models' - -function activityPubContextify (data: T) { - return Object.assign(data, { - '@context': [ - 'https://www.w3.org/ns/activitystreams', - 'https://w3id.org/security/v1', - { - RsaSignature2017: 'https://w3id.org/security#RsaSignature2017', - pt: 'https://joinpeertube.org/ns#', - sc: 'http://schema.org#', +import { signJsonLDObject } from './peertube-crypto' + +function getContextData (type: ContextType) { + const context: any[] = [ + 'https://www.w3.org/ns/activitystreams', + 'https://w3id.org/security/v1', + { + RsaSignature2017: 'https://w3id.org/security#RsaSignature2017' + } + ] + + if (type !== 'View' && type !== 'Announce') { + const additional = { + pt: 'https://joinpeertube.org/ns#', + sc: 'http://schema.org#' + } + + if (type === 'CacheFile') { + Object.assign(additional, { + expires: 'sc:expires', + CacheFile: 'pt:CacheFile' + }) + } else { + Object.assign(additional, { Hashtag: 'as:Hashtag', uuid: 'sc:identifier', category: 'sc:category', @@ -24,9 +37,21 @@ function activityPubContextify (data: T) { subtitleLanguage: 'sc:subtitleLanguage', sensitive: 'as:sensitive', language: 'sc:inLanguage', - expires: 'sc:expires', - CacheFile: 'pt:CacheFile', + + isLiveBroadcast: 'sc:isLiveBroadcast', + liveSaveReplay: { + '@type': 'sc:Boolean', + '@id': 'pt:liveSaveReplay' + }, + permanentLive: { + '@type': 'sc:Boolean', + '@id': 'pt:permanentLive' + }, + Infohash: 'pt:Infohash', + Playlist: 'pt:Playlist', + PlaylistElement: 'pt:PlaylistElement', + originallyPublishedAt: 'sc:datePublished', views: { '@type': 'sc:Number', @@ -71,9 +96,7 @@ function activityPubContextify (data: T) { support: { '@type': 'sc:Text', '@id': 'pt:support' - } - }, - { + }, likes: { '@id': 'as:likes', '@type': '@id' @@ -94,9 +117,19 @@ function activityPubContextify (data: T) { '@id': 'as:comments', '@type': '@id' } - } - ] - }) + }) + } + + context.push(additional) + } + + return { + '@context': context + } +} + +function activityPubContextify (data: T, type: ContextType = 'All') { + return Object.assign({}, data, getContextData(type)) } type ActivityPubCollectionPaginationHandler = (start: number, count: number) => Bluebird> | Promise> @@ -148,10 +181,10 @@ async function activityPubCollectionPagination ( } -function buildSignedActivity (byActor: MActor, data: Object) { - const activity = activityPubContextify(data) +function buildSignedActivity (byActor: MActor, data: T, contextType?: ContextType) { + const activity = activityPubContextify(data, contextType) - return signJsonLDObject(byActor, activity) as Promise + return signJsonLDObject(byActor, activity) } function getAPId (activity: string | { id: string }) { @@ -161,12 +194,20 @@ function getAPId (activity: string | { id: string }) { } function checkUrlsSameHost (url1: string, url2: string) { - const idHost = parse(url1).host - const actorHost = parse(url2).host + const idHost = new URL(url1).host + const actorHost = new URL(url2).host return idHost && actorHost && idHost.toLowerCase() === actorHost.toLowerCase() } +function buildRemoteVideoBaseUrl (video: MVideoWithHost, path: string, scheme?: string) { + if (!scheme) scheme = REMOTE_SCHEME.HTTP + + const host = video.VideoChannel.Actor.Server.host + + return scheme + '://' + host + path +} + // --------------------------------------------------------------------------- export { @@ -174,5 +215,6 @@ export { getAPId, activityPubContextify, activityPubCollectionPagination, - buildSignedActivity + buildSignedActivity, + buildRemoteVideoBaseUrl }