1
0
Fork 0
peertube/server/helpers/activitypub.ts

116 lines
2.9 KiB
TypeScript
Raw Normal View History

2017-12-12 11:53:50 -05:00
import { ResultList } from '../../shared/models'
import { Activity, ActivityPubActor } from '../../shared/models/activitypub'
2017-12-12 11:53:50 -05:00
import { ACTIVITY_PUB } from '../initializers'
2017-12-14 11:38:41 -05:00
import { ActorModel } from '../models/activitypub/actor'
2017-11-17 05:35:10 -05:00
import { signObject } from './peertube-crypto'
2017-11-10 11:27:49 -05:00
function activityPubContextify <T> (data: T) {
2017-11-09 11:51:58 -05:00
return Object.assign(data,{
'@context': [
'https://www.w3.org/ns/activitystreams',
'https://w3id.org/security/v1',
{
2017-12-18 05:53:04 -05:00
'RsaSignature2017': 'https://w3id.org/security#RsaSignature2017',
2017-11-09 11:51:58 -05:00
'Hashtag': 'as:Hashtag',
'uuid': 'http://schema.org/identifier',
'category': 'http://schema.org/category',
'licence': 'http://schema.org/license',
'sensitive': 'as:sensitive',
2017-11-09 11:51:58 -05:00
'language': 'http://schema.org/inLanguage',
'views': 'http://schema.org/Number',
'size': 'http://schema.org/Number',
'commentsEnabled': 'http://schema.org/Boolean',
'support': 'http://schema.org/Text'
2018-01-29 05:05:52 -05:00
},
{
likes: {
'@id': 'as:likes',
'@type': '@id'
},
dislikes: {
'@id': 'as:dislikes',
'@type': '@id'
},
shares: {
'@id': 'as:shares',
'@type': '@id'
},
comments: {
'@id': 'as:comments',
'@type': '@id'
}
2017-11-09 11:51:58 -05:00
}
]
})
}
function activityPubCollection (url: string, results: any[]) {
2017-11-23 10:55:13 -05:00
return {
id: url,
2017-11-23 10:55:13 -05:00
type: 'OrderedCollection',
totalItems: results.length,
orderedItems: results
}
}
function activityPubCollectionPagination (url: string, page: any, result: ResultList<any>) {
2017-11-21 12:23:10 -05:00
let next: string
let prev: string
// Assert page is a number
page = parseInt(page, 10)
2017-11-21 12:23:10 -05:00
// There are more results
if (result.total > page * ACTIVITY_PUB.COLLECTION_ITEMS_PER_PAGE) {
2017-11-21 12:23:10 -05:00
next = url + '?page=' + (page + 1)
}
if (page > 1) {
prev = url + '?page=' + (page - 1)
}
const orderedCollectionPagination = {
id: url + '?page=' + page,
type: 'OrderedCollectionPage',
prev,
next,
partOf: url,
orderedItems: result.data
}
2017-11-09 11:51:58 -05:00
2017-11-22 04:29:55 -05:00
if (page === 1) {
return activityPubContextify({
id: url,
type: 'OrderedCollection',
totalItems: result.total,
first: orderedCollectionPagination
})
} else {
orderedCollectionPagination['totalItems'] = result.total
2017-11-09 11:51:58 -05:00
}
2017-11-22 04:29:55 -05:00
return orderedCollectionPagination
2017-11-09 11:51:58 -05:00
}
2017-12-14 11:38:41 -05:00
function buildSignedActivity (byActor: ActorModel, data: Object) {
2017-11-17 05:35:10 -05:00
const activity = activityPubContextify(data)
2017-12-14 11:38:41 -05:00
return signObject(byActor, activity) as Promise<Activity>
2017-11-17 05:35:10 -05:00
}
function getActorUrl (activityActor: string | ActivityPubActor) {
if (typeof activityActor === 'string') return activityActor
return activityActor.id
}
2017-11-09 11:51:58 -05:00
// ---------------------------------------------------------------------------
export {
getActorUrl,
2017-11-09 11:51:58 -05:00
activityPubContextify,
2017-11-10 08:34:45 -05:00
activityPubCollectionPagination,
2017-11-23 10:55:13 -05:00
activityPubCollection,
buildSignedActivity
2017-11-09 11:51:58 -05:00
}