1 import { logger } from '@server/helpers/logger'
2 import { PeerTubeRequestError } from '@server/helpers/requests'
3 import { ActorFetchByUrlType } from '@server/lib/model-loaders'
4 import { ActorModel } from '@server/models/actor/actor'
5 import { MActorAccountChannelId, MActorFull } from '@server/types/models'
6 import { HttpStatusCode } from '@shared/core-utils'
7 import { fetchRemoteActor } from './shared'
8 import { APActorUpdater } from './updater'
9 import { getUrlFromWebfinger } from './webfinger'
11 async function refreshActorIfNeeded <T extends MActorFull | MActorAccountChannelId> (
13 fetchedType: ActorFetchByUrlType
14 ): Promise<{ actor: T | MActorFull, refreshed: boolean }> {
15 if (!actorArg.isOutdated()) return { actor: actorArg, refreshed: false }
17 // We need more attributes
18 const actor = fetchedType === 'all'
19 ? actorArg as MActorFull
20 : await ActorModel.loadByUrlAndPopulateAccountAndChannel(actorArg.url)
23 const actorUrl = await getActorUrl(actor)
24 const { actorObject } = await fetchRemoteActor(actorUrl)
26 if (actorObject === undefined) {
27 logger.warn('Cannot fetch remote actor in refresh actor.')
28 return { actor, refreshed: false }
31 const updater = new APActorUpdater(actorObject, actor)
32 await updater.update()
34 return { refreshed: true, actor }
36 if ((err as PeerTubeRequestError).statusCode === HttpStatusCode.NOT_FOUND_404) {
37 logger.info('Deleting actor %s because there is a 404 in refresh actor.', actor.url)
40 ? await actor.Account.destroy()
41 : await actor.VideoChannel.destroy()
43 return { actor: undefined, refreshed: false }
46 logger.warn('Cannot refresh actor %s.', actor.url, { err })
47 return { actor, refreshed: false }
55 // ---------------------------------------------------------------------------
57 function getActorUrl (actor: MActorFull) {
58 return getUrlFromWebfinger(actor.preferredUsername + '@' + actor.getHost())
60 logger.warn('Cannot get actor URL from webfinger, keeping the old one.', err)