import * as express from 'express'
-import { buildNSFWFilter } from '../../helpers/express-utils'
+import { buildNSFWFilter, isUserAbleToSearchRemoteURI } from '../../helpers/express-utils'
import { getFormattedObjects, getServerActor } from '../../helpers/utils'
import { VideoModel } from '../../models/video/video'
import {
videoChannelsSearchSortValidator,
setDefaultSearchSort,
optionalAuthenticate,
- commonVideosFiltersValidator,
videoChannelsSearchValidator,
asyncMiddleware(searchVideoChannels)
)
const isURISearch = search.startsWith('http://') || search.startsWith('https://')
const parts = search.split('@')
- const isHandleSearch = parts.length === 2 && parts.every(p => p.indexOf(' ') === -1)
+ const isWebfingerSearch = parts.length === 2 && parts.every(p => p.indexOf(' ') === -1)
- if (isURISearch || isHandleSearch) return searchVideoChannelURI(search, isHandleSearch, res)
+ if (isURISearch || isWebfingerSearch) return searchVideoChannelURI(search, isWebfingerSearch, res)
return searchVideoChannelsDB(query, res)
}
return res.json(getFormattedObjects(resultList.data, resultList.total))
}
-async function searchVideoChannelURI (search: string, isHandleSearch: boolean, res: express.Response) {
+async function searchVideoChannelURI (search: string, isWebfingerSearch: boolean, res: express.Response) {
let videoChannel: VideoChannelModel
+ let uri = search
- if (isUserAbleToSearchRemoteURI(res)) {
- let uri = search
- if (isHandleSearch) uri = await loadActorUrlOrGetFromWebfinger(search)
+ if (isWebfingerSearch) uri = await loadActorUrlOrGetFromWebfinger(search)
- const actor = await getOrCreateActorAndServerAndModel(uri)
- videoChannel = actor.VideoChannel
+ if (isUserAbleToSearchRemoteURI(res)) {
+ try {
+ const actor = await getOrCreateActorAndServerAndModel(uri, true, true)
+ videoChannel = actor.VideoChannel
+ } catch (err) {
+ logger.info('Cannot search remote video channel %s.', uri, { err })
+ }
} else {
- videoChannel = await VideoChannelModel.loadByUrlAndPopulateAccount(search)
+ videoChannel = await VideoChannelModel.loadByUrlAndPopulateAccount(uri)
}
return res.json({
const result = await getOrCreateVideoAndAccountAndChannel(url, syncParam)
video = result ? result.video : undefined
} catch (err) {
- logger.info('Cannot search remote video %s.', url)
+ logger.info('Cannot search remote video %s.', url, { err })
}
} else {
video = await VideoModel.loadByUrlAndPopulateAccount(url)
data: video ? [ video.toFormattedJSON() ] : []
})
}
-
-function isUserAbleToSearchRemoteURI (res: express.Response) {
- const user: User = res.locals.oauth ? res.locals.oauth.token.User : undefined
-
- return CONFIG.SEARCH.REMOTE_URI.ANONYMOUS === true ||
- (CONFIG.SEARCH.REMOTE_URI.USERS === true && user !== undefined)
-}