]> git.localhorst.tv Git - alttp.git/blobdiff - resources/js/helpers/permissions.js
allow admins to lock/unlock rounds
[alttp.git] / resources / js / helpers / permissions.js
index 891803110ace4d65b34a7acb8d514a9f6676cd6e..32662944a90412639878392d3e32663f6e3e59fe 100644 (file)
@@ -1,6 +1,8 @@
 /// NOTE: These permissions are for UI cosmetics only!
 /// They should be in sync with the backend Policies.
 
+import Round from './Round';
+
 export const isAdmin = user => user && user.role === 'admin';
 
 export const isSameUser = (user, subject) => user && subject && user.id === subject.id;
@@ -11,9 +13,36 @@ export const isParticipant = (user, tournament) =>
        user && tournament && tournament.participants &&
        tournament.participants.find(p => p.user && p.user.id == user.id);
 
+export const isRunner = (user, tournament) => {
+       const p = isParticipant(user, tournament);
+       return p && p.roles && p.roles.includes('runner');
+};
+
+export const isTournamentAdmin = (user, tournament) => {
+       const p = isParticipant(user, tournament);
+       return p && p.roles && p.roles.includes('admin');
+};
+
+export const hasFinished = (user, round) =>
+       user && round && round.results &&
+       round.results.find(r => r.user_id == user.id && r.has_finished);
+
 export const mayAddRounds = (user, tournament) =>
+       isAdmin(user) || (!tournament.locked && isParticipant(user, tournament));
+
+export const mayLockRound = (user, tournament) =>
+       isAdmin(user) || (!tournament.locked && isTournamentAdmin(user, tournament));
+
+export const maySetSeed = (user, tournament) =>
        isAdmin(user) || isParticipant(user, tournament);
 
-export const mayViewProtocol = user =>
-       isAdmin(user);
+export const mayViewProtocol = (user, tournament) =>
+       isAdmin(user) || isTournamentAdmin(user, tournament);
+
+export const maySeeResults = (user, tournament, round) =>
+       isAdmin(user) || hasFinished(user, round) || Round.isComplete(tournament, round);
+
+// Users
 
+export const mayEditStreamLink = (user, subject) =>
+       isAdmin(user) || isSameUser(user, subject);