Implement video channel feeds
This commit is contained in:
parent
170726f523
commit
e0ea4b1d55
|
@ -3,10 +3,9 @@ import { CONFIG, FEEDS } from '../initializers/constants'
|
||||||
import { asyncMiddleware, feedsValidator, setDefaultSort, videosSortValidator } from '../middlewares'
|
import { asyncMiddleware, feedsValidator, setDefaultSort, videosSortValidator } from '../middlewares'
|
||||||
import { VideoModel } from '../models/video/video'
|
import { VideoModel } from '../models/video/video'
|
||||||
import * as Feed from 'pfeed'
|
import * as Feed from 'pfeed'
|
||||||
import { ResultList } from '../../shared/models'
|
|
||||||
import { AccountModel } from '../models/account/account'
|
import { AccountModel } from '../models/account/account'
|
||||||
import { cacheRoute } from '../middlewares/cache'
|
import { cacheRoute } from '../middlewares/cache'
|
||||||
import { VideoSortField } from '../../client/src/app/shared/video/sort-field.type'
|
import { VideoChannelModel } from '../models/video/video-channel'
|
||||||
|
|
||||||
const feedsRouter = express.Router()
|
const feedsRouter = express.Router()
|
||||||
|
|
||||||
|
@ -31,6 +30,7 @@ async function generateFeed (req: express.Request, res: express.Response, next:
|
||||||
const start = 0
|
const start = 0
|
||||||
|
|
||||||
const account: AccountModel = res.locals.account
|
const account: AccountModel = res.locals.account
|
||||||
|
const videoChannel: VideoChannelModel = res.locals.videoChannel
|
||||||
const hideNSFW = CONFIG.INSTANCE.DEFAULT_NSFW_POLICY === 'do_not_list'
|
const hideNSFW = CONFIG.INSTANCE.DEFAULT_NSFW_POLICY === 'do_not_list'
|
||||||
|
|
||||||
const resultList = await VideoModel.listForApi({
|
const resultList = await VideoModel.listForApi({
|
||||||
|
@ -40,7 +40,8 @@ async function generateFeed (req: express.Request, res: express.Response, next:
|
||||||
hideNSFW,
|
hideNSFW,
|
||||||
filter: req.query.filter,
|
filter: req.query.filter,
|
||||||
withFiles: true,
|
withFiles: true,
|
||||||
accountId: account ? account.id : null
|
accountId: account ? account.id : null,
|
||||||
|
videoChannelId: videoChannel ? videoChannel.id : null
|
||||||
})
|
})
|
||||||
|
|
||||||
// Adding video items to the feed, one at a time
|
// Adding video items to the feed, one at a time
|
||||||
|
|
|
@ -1,11 +1,12 @@
|
||||||
import * as express from 'express'
|
import * as express from 'express'
|
||||||
import { param, query } from 'express-validator/check'
|
import { param, query } from 'express-validator/check'
|
||||||
import { isAccountIdExist, isAccountNameValid, isLocalAccountNameExist } from '../../helpers/custom-validators/accounts'
|
import { isAccountIdExist, isAccountNameValid } from '../../helpers/custom-validators/accounts'
|
||||||
import { join } from 'path'
|
import { join } from 'path'
|
||||||
import { isIdOrUUIDValid } from '../../helpers/custom-validators/misc'
|
import { isIdOrUUIDValid } from '../../helpers/custom-validators/misc'
|
||||||
import { logger } from '../../helpers/logger'
|
import { logger } from '../../helpers/logger'
|
||||||
import { areValidationErrors } from './utils'
|
import { areValidationErrors } from './utils'
|
||||||
import { isValidRSSFeed } from '../../helpers/custom-validators/feeds'
|
import { isValidRSSFeed } from '../../helpers/custom-validators/feeds'
|
||||||
|
import { isVideoChannelExist } from '../../helpers/custom-validators/video-channels'
|
||||||
|
|
||||||
const feedsValidator = [
|
const feedsValidator = [
|
||||||
param('format').optional().custom(isValidRSSFeed).withMessage('Should have a valid format (rss, atom, json)'),
|
param('format').optional().custom(isValidRSSFeed).withMessage('Should have a valid format (rss, atom, json)'),
|
||||||
|
@ -18,11 +19,8 @@ const feedsValidator = [
|
||||||
|
|
||||||
if (areValidationErrors(req, res)) return
|
if (areValidationErrors(req, res)) return
|
||||||
|
|
||||||
if (req.query.accountId) {
|
if (req.query.accountId && !await isAccountIdExist(req.query.accountId, res)) return
|
||||||
if (!await isAccountIdExist(req.query.accountId, res)) return
|
if (req.query.videoChannelId && !await isVideoChannelExist(req.query.videoChannelId, res)) return
|
||||||
} else if (req.query.accountName) {
|
|
||||||
if (!await isLocalAccountNameExist(req.query.accountName, res)) return
|
|
||||||
}
|
|
||||||
|
|
||||||
return next()
|
return next()
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue