PeerTube/server/lib/job-queue/handlers/activitypub-http-fetcher.ts

64 lines
1.8 KiB
TypeScript
Raw Normal View History

import * as kue from 'kue'
2017-12-28 04:16:08 -06:00
import { logger } from '../../../helpers/logger'
import { doRequest } from '../../../helpers/requests'
2017-12-12 10:53:50 -06:00
import { ACTIVITY_PUB } from '../../../initializers'
import { processActivities } from '../../activitypub/process'
import { ActivitypubHttpBroadcastPayload } from './activitypub-http-broadcast'
2017-11-22 03:29:55 -06:00
export type ActivitypubHttpFetcherPayload = {
uris: string[]
}
async function processActivityPubHttpFetcher (job: kue.Job) {
logger.info('Processing ActivityPub fetcher in job %d.', job.id)
const payload = job.data as ActivitypubHttpBroadcastPayload
2017-11-22 03:29:55 -06:00
const options = {
method: 'GET',
uri: '',
2017-12-28 04:16:08 -06:00
json: true,
activityPub: true
2017-11-22 03:29:55 -06:00
}
for (const uri of payload.uris) {
options.uri = uri
logger.info('Fetching ActivityPub data on %s.', uri)
const response = await doRequest(options)
const firstBody = response.body
if (firstBody.first && Array.isArray(firstBody.first.orderedItems)) {
const activities = firstBody.first.orderedItems
logger.info('Processing %i items ActivityPub fetcher for %s.', activities.length, options.uri)
2017-11-22 03:29:55 -06:00
await processActivities(activities)
}
let limit = ACTIVITY_PUB.FETCH_PAGE_LIMIT
let i = 0
let nextLink = firstBody.first.next
while (nextLink && i < limit) {
options.uri = nextLink
const { body } = await doRequest(options)
nextLink = body.next
2017-11-22 03:29:55 -06:00
i++
if (Array.isArray(body.orderedItems)) {
const activities = body.orderedItems
logger.info('Processing %i items ActivityPub fetcher for %s.', activities.length, options.uri)
2017-11-22 03:29:55 -06:00
await processActivities(activities)
}
}
}
}
// ---------------------------------------------------------------------------
export {
processActivityPubHttpFetcher
2017-11-22 03:29:55 -06:00
}