Avoid making retried requests to dead followers

This commit is contained in:
Chocobozzz 2018-01-12 10:02:11 +01:00
parent 9a8cbd8278
commit 6502c3d43e
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
7 changed files with 44 additions and 3 deletions

View File

@ -81,7 +81,6 @@ async function resolveThread (url: string, comments: VideoCommentModel[] = []) {
// Speed up things and resolve directly the thread // Speed up things and resolve directly the thread
if (commentFromDatabase.InReplyToVideoComment) { if (commentFromDatabase.InReplyToVideoComment) {
const data = await VideoCommentModel.listThreadParentComments(commentFromDatabase, undefined, 'DESC') const data = await VideoCommentModel.listThreadParentComments(commentFromDatabase, undefined, 'DESC')
console.log(data)
parentComments = parentComments.concat(data) parentComments = parentComments.concat(data)
} }

View File

@ -4,6 +4,7 @@ import { logger } from '../../../helpers/logger'
import { getServerActor } from '../../../helpers/utils' import { getServerActor } from '../../../helpers/utils'
import { ACTIVITY_PUB } from '../../../initializers' import { ACTIVITY_PUB } from '../../../initializers'
import { ActorModel } from '../../../models/activitypub/actor' import { ActorModel } from '../../../models/activitypub/actor'
import { ActorFollowModel } from '../../../models/activitypub/actor-follow'
import { JobHandler, JobScheduler } from '../job-scheduler' import { JobHandler, JobScheduler } from '../job-scheduler'
import * as activitypubHttpBroadcastHandler from './activitypub-http-broadcast-handler' import * as activitypubHttpBroadcastHandler from './activitypub-http-broadcast-handler'
@ -35,6 +36,12 @@ async function maybeRetryRequestLater (err: Error, payload: ActivityPubHttpPaylo
if (attemptNumber < ACTIVITY_PUB.MAX_HTTP_ATTEMPT) { if (attemptNumber < ACTIVITY_PUB.MAX_HTTP_ATTEMPT) {
logger.debug('Retrying request to %s (attempt %d/%d).', uri, attemptNumber, ACTIVITY_PUB.MAX_HTTP_ATTEMPT, err) logger.debug('Retrying request to %s (attempt %d/%d).', uri, attemptNumber, ACTIVITY_PUB.MAX_HTTP_ATTEMPT, err)
const actor = await ActorFollowModel.loadByFollowerInbox(uri, undefined)
if (!actor) {
logger.debug('Actor %s is not a follower, do not retry the request.', uri)
return false
}
const newPayload = Object.assign(payload, { const newPayload = Object.assign(payload, {
uris: [ uri ], uris: [ uri ],
attemptNumber attemptNumber

View File

@ -6,10 +6,11 @@ import { ActivityPubHttpPayload, buildSignedRequestOptions, computeBody, maybeRe
async function process (payload: ActivityPubHttpPayload, jobId: number) { async function process (payload: ActivityPubHttpPayload, jobId: number) {
logger.info('Processing ActivityPub unicast in job %d.', jobId) logger.info('Processing ActivityPub unicast in job %d.', jobId)
const uri = payload.uris[0]
const body = await computeBody(payload) const body = await computeBody(payload)
const httpSignatureOptions = await buildSignedRequestOptions(payload) const httpSignatureOptions = await buildSignedRequestOptions(payload)
const uri = payload.uris[0]
const options = { const options = {
method: 'POST', method: 'POST',
uri, uri,

View File

@ -35,7 +35,6 @@ async function checkSignature (req: Request, res: Response, next: NextFunction)
function executeIfActivityPub (fun: RequestHandler | RequestHandler[]) { function executeIfActivityPub (fun: RequestHandler | RequestHandler[]) {
return (req: Request, res: Response, next: NextFunction) => { return (req: Request, res: Response, next: NextFunction) => {
const accepted = req.accepts(ACCEPT_HEADERS) const accepted = req.accepts(ACCEPT_HEADERS)
console.log(accepted)
if (accepted === false || ACTIVITY_PUB.POTENTIAL_ACCEPT_HEADERS.indexOf(accepted) === -1) { if (accepted === false || ACTIVITY_PUB.POTENTIAL_ACCEPT_HEADERS.indexOf(accepted) === -1) {
return next() return next()
} }

View File

@ -163,6 +163,34 @@ export class ActorFollowModel extends Model<ActorFollowModel> {
return ActorFollowModel.findOne(query) return ActorFollowModel.findOne(query)
} }
static loadByFollowerInbox (url: string, t?: Sequelize.Transaction) {
const query = {
where: {
state: 'accepted'
},
include: [
{
model: ActorModel,
required: true,
as: 'ActorFollower',
where: {
[Sequelize.Op.or]: [
{
inboxUrl: url
},
{
sharedInboxUrl: url
}
]
}
}
],
transaction: t
} as any // FIXME: typings does not work
return ActorFollowModel.findOne(query)
}
static listFollowingForApi (id: number, start: number, count: number, sort: string) { static listFollowingForApi (id: number, start: number, count: number, sort: string) {
const query = { const query = {
distinct: true, distinct: true,

View File

@ -68,6 +68,9 @@ enum ScopeNames {
{ {
fields: [ 'preferredUsername', 'serverId' ], fields: [ 'preferredUsername', 'serverId' ],
unique: true unique: true
},
{
fields: [ 'inboxUrl', 'sharedInboxUrl' ]
} }
] ]
}) })

View File

@ -113,6 +113,10 @@ describe('Test handle downs', function () {
videos.push(resVideo.body.video) videos.push(resVideo.body.video)
} }
await wait(2000)
await uploadVideo(servers[ 0 ].url, servers[ 0 ].accessToken, videoAttributes)
// Add comments to video 2 // Add comments to video 2
{ {
const text = 'thread 1' const text = 'thread 1'