a37e9e74ff
* give admins access to edit all channels
closes #4598
* test(channels): +admin update another users channel
* Fix tests
* fix(server): delete another users channel
Since the channel owner isn't necessary the auth user we need to check
the right account whether it's the last video or not.
* REMOVE_ANY_VIDEO_CHANNEL > MANAGE_ANY_VIDEO_CHANNEL
Merge REMOVE_ANY_VIDEO_CHANNEL and MANY_VIDEO_CHANNELS to
MANAGE_ANY_VIDEO_CHANNEL.
* user-right: moderator can't manage admins channel
* client: MyVideoChannelCreateComponent > VideoChannelCreateComponent
* client: MyVideoChannelEdit > VideoChannelEdit
* Revert "user-right: moderator can't manage admins channel"
This reverts commit 2c627c154e
.
* server: clean dupl validator functionality
* fix ensureUserCanManageChannel usage
It's not async anymore.
* server: merge channel validator middleares
ensureAuthUserOwnsChannelValidator & ensureUserCanManageChannel gets
merged into one middleware.
* client(VideoChannelEdit): redirect to prev route
* fix(VideoChannels): handle anon users
* client: new routes for create/update channel
* Refactor channel validators
Co-authored-by: Chocobozzz <me@florianbigard.com>
36 lines
1 KiB
TypeScript
36 lines
1 KiB
TypeScript
import { UserRight, UserRole } from '../../models/users'
|
|
|
|
export const USER_ROLE_LABELS: { [ id in UserRole ]: string } = {
|
|
[UserRole.USER]: 'User',
|
|
[UserRole.MODERATOR]: 'Moderator',
|
|
[UserRole.ADMINISTRATOR]: 'Administrator'
|
|
}
|
|
|
|
const userRoleRights: { [ id in UserRole ]: UserRight[] } = {
|
|
[UserRole.ADMINISTRATOR]: [
|
|
UserRight.ALL
|
|
],
|
|
|
|
[UserRole.MODERATOR]: [
|
|
UserRight.MANAGE_VIDEO_BLACKLIST,
|
|
UserRight.MANAGE_ABUSES,
|
|
UserRight.MANAGE_ANY_VIDEO_CHANNEL,
|
|
UserRight.REMOVE_ANY_VIDEO,
|
|
UserRight.REMOVE_ANY_VIDEO_PLAYLIST,
|
|
UserRight.REMOVE_ANY_VIDEO_COMMENT,
|
|
UserRight.UPDATE_ANY_VIDEO,
|
|
UserRight.SEE_ALL_VIDEOS,
|
|
UserRight.MANAGE_ACCOUNTS_BLOCKLIST,
|
|
UserRight.MANAGE_SERVERS_BLOCKLIST,
|
|
UserRight.MANAGE_USERS,
|
|
UserRight.SEE_ALL_COMMENTS
|
|
],
|
|
|
|
[UserRole.USER]: []
|
|
}
|
|
|
|
export function hasUserRight (userRole: UserRole, userRight: UserRight) {
|
|
const userRights = userRoleRights[userRole]
|
|
|
|
return userRights.includes(UserRight.ALL) || userRights.includes(userRight)
|
|
}
|