import validator from 'validator'
-import { isArray } from './misc'
+import { SearchTargetType } from '@shared/models/search/search-target-query.model'
+import { isArray, exists } from './misc'
+import { CONFIG } from '@server/initializers/config'
function isNumberArray (value: any) {
return isArray(value) && value.every(v => validator.isInt('' + v))
return value === 'true' || value === 'false' || value === 'both'
}
+function isSearchTargetValid (value: SearchTargetType) {
+ if (!exists(value)) return true
+
+ const searchIndexConfig = CONFIG.SEARCH.SEARCH_INDEX
+
+ if (value === 'local' && (!searchIndexConfig.ENABLED || !searchIndexConfig.DISABLE_LOCAL_SEARCH)) return true
+
+ if (value === 'search-index' && searchIndexConfig.ENABLED) return true
+
+ return false
+}
+
// ---------------------------------------------------------------------------
export {
isNumberArray,
isStringArray,
- isNSFWQueryValid
+ isNSFWQueryValid,
+ isSearchTargetValid
}
import { logger } from '../../helpers/logger'
import { query } from 'express-validator'
import { isDateValid } from '../../helpers/custom-validators/misc'
+import { isSearchTargetValid } from '@server/helpers/custom-validators/search'
const videosSearchValidator = [
query('search').optional().not().isEmpty().withMessage('Should have a valid search'),
query('durationMin').optional().isInt().withMessage('Should have a valid min duration'),
query('durationMax').optional().isInt().withMessage('Should have a valid max duration'),
+ query('searchTarget').optional().custom(isSearchTargetValid).withMessage('Should have a valid search target'),
+
(req: express.Request, res: express.Response, next: express.NextFunction) => {
logger.debug('Checking videos search query', { parameters: req.query })
const videoChannelsSearchValidator = [
query('search').not().isEmpty().withMessage('Should have a valid search'),
+ query('searchTarget').optional().custom(isSearchTargetValid).withMessage('Should have a valid search target'),
(req: express.Request, res: express.Response, next: express.NextFunction) => {
logger.debug('Checking video channels search query', { parameters: req.query })
/* eslint-disable @typescript-eslint/no-unused-expressions,@typescript-eslint/require-await */
import 'mocha'
-
-import { cleanupTests, flushAndRunServer, immutableAssign, makeGetRequest, ServerInfo } from '../../../../shared/extra-utils'
+import {
+ cleanupTests,
+ flushAndRunServer,
+ immutableAssign,
+ makeGetRequest,
+ ServerInfo,
+ updateCustomSubConfig,
+ setAccessTokensToServers
+} from '../../../../shared/extra-utils'
import {
checkBadCountPagination,
checkBadSortPagination,
checkBadStartPagination
} from '../../../../shared/extra-utils/requests/check-api-params'
+function updateSearchIndex (server: ServerInfo, enabled: boolean, disableLocalSearch = false) {
+ return updateCustomSubConfig(server.url, server.accessToken, {
+ search: {
+ searchIndex: {
+ enabled,
+ disableLocalSearch
+ }
+ }
+ })
+}
+
describe('Test videos API validator', function () {
let server: ServerInfo
this.timeout(30000)
server = await flushAndRunServer(1)
+ await setAccessTokensToServers([ server ])
})
describe('When searching videos', function () {
})
})
+ describe('Search target', function () {
+
+ it('Should fail/succeed depending on the search target', async function () {
+ this.timeout(10000)
+
+ const query = { search: 'coucou' }
+ const paths = [
+ '/api/v1/search/video-channels/',
+ '/api/v1/search/videos/'
+ ]
+
+ for (const path of paths) {
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'hello' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 400 })
+ }
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: undefined })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 200 })
+ }
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'local' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 200 })
+ }
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'search-index' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 400 })
+ }
+
+ await updateSearchIndex(server, true, true)
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'local' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 400 })
+ }
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'search-index' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 200 })
+ }
+
+ await updateSearchIndex(server, true, false)
+
+ {
+ const customQuery = immutableAssign(query, { searchTarget: 'local' })
+ await makeGetRequest({ url: server.url, path, query: customQuery, statusCodeExpected: 200 })
+ }
+
+ await updateSearchIndex(server, false, false)
+ }
+ })
+ })
+
after(async function () {
await cleanupTests([ server ])
})