import * as WebFinger from 'webfinger.js'
-
-import { isTestInstance } from './core-utils'
-import { isActivityPubUrlValid } from './custom-validators'
import { WebFingerData } from '../../shared'
-import { fetchRemoteAccountAndCreatePod } from './activitypub'
+import { ActorModel } from '../models/activitypub/actor'
+import { isTestInstance } from './core-utils'
+import { isActivityPubUrlValid } from './custom-validators/activitypub/misc'
+import { CONFIG } from '../initializers'
const webfinger = new WebFinger({
webfist_fallback: false,
request_timeout: 3000
})
-async function getAccountFromWebfinger (url: string) {
- const webfingerData: WebFingerData = await webfingerLookup(url)
+async function loadActorUrlOrGetFromWebfinger (uri: string) {
+ const [ name, host ] = uri.split('@')
+ let actor: ActorModel
- if (Array.isArray(webfingerData.links) === false) return undefined
+ if (host === CONFIG.WEBSERVER.HOST) {
+ actor = await ActorModel.loadLocalByName(name)
+ } else {
+ actor = await ActorModel.loadByNameAndHost(name, host)
+ }
- const selfLink = webfingerData.links.find(l => l.rel === 'self')
- if (selfLink === undefined || isActivityPubUrlValid(selfLink.href) === false) return undefined
+ if (actor) return actor.url
- const { account } = await fetchRemoteAccountAndCreatePod(selfLink.href)
+ return getUrlFromWebfinger(uri)
+}
- return account
+async function getUrlFromWebfinger (uri: string) {
+ const webfingerData: WebFingerData = await webfingerLookup(uri)
+ return getLinkOrThrow(webfingerData)
}
// ---------------------------------------------------------------------------
export {
- getAccountFromWebfinger
+ getUrlFromWebfinger,
+ loadActorUrlOrGetFromWebfinger
}
// ---------------------------------------------------------------------------
-function webfingerLookup (url: string) {
+function getLinkOrThrow (webfingerData: WebFingerData) {
+ if (Array.isArray(webfingerData.links) === false) throw new Error('WebFinger links is not an array.')
+
+ const selfLink = webfingerData.links.find(l => l.rel === 'self')
+ if (selfLink === undefined || isActivityPubUrlValid(selfLink.href) === false) {
+ throw new Error('Cannot find self link or href is not a valid URL.')
+ }
+
+ return selfLink.href
+}
+
+function webfingerLookup (nameWithHost: string) {
return new Promise<WebFingerData>((res, rej) => {
- webfinger.lookup('nick@silverbucket.net', (err, p) => {
+ webfinger.lookup(nameWithHost, (err, p) => {
if (err) return rej(err)
- return p
+ return res(p.object)
})
})
}