This repository has been archived on 2022-08-14. You can view files and clone it, but cannot push or open issues or pull requests.
2020-08-08 18:53:11 -07:00

42 lines
964 B
JavaScript

// @flow
import policy from "./policy";
import { User } from "../models";
import { AdminRequiredError } from "../errors";
const { allow } = policy;
allow(
User,
"read",
User,
(actor, user) => user && user.teamId === actor.teamId
);
allow(User, "invite", User, (actor) => {
return true;
});
allow(User, "update", User, (actor, user) => {
if (!user || user.teamId !== actor.teamId) return false;
if (user.id === actor.id) return true;
throw new AdminRequiredError();
});
allow(User, "delete", User, (actor, user) => {
if (!user || user.teamId !== actor.teamId) return false;
if (user.id === actor.id) return true;
if (actor.isAdmin && !user.lastActiveAt) return true;
throw new AdminRequiredError();
});
allow(
User,
["promote", "demote", "activate", "suspend"],
User,
(actor, user) => {
if (!user || user.teamId !== actor.teamId) return false;
if (actor.isAdmin) return true;
throw new AdminRequiredError();
}
);