]> git.localhorst.tv Git - alttp.git/blobdiff - resources/js/helpers/permissions.js
separate bottle tracking
[alttp.git] / resources / js / helpers / permissions.js
index 54bf905fe473a9224419c4325e1b6b9b5c72d5a2..23aba6955b2eb2783894497f85bf881ce43bca66 100644 (file)
@@ -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,14 @@ export const isChannelAdmin = (user, channel) =>
        user && channel && user.channel_crews &&
                user.channel_crews.find(c => c.role === 'admin' && c.channel_id === channel.id);
 
+export const isAnyChannelAdmin = user =>
+       user && user.channel_crews && user.channel_crews.find(c => c.role === 'admin');
+
+// Content
+
+export const mayEditContent = user =>
+       user && hasGlobalRole(user, 'content');
+
 // Episodes
 
 export const isCommentator = (user, episode) => {
@@ -29,8 +40,7 @@ export const isTracker = (user, episode) => {
 export const episodeHasChannel = (episode, channel) =>
        episode && channel && episode.channels && episode.channels.find(c => c.id === channel.id);
 
-export const mayRestreamEpisodes = user =>
-       user && user.channel_crews && user.channel_crews.find(c => c.role === 'admin');
+export const mayRestreamEpisodes = user => isAnyChannelAdmin(user);
 
 export const mayEditRestream = (user, episode, channel) =>
        episodeHasChannel(episode, channel) && isChannelAdmin(user, channel);
@@ -147,6 +157,10 @@ export const maySeeResults = (user, tournament, round) =>
        isTournamentMonitor(user, tournament) ||
        Round.isComplete(tournament, round);
 
+// Twitch
+
+export const mayManageTwitchBot = user => isAnyChannelAdmin(user);
+
 // Users
 
 export const mayEditNickname = (user, subject) =>