X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Fsort.ts;h=e6cc46317593772a68c19e22d2071ffd02f3827b;hb=05a60d85997c108d39bcfb14f1ffd4c74f8b1e93;hp=6fea41bb88c1116b5c070c4992da3fc4e080e8fa;hpb=7a7724e66e4533523083e7336cd0d0c747c4a33b;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/sort.ts b/server/middlewares/validators/sort.ts index 6fea41bb8..e6cc46317 100644 --- a/server/middlewares/validators/sort.ts +++ b/server/middlewares/validators/sort.ts @@ -1,49 +1,55 @@ -import { query } from 'express-validator/check' -import * as express from 'express' - -import { checkErrors } from './utils' -import { logger } from '../../helpers' -import { SORTABLE_COLUMNS } from '../../initializers' - -// Initialize constants here for better performances -const SORTABLE_USERS_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.USERS) -const SORTABLE_VIDEO_ABUSES_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.VIDEO_ABUSES) -const SORTABLE_VIDEOS_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.VIDEOS) -const SORTABLE_BLACKLISTS_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.BLACKLISTS) -const SORTABLE_VIDEO_CHANNELS_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.VIDEO_CHANNELS) -const SORTABLE_FOLLOWERS_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.FOLLOWERS) -const SORTABLE_FOLLOWING_COLUMNS = createSortableColumns(SORTABLE_COLUMNS.FOLLOWING) - -const usersSortValidator = checkSort(SORTABLE_USERS_COLUMNS) -const videoAbusesSortValidator = checkSort(SORTABLE_VIDEO_ABUSES_COLUMNS) -const videosSortValidator = checkSort(SORTABLE_VIDEOS_COLUMNS) -const blacklistSortValidator = checkSort(SORTABLE_BLACKLISTS_COLUMNS) -const videoChannelsSortValidator = checkSort(SORTABLE_VIDEO_CHANNELS_COLUMNS) -const followersSortValidator = checkSort(SORTABLE_FOLLOWERS_COLUMNS) -const followingSortValidator = checkSort(SORTABLE_FOLLOWING_COLUMNS) +import express from 'express' +import { query } from 'express-validator' +import { SORTABLE_COLUMNS } from '../../initializers/constants' +import { areValidationErrors } from './shared' + +export const adminUsersSortValidator = checkSortFactory(SORTABLE_COLUMNS.ADMIN_USERS) +export const accountsSortValidator = checkSortFactory(SORTABLE_COLUMNS.ACCOUNTS) +export const jobsSortValidator = checkSortFactory(SORTABLE_COLUMNS.JOBS, [ 'jobs' ]) +export const abusesSortValidator = checkSortFactory(SORTABLE_COLUMNS.ABUSES) +export const videosSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEOS) +export const videoImportsSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_IMPORTS) +export const videosSearchSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEOS_SEARCH) +export const videoChannelsSearchSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_CHANNELS_SEARCH) +export const videoPlaylistsSearchSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_PLAYLISTS_SEARCH) +export const videoCommentsValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_COMMENTS) +export const videoCommentThreadsSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_COMMENT_THREADS) +export const videoRatesSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_RATES) +export const blacklistSortValidator = checkSortFactory(SORTABLE_COLUMNS.BLACKLISTS) +export const videoChannelsSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_CHANNELS) +export const instanceFollowersSortValidator = checkSortFactory(SORTABLE_COLUMNS.INSTANCE_FOLLOWERS) +export const instanceFollowingSortValidator = checkSortFactory(SORTABLE_COLUMNS.INSTANCE_FOLLOWING) +export const userSubscriptionsSortValidator = checkSortFactory(SORTABLE_COLUMNS.USER_SUBSCRIPTIONS) +export const accountsBlocklistSortValidator = checkSortFactory(SORTABLE_COLUMNS.ACCOUNTS_BLOCKLIST) +export const serversBlocklistSortValidator = checkSortFactory(SORTABLE_COLUMNS.SERVERS_BLOCKLIST) +export const userNotificationsSortValidator = checkSortFactory(SORTABLE_COLUMNS.USER_NOTIFICATIONS) +export const videoPlaylistsSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_PLAYLISTS) +export const pluginsSortValidator = checkSortFactory(SORTABLE_COLUMNS.PLUGINS) +export const availablePluginsSortValidator = checkSortFactory(SORTABLE_COLUMNS.AVAILABLE_PLUGINS) +export const videoRedundanciesSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_REDUNDANCIES) +export const videoChannelSyncsSortValidator = checkSortFactory(SORTABLE_COLUMNS.VIDEO_CHANNEL_SYNCS) + +export const accountsFollowersSortValidator = checkSortFactory(SORTABLE_COLUMNS.ACCOUNT_FOLLOWERS) +export const videoChannelsFollowersSortValidator = checkSortFactory(SORTABLE_COLUMNS.CHANNEL_FOLLOWERS) + +export const userRegistrationsSortValidator = checkSortFactory(SORTABLE_COLUMNS.USER_REGISTRATIONS) // --------------------------------------------------------------------------- -export { - usersSortValidator, - videoAbusesSortValidator, - videoChannelsSortValidator, - videosSortValidator, - blacklistSortValidator, - followersSortValidator, - followingSortValidator +function checkSortFactory (columns: string[], tags: string[] = []) { + return checkSort(createSortableColumns(columns), tags) } -// --------------------------------------------------------------------------- - -function checkSort (sortableColumns: string[]) { +function checkSort (sortableColumns: string[], tags: string[] = []) { return [ - query('sort').optional().isIn(sortableColumns).withMessage('Should have correct sortable column'), + query('sort') + .optional() + .isIn(sortableColumns), (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking sort parameters', { parameters: req.query }) + if (areValidationErrors(req, res, { tags })) return - checkErrors(req, res, next) + return next() } ] }