]> git.localhorst.tv Git - alttp.git/blobdiff - resources/js/helpers/permissions.js
round titles
[alttp.git] / resources / js / helpers / permissions.js
index f86b5851c94c4553486b3f2b741678de9c345197..b1de05180d2b1b9ea04f83a4921a9cbd56190162 100644 (file)
@@ -9,6 +9,21 @@ export const isSameUser = (user, subject) => user && subject && user.id === subj
 
 // Tournaments
 
+export const isApplicant = (user, tournament) => {
+       if (!user || !tournament || !tournament.applications) {
+               return false;
+       }
+       return tournament.applications.find(p => p.user && p.user.id == user.id);
+};
+
+export const isDeniedApplicant = (user, tournament) => {
+       if (!user || !tournament || !tournament.applications) {
+               return false;
+       }
+       const applicant = tournament.applications.find(p => p.user && p.user.id == user.id);
+       return applicant && applicant.denied;
+};
+
 export const isParticipant = (user, tournament) =>
        user && tournament && tournament.participants &&
        tournament.participants.find(p => p.user && p.user.id == user.id);
@@ -36,27 +51,48 @@ export const hasFinished = (user, round) =>
        round.results.find(r => r.user_id == user.id && r.has_finished);
 
 export const mayAddRounds = (user, tournament) =>
-       isAdmin(user) || (!tournament.locked &&
-               (isRunner(user, tournament) || isTournamentAdmin(user, tournament)));
+       !tournament.locked &&
+               (isRunner(user, tournament) || isTournamentAdmin(user, tournament));
+
+export const mayApply = (user, tournament) =>
+       user && tournament && tournament.accept_applications &&
+               !isRunner(user, tournament) && !isApplicant(user, tournament);
+
+export const mayHandleApplications = (user, tournament) =>
+       tournament && tournament.accept_applications && isTournamentAdmin(user, tournament);
+
+export const mayReportResult = (user, tournament) => {
+       if (!user || !tournament) return false;
+       if (tournament.type === 'open-async') return true;
+       return isRunner(user, tournament);
+};
+
+export const mayEditRound = (user, tournament) =>
+       !tournament.locked && isTournamentAdmin(user, tournament);
 
 export const mayLockRound = (user, tournament) =>
-       isAdmin(user) || (!tournament.locked && isTournamentAdmin(user, tournament));
+       !tournament.locked && isTournamentAdmin(user, tournament);
 
 export const maySetSeed = (user, tournament, round) =>
-       isAdmin(user) || (!round.locked &&
-               (isRunner(user, tournament) || isTournamentAdmin(user, tournament)));
+       !round.locked &&
+               (isRunner(user, tournament) || isTournamentAdmin(user, tournament));
+
+export const mayUpdateTournament = (user, tournament) =>
+       isAdmin(user) || isTournamentAdmin(user, tournament);
 
 export const mayViewProtocol = (user, tournament) =>
-       isAdmin(user) || isTournamentCrew(user, tournament);
+       isTournamentCrew(user, tournament);
 
 export const maySeeResults = (user, tournament, round) =>
-       isAdmin(user) || hasFinished(user, round) ||
-               isTournamentMonitor(user, tournament) || Round.isComplete(tournament, round);
+       round.locked ||
+       hasFinished(user, round) ||
+       isTournamentMonitor(user, tournament) ||
+       Round.isComplete(tournament, round);
 
 // Users
 
 export const mayEditNickname = (user, subject) =>
-       isAdmin(user) || isSameUser(user, subject);
+       isSameUser(user, subject);
 
 export const mayEditStreamLink = (user, subject) =>
-       isAdmin(user) || isSameUser(user, subject);
+       isSameUser(user, subject);