X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Fapi%2Fvideo-channel.ts;h=e65550a221fe03c3dd052c676a4056cf0d27b3bd;hb=cbe2f36d93c779ca08424336be7e3988e57be01d;hp=f9c1a405d907038ca81ef7e5e9d8102a85b7af3d;hpb=2760b454a761f6af3138b2fb5f34340772ab0d1e;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/api/video-channel.ts b/server/controllers/api/video-channel.ts index f9c1a405d..e65550a22 100644 --- a/server/controllers/api/video-channel.ts +++ b/server/controllers/api/video-channel.ts @@ -5,8 +5,7 @@ import { ActorFollowModel } from '@server/models/actor/actor-follow' import { getServerActor } from '@server/models/application/application' import { guessAdditionalAttributesFromQuery } from '@server/models/video/formatter/video-format-utils' import { MChannelBannerAccountDefault } from '@server/types/models' -import { ActorImageType, VideoChannelCreate, VideoChannelUpdate } from '../../../shared' -import { HttpStatusCode } from '../../../shared/models/http/http-error-codes' +import { ActorImageType, HttpStatusCode, VideoChannelCreate, VideoChannelUpdate } from '@shared/models' import { auditLoggerFactory, getAuditIdFromRes, VideoChannelAuditView } from '../../helpers/audit-logger' import { resetSequelizeInstance } from '../../helpers/database-utils' import { buildNSFWFilter, createReqFiles, getCountVideos, isUserAbleToSearchRemoteURI } from '../../helpers/express-utils' @@ -24,6 +23,7 @@ import { asyncRetryTransactionMiddleware, authenticate, commonVideosFiltersValidator, + ensureCanManageChannel, optionalAuthenticate, paginationValidator, setDefaultPagination, @@ -36,7 +36,7 @@ import { videoPlaylistsSortValidator } from '../../middlewares' import { - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, videoChannelsFollowersSortValidator, videoChannelsListValidator, videoChannelsNameWithHostValidator, @@ -74,7 +74,8 @@ videoChannelRouter.post('/:nameWithHost/avatar/pick', authenticate, reqAvatarFile, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, + ensureCanManageChannel, updateAvatarValidator, asyncMiddleware(updateVideoChannelAvatar) ) @@ -83,7 +84,8 @@ videoChannelRouter.post('/:nameWithHost/banner/pick', authenticate, reqBannerFile, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, + ensureCanManageChannel, updateBannerValidator, asyncMiddleware(updateVideoChannelBanner) ) @@ -91,27 +93,33 @@ videoChannelRouter.post('/:nameWithHost/banner/pick', videoChannelRouter.delete('/:nameWithHost/avatar', authenticate, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, + ensureCanManageChannel, asyncMiddleware(deleteVideoChannelAvatar) ) videoChannelRouter.delete('/:nameWithHost/banner', authenticate, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, + ensureCanManageChannel, asyncMiddleware(deleteVideoChannelBanner) ) videoChannelRouter.put('/:nameWithHost', authenticate, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureIsLocalChannel, + ensureCanManageChannel, videoChannelsUpdateValidator, asyncRetryTransactionMiddleware(updateVideoChannel) ) videoChannelRouter.delete('/:nameWithHost', authenticate, + asyncMiddleware(videoChannelsNameWithHostValidator), + ensureIsLocalChannel, + ensureCanManageChannel, asyncMiddleware(videoChannelsRemoveValidator), asyncRetryTransactionMiddleware(removeVideoChannel) ) @@ -145,7 +153,7 @@ videoChannelRouter.get('/:nameWithHost/videos', videoChannelRouter.get('/:nameWithHost/followers', authenticate, asyncMiddleware(videoChannelsNameWithHostValidator), - ensureAuthUserOwnsChannelValidator, + ensureCanManageChannel, paginationValidator, videoChannelsFollowersSortValidator, setDefaultSort, @@ -347,7 +355,6 @@ async function listVideoChannelVideos (req: express.Request, res: express.Respon displayOnlyForFollower, nsfw: buildNSFWFilter(res, query.nsfw), - withFiles: false, videoChannelId: videoChannelInstance.id, user: res.locals.oauth ? res.locals.oauth.token.User : undefined, countVideos