// @flow import policy from './policy'; import { Integration, User } from '../models'; import { AdminRequiredError } from '../errors'; const { allow } = policy; allow(User, 'create', Integration); allow( User, 'read', Integration, (user, integration) => user.teamId === integration.teamId ); allow(User, ['update', 'delete'], Integration, (user, integration) => { if (!integration || user.teamId !== integration.teamId) return false; if (user.isAdmin) return true; throw new AdminRequiredError(); });