X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fhelpers%2Fpermissions.js;h=8b8c596100270d6c32c4e2b2ff08d2220e96ba08;hb=eca3f0074e6f9e882b91893e554ce249e25338de;hp=32662944a90412639878392d3e32663f6e3e59fe;hpb=d1f28ea443b090c7593791eba9631796ccaeafe1;p=alttp.git diff --git a/resources/js/helpers/permissions.js b/resources/js/helpers/permissions.js index 3266294..8b8c596 100644 --- a/resources/js/helpers/permissions.js +++ b/resources/js/helpers/permissions.js @@ -23,26 +23,43 @@ export const isTournamentAdmin = (user, tournament) => { return p && p.roles && p.roles.includes('admin'); }; +export const isTournamentCrew = (user, tournament) => + isTournamentAdmin(user, tournament) || isTournamentMonitor(user, tournament); + +export const isTournamentMonitor = (user, tournament) => { + const p = isParticipant(user, tournament); + return p && p.roles && p.roles.includes('monitor'); +}; + 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)); + !tournament.locked && + (isRunner(user, tournament) || 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) => - isAdmin(user) || isParticipant(user, tournament); +export const maySetSeed = (user, tournament, round) => + !round.locked && + (isRunner(user, tournament) || isTournamentAdmin(user, tournament)); export const mayViewProtocol = (user, tournament) => - isAdmin(user) || isTournamentAdmin(user, tournament); + isTournamentCrew(user, tournament); export const maySeeResults = (user, tournament, round) => - isAdmin(user) || hasFinished(user, round) || Round.isComplete(tournament, round); + round.locked || + hasFinished(user, round) || + isTournamentMonitor(user, tournament) || + (isTournamentAdmin(user, tournament) && !isRunner(user, tournament)) || + Round.isComplete(tournament, round); // Users +export const mayEditNickname = (user, subject) => + isSameUser(user, subject); + export const mayEditStreamLink = (user, subject) => - isAdmin(user) || isSameUser(user, subject); + isSameUser(user, subject);