]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - server/middlewares/sort.ts
Cache AP video route for 5 seconds
[github/Chocobozzz/PeerTube.git] / server / middlewares / sort.ts
index 632b2fae4158fd2bbfa0ff18e4dbb23844f9d0ca..cdb809e75e80084d5f6774e4f21ba4159be89fee 100644 (file)
@@ -1,20 +1,30 @@
-import 'express-validator'
 import * as express from 'express'
+import 'express-validator'
+import { SortType } from '../helpers/utils'
 
-function setUsersSort (req: express.Request, res: express.Response, next: express.NextFunction) {
+function setDefaultSort (req: express.Request, res: express.Response, next: express.NextFunction) {
   if (!req.query.sort) req.query.sort = '-createdAt'
 
   return next()
 }
 
-function setVideoAbusesSort (req: express.Request, res: express.Response, next: express.NextFunction) {
+function setBlacklistSort (req: express.Request, res: express.Response, next: express.NextFunction) {
+  let newSort: SortType = { sortModel: undefined, sortValue: undefined }
+
   if (!req.query.sort) req.query.sort = '-createdAt'
 
-  return next()
-}
+  // Set model we want to sort onto
+  if (req.query.sort === '-createdAt' || req.query.sort === 'createdAt' ||
+      req.query.sort === '-id' || req.query.sort === 'id') {
+    // If we want to sort onto the BlacklistedVideos relation, we won't specify it in the query parameter ...
+    newSort.sortModel = undefined
+  } else {
+    newSort.sortModel = 'Video'
+  }
 
-function setVideosSort (req: express.Request, res: express.Response, next: express.NextFunction) {
-  if (!req.query.sort) req.query.sort = '-createdAt'
+  newSort.sortValue = req.query.sort
+
+  req.query.sort = newSort
 
   return next()
 }
@@ -22,7 +32,6 @@ function setVideosSort (req: express.Request, res: express.Response, next: expre
 // ---------------------------------------------------------------------------
 
 export {
-  setUsersSort,
-  setVideoAbusesSort,
-  setVideosSort
+  setDefaultSort,
+  setBlacklistSort
 }