| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- import express from "express";
- import internalAuditLog from "../internal/audit-log.js";
- import jwtdecode from "../lib/express/jwt-decode.js";
- import validator from "../lib/validator/index.js";
- import { express as logger } from "../logger.js";
- const router = express.Router({
- caseSensitive: true,
- strict: true,
- mergeParams: true,
- });
- /**
- * /api/audit-log
- */
- router
- .route("/")
- .options((_, res) => {
- res.sendStatus(204);
- })
- .all(jwtdecode())
- /**
- * GET /api/audit-log
- *
- * Retrieve all logs
- */
- .get(async (req, res, next) => {
- try {
- const data = await validator(
- {
- additionalProperties: false,
- properties: {
- expand: {
- $ref: "common#/properties/expand",
- },
- query: {
- $ref: "common#/properties/query",
- },
- },
- },
- {
- expand: typeof req.query.expand === "string" ? req.query.expand.split(",") : null,
- query: typeof req.query.query === "string" ? req.query.query : null,
- },
- );
- const rows = await internalAuditLog.getAll(res.locals.access, data.expand, data.query);
- res.status(200).send(rows);
- } catch (err) {
- logger.debug(`${req.method.toUpperCase()} ${req.path}: ${err}`);
- next(err);
- }
- });
- /**
- * Specific audit log entry
- *
- * /api/audit-log/123
- */
- router
- .route("/:event_id")
- .options((_, res) => {
- res.sendStatus(204);
- })
- .all(jwtdecode())
- /**
- * GET /api/audit-log/123
- *
- * Retrieve a specific entry
- */
- .get(async (req, res, next) => {
- try {
- const data = await validator(
- {
- required: ["event_id"],
- additionalProperties: false,
- properties: {
- event_id: {
- $ref: "common#/properties/id",
- },
- expand: {
- $ref: "common#/properties/expand",
- },
- },
- },
- {
- event_id: req.params.event_id,
- expand:
- typeof req.query.expand === "string"
- ? req.query.expand.split(",")
- : null,
- },
- );
- const item = await internalAuditLog.get(res.locals.access, {
- id: data.event_id,
- expand: data.expand,
- });
- res.status(200).send(item);
- } catch (err) {
- logger.debug(`${req.method.toUpperCase()} ${req.path}: ${err}`);
- next(err);
- }
- });
- export default router;
|