2020-02-03 04:12:29 -06:00
|
|
|
import { buildSignedActivity, ContextType } from '../../../../helpers/activitypub'
|
2018-01-25 08:05:18 -06:00
|
|
|
import { getServerActor } from '../../../../helpers/utils'
|
|
|
|
import { ActorModel } from '../../../../models/activitypub/actor'
|
2018-10-10 01:51:58 -05:00
|
|
|
import { sha256 } from '../../../../helpers/core-utils'
|
2020-03-12 08:14:00 -05:00
|
|
|
import { ACTIVITY_PUB, HTTP_SIGNATURE } from '../../../../initializers/constants'
|
2019-08-15 04:53:26 -05:00
|
|
|
import { MActor } from '../../../../typings/models'
|
2018-01-25 08:05:18 -06:00
|
|
|
|
2020-02-03 04:12:29 -06:00
|
|
|
type Payload = { body: any, contextType?: ContextType, signatureActorId?: number }
|
2018-10-10 01:51:58 -05:00
|
|
|
|
|
|
|
async function computeBody (payload: Payload) {
|
2018-01-25 08:05:18 -06:00
|
|
|
let body = payload.body
|
|
|
|
|
|
|
|
if (payload.signatureActorId) {
|
|
|
|
const actorSignature = await ActorModel.load(payload.signatureActorId)
|
|
|
|
if (!actorSignature) throw new Error('Unknown signature actor id.')
|
2020-02-03 04:12:29 -06:00
|
|
|
body = await buildSignedActivity(actorSignature, payload.body, payload.contextType)
|
2018-01-25 08:05:18 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
return body
|
|
|
|
}
|
|
|
|
|
2018-10-10 01:51:58 -05:00
|
|
|
async function buildSignedRequestOptions (payload: Payload) {
|
2019-08-15 04:53:26 -05:00
|
|
|
let actor: MActor | null
|
|
|
|
|
2018-01-25 08:05:18 -06:00
|
|
|
if (payload.signatureActorId) {
|
|
|
|
actor = await ActorModel.load(payload.signatureActorId)
|
|
|
|
if (!actor) throw new Error('Unknown signature actor id.')
|
|
|
|
} else {
|
|
|
|
// We need to sign the request, so use the server
|
|
|
|
actor = await getServerActor()
|
|
|
|
}
|
|
|
|
|
2019-04-25 08:19:53 -05:00
|
|
|
const keyId = actor.url
|
2018-01-25 08:05:18 -06:00
|
|
|
return {
|
2018-10-19 04:41:19 -05:00
|
|
|
algorithm: HTTP_SIGNATURE.ALGORITHM,
|
|
|
|
authorizationHeaderName: HTTP_SIGNATURE.HEADER_NAME,
|
2018-01-25 08:05:18 -06:00
|
|
|
keyId,
|
2018-10-10 01:51:58 -05:00
|
|
|
key: actor.privateKey,
|
2018-10-19 04:41:19 -05:00
|
|
|
headers: HTTP_SIGNATURE.HEADERS_TO_SIGN
|
2018-10-10 01:51:58 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-23 04:38:48 -05:00
|
|
|
function buildGlobalHeaders (body: any) {
|
2018-10-10 01:51:58 -05:00
|
|
|
return {
|
2020-03-12 08:14:00 -05:00
|
|
|
'Digest': buildDigest(body),
|
|
|
|
'Content-Type': 'application/activity+json',
|
|
|
|
'Accept': ACTIVITY_PUB.ACCEPT_HEADER
|
2018-01-25 08:05:18 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-23 04:38:48 -05:00
|
|
|
function buildDigest (body: any) {
|
|
|
|
const rawBody = typeof body === 'string' ? body : JSON.stringify(body)
|
|
|
|
|
|
|
|
return 'SHA-256=' + sha256(rawBody, 'base64')
|
|
|
|
}
|
|
|
|
|
2018-01-25 08:05:18 -06:00
|
|
|
export {
|
2018-10-23 04:38:48 -05:00
|
|
|
buildDigest,
|
2018-10-10 01:51:58 -05:00
|
|
|
buildGlobalHeaders,
|
2018-01-25 08:05:18 -06:00
|
|
|
computeBody,
|
|
|
|
buildSignedRequestOptions
|
|
|
|
}
|