import * as express from 'express'
-import { CONFIG } from '../initializers'
-import {
- asyncMiddleware,
- feedsValidator,
- setDefaultPagination,
- setDefaultSort,
- videosSortValidator
-} from '../middlewares'
+import { CONFIG, FEEDS } from '../initializers/constants'
+import { asyncMiddleware, feedsValidator, setDefaultSort, videosSortValidator } from '../middlewares'
import { VideoModel } from '../models/video/video'
import * as Feed from 'pfeed'
-import { ResultList } from '../../shared/models'
import { AccountModel } from '../models/account/account'
+import { cacheRoute } from '../middlewares/cache'
+import { VideoChannelModel } from '../models/video/video-channel'
const feedsRouter = express.Router()
videosSortValidator,
setDefaultSort,
asyncMiddleware(feedsValidator),
+ asyncMiddleware(cacheRoute),
asyncMiddleware(generateFeed)
)
async function generateFeed (req: express.Request, res: express.Response, next: express.NextFunction) {
let feed = initFeed()
- const paginationStart = 0
- const paginationCount = 20
+ const start = 0
- let resultList: ResultList<VideoModel>
const account: AccountModel = res.locals.account
-
- if (account) {
- resultList = await VideoModel.listAccountVideosForApi(
- account.id,
- paginationStart,
- paginationCount,
- req.query.sort,
- true
- )
- } else {
- resultList = await VideoModel.listForApi(
- paginationStart,
- paginationCount,
- req.query.sort,
- req.query.filter,
- true
- )
- }
+ const videoChannel: VideoChannelModel = res.locals.videoChannel
+ const hideNSFW = CONFIG.INSTANCE.DEFAULT_NSFW_POLICY === 'do_not_list'
+
+ const resultList = await VideoModel.listForApi({
+ start,
+ count: FEEDS.COUNT,
+ sort: req.query.sort,
+ hideNSFW,
+ filter: req.query.filter,
+ withFiles: true,
+ accountId: account ? account.id : null,
+ videoChannelId: videoChannel ? videoChannel.id : null
+ })
// Adding video items to the feed, one at a time
resultList.data.forEach(video => {