X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fhelpers%2Fpermissions.js;h=706e676ab692d5b44ec606e66ad8fc01c13a372f;hb=5dc7faa01ad96732b0ea126e945f215a9d0490af;hp=54bf905fe473a9224419c4325e1b6b9b5c72d5a2;hpb=5a575dc29f3af10f1d8e142ff9e1c6ccdfa3b075;p=alttp.git diff --git a/resources/js/helpers/permissions.js b/resources/js/helpers/permissions.js index 54bf905..706e676 100644 --- a/resources/js/helpers/permissions.js +++ b/resources/js/helpers/permissions.js @@ -4,6 +4,9 @@ import * as Episode from './Episode'; import Round from './Round'; +export const hasGlobalRole = (user, role) => + user && role && user.global_roles && user.global_roles.includes(role); + export const isAdmin = user => user && user.role === 'admin'; export const isSameUser = (user, subject) => user && subject && user.id === subject.id; @@ -14,6 +17,11 @@ export const isChannelAdmin = (user, channel) => user && channel && user.channel_crews && user.channel_crews.find(c => c.role === 'admin' && c.channel_id === channel.id); +// Content + +export const mayEditContent = user => + user && hasGlobalRole(user, 'content'); + // Episodes export const isCommentator = (user, episode) => { @@ -147,6 +155,10 @@ export const maySeeResults = (user, tournament, round) => isTournamentMonitor(user, tournament) || Round.isComplete(tournament, round); +// Twitch + +export const mayManageTwitchBot = user => isAdmin(user) || hasGlobalRole(user, 'twitch'); + // Users export const mayEditNickname = (user, subject) =>