mirror of
https://github.com/directus/directus.git
synced 2026-02-04 03:05:05 -05:00
* Pass relations through schema, instead of individual reads * Fetch field transforms upfront * Fix length check * List if user has app access or not in accountability * Load permissions up front, merge app access minimal permissions * Show app access required permissions in permissions overview * Show system minimal permissions in permissions detail * Fix app access check in authenticate for jwt use * Fix minimal permissions for presets * Remove /permissions/me in favor of root use w/ permissions * Fix logical nested OR in an AND * Use root permissions endpoint with filter instead of /me * Allow filter query on /permissions * Add system minimal app access permissions into result of /permissions * Remove stray console log * Remove stray console.dir * Set current role as role for minimal permissions * Fix no-permissions state for user detail * Add filter items function that allows altering existing result set
134 lines
3.2 KiB
TypeScript
134 lines
3.2 KiB
TypeScript
import express from 'express';
|
|
import asyncHandler from '../utils/async-handler';
|
|
import { PermissionsService, MetaService } from '../services';
|
|
import { ForbiddenException, InvalidPayloadException } from '../exceptions';
|
|
import useCollection from '../middleware/use-collection';
|
|
import { respond } from '../middleware/respond';
|
|
import { PrimaryKey } from '../types';
|
|
|
|
const router = express.Router();
|
|
|
|
router.use(useCollection('directus_permissions'));
|
|
|
|
router.post(
|
|
'/',
|
|
asyncHandler(async (req, res, next) => {
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
const primaryKey = await service.create(req.body);
|
|
|
|
try {
|
|
const item = await service.readByKey(primaryKey, req.sanitizedQuery);
|
|
res.locals.payload = { data: item || null };
|
|
} catch (error) {
|
|
if (error instanceof ForbiddenException) {
|
|
return next();
|
|
}
|
|
|
|
throw error;
|
|
}
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
router.get(
|
|
'/',
|
|
asyncHandler(async (req, res, next) => {
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
|
|
const metaService = new MetaService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
|
|
const item = await service.readByQuery(req.sanitizedQuery);
|
|
const meta = await metaService.getMetaForQuery('directus_permissions', req.sanitizedQuery);
|
|
|
|
res.locals.payload = { data: item || null, meta };
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
router.get(
|
|
'/:pk',
|
|
asyncHandler(async (req, res, next) => {
|
|
if (req.path.endsWith('me')) return next();
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
const primaryKey = req.params.pk.includes(',') ? req.params.pk.split(',') : req.params.pk;
|
|
const record = await service.readByKey(primaryKey as any, req.sanitizedQuery);
|
|
|
|
res.locals.payload = { data: record || null };
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
router.patch(
|
|
'/:pk',
|
|
asyncHandler(async (req, res, next) => {
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
const pk = req.params.pk.includes(',') ? req.params.pk.split(',') : req.params.pk;
|
|
const primaryKey = await service.update(req.body, pk as any);
|
|
|
|
try {
|
|
const item = await service.readByKey(primaryKey, req.sanitizedQuery);
|
|
res.locals.payload = { data: item || null };
|
|
} catch (error) {
|
|
if (error instanceof ForbiddenException) {
|
|
return next();
|
|
}
|
|
|
|
throw error;
|
|
}
|
|
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
router.delete(
|
|
'/',
|
|
asyncHandler(async (req, res, next) => {
|
|
if (!req.body || Array.isArray(req.body) === false) {
|
|
throw new InvalidPayloadException(`Body has to be an array of primary keys`);
|
|
}
|
|
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
await service.delete(req.body as PrimaryKey[]);
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
router.delete(
|
|
'/:pk',
|
|
asyncHandler(async (req, res, next) => {
|
|
const service = new PermissionsService({
|
|
accountability: req.accountability,
|
|
schema: req.schema,
|
|
});
|
|
const pk = req.params.pk.includes(',') ? req.params.pk.split(',') : req.params.pk;
|
|
await service.delete(pk as any);
|
|
return next();
|
|
}),
|
|
respond
|
|
);
|
|
|
|
export default router;
|