1 /// NOTE: These permissions are for UI cosmetics only!
2 /// They should be in sync with the backend Policies.
4 import Round from './Round';
6 export const isAdmin = user => user && user.role === 'admin';
8 export const isSameUser = (user, subject) => user && subject && user.id === subject.id;
12 export const isParticipant = (user, tournament) =>
13 user && tournament && tournament.participants &&
14 tournament.participants.find(p => p.user && p.user.id == user.id);
16 export const isRunner = (user, tournament) => {
17 const p = isParticipant(user, tournament);
18 return p && p.roles && p.roles.includes('runner');
21 export const isTournamentAdmin = (user, tournament) => {
22 const p = isParticipant(user, tournament);
23 return p && p.roles && p.roles.includes('admin');
26 export const hasFinished = (user, round) =>
27 user && round && round.results &&
28 round.results.find(r => r.user_id == user.id && r.has_finished);
30 export const mayAddRounds = (user, tournament) =>
31 isAdmin(user) || (!tournament.locked && isParticipant(user, tournament));
33 export const maySetSeed = (user, tournament) =>
34 isAdmin(user) || isParticipant(user, tournament);
36 export const mayViewProtocol = (user, tournament) =>
37 isAdmin(user) || isTournamentAdmin(user, tournament);
39 export const maySeeResults = (user, tournament, round) =>
40 isAdmin(user) || hasFinished(user, round) || Round.isComplete(tournament, round);
44 export const mayEditStreamLink = (user, subject) =>
45 isAdmin(user) || isSameUser(user, subject);