2017-12-28 10:16:08 +00:00
|
|
|
import { logger } from '../../../helpers/logger'
|
|
|
|
import { doRequest } from '../../../helpers/requests'
|
2018-01-11 08:35:50 +00:00
|
|
|
import { ActorFollowModel } from '../../../models/activitypub/actor-follow'
|
2017-12-19 09:34:56 +00:00
|
|
|
import { ActivityPubHttpPayload, buildSignedRequestOptions, computeBody, maybeRetryRequestLater } from './activitypub-http-job-scheduler'
|
2017-11-17 10:35:10 +00:00
|
|
|
|
|
|
|
async function process (payload: ActivityPubHttpPayload, jobId: number) {
|
|
|
|
logger.info('Processing ActivityPub unicast in job %d.', jobId)
|
|
|
|
|
2018-01-12 09:02:11 +00:00
|
|
|
const uri = payload.uris[0]
|
|
|
|
|
2017-11-24 12:41:10 +00:00
|
|
|
const body = await computeBody(payload)
|
2017-12-19 09:34:56 +00:00
|
|
|
const httpSignatureOptions = await buildSignedRequestOptions(payload)
|
2017-11-17 10:35:10 +00:00
|
|
|
|
|
|
|
const options = {
|
|
|
|
method: 'POST',
|
|
|
|
uri,
|
2017-12-19 09:34:56 +00:00
|
|
|
json: body,
|
|
|
|
httpSignature: httpSignatureOptions
|
2017-11-17 10:35:10 +00:00
|
|
|
}
|
|
|
|
|
2017-11-23 13:19:55 +00:00
|
|
|
try {
|
|
|
|
await doRequest(options)
|
2018-01-11 10:40:18 +00:00
|
|
|
ActorFollowModel.updateActorFollowsScoreAndRemoveBadOnes([ uri ], [], undefined)
|
2017-11-23 13:19:55 +00:00
|
|
|
} catch (err) {
|
2018-01-11 08:35:50 +00:00
|
|
|
const isRetryingLater = await maybeRetryRequestLater(err, payload, uri)
|
|
|
|
if (isRetryingLater === false) {
|
2018-01-11 10:40:18 +00:00
|
|
|
ActorFollowModel.updateActorFollowsScoreAndRemoveBadOnes([], [ uri ], undefined)
|
2018-01-11 08:35:50 +00:00
|
|
|
}
|
|
|
|
|
2017-11-23 13:19:55 +00:00
|
|
|
throw err
|
|
|
|
}
|
2017-11-17 10:35:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function onError (err: Error, jobId: number) {
|
|
|
|
logger.error('Error when sending ActivityPub request in job %d.', jobId, err)
|
|
|
|
return Promise.resolve()
|
|
|
|
}
|
|
|
|
|
|
|
|
function onSuccess (jobId: number) {
|
|
|
|
logger.info('Job %d is a success.', jobId)
|
|
|
|
return Promise.resolve()
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
export {
|
|
|
|
process,
|
|
|
|
onError,
|
|
|
|
onSuccess
|
|
|
|
}
|