Configure user access

This commit is contained in:
tobias 2024-05-20 09:10:08 +02:00
parent 1dbb075cd8
commit 1ccf660f5b
3 changed files with 46 additions and 10 deletions

View File

@ -0,0 +1,12 @@
import { Access, FieldAccess } from "payload/types";
import { User } from "../payload-types";
export const isAdmin: Access<any, User> = ({ req: { user } }) => {
// Return true or false based on if the user has an admin role
return Boolean(user?.roles?.includes('admin'));
}
export const isAdminFieldLevel: FieldAccess<{ id: string }, unknown, User> = ({ req: { user } }) => {
// Return true or false based on if the user has an admin role
return Boolean(user?.roles?.includes('admin'));
}

View File

@ -0,0 +1,21 @@
import { Access } from "payload/config";
export const isAdminOrSelf: Access = ({ req: { user } }) => {
// Need to be logged in
if (user) {
// If user has role of 'admin'
if (user.roles?.includes('admin')) {
return true;
}
// If any other type of user, only provide access to themselves
return {
id: {
equals: user.id,
}
}
}
// Reject everyone else
return false;
}

View File

@ -1,6 +1,6 @@
import { CollectionConfig } from 'payload/types';
const isAdmin = ({ req: { user } }) => (user && user.role === 'admin');
import { isAdmin, isAdminFieldLevel } from '../access/isAdmin';
import { isAdminOrSelf } from '../access/isAdminOrSelf';
const Users: CollectionConfig = {
slug: 'users',
@ -9,11 +9,14 @@ const Users: CollectionConfig = {
useAsTitle: 'email',
},
access: {
read: isAdmin,
create: isAdmin,
read: isAdminOrSelf,
update: isAdminOrSelf,
delete: isAdmin,
},
fields: [
{
name: 'role',
name: 'roles',
type: 'select',
options: [
{ label: 'ssg', value: 'ssg' }, //cRud
@ -23,14 +26,14 @@ const Users: CollectionConfig = {
],
required: true,
defaultValue: "user",
// JWT so that role is accessible from 'req.user'
saveToJWT: true,
hasMany: true,
access: {
create: isAdmin,
read: isAdmin,
update: isAdmin,
create: isAdminFieldLevel,
read: () => true,
update: isAdminFieldLevel,
},
admin: {
readOnly: !isAdmin
}
},
{
name: 'name',