Numeric conversions for all ids coming in as route req params. Infrastructure for proper error message when dependencies prevent entity deletion.
85 lines
No EOL
3.1 KiB
JavaScript
85 lines
No EOL
3.1 KiB
JavaScript
'use strict';
|
|
|
|
const passport = require('../../lib/passport');
|
|
const _ = require('../../lib/translate')._;
|
|
const reports = require('../../models/reports');
|
|
const reportProcessor = require('../../lib/report-processor');
|
|
const reportHelpers = require('../../lib/report-helpers');
|
|
const shares = require('../../models/shares');
|
|
const contextHelpers = require('../../lib/context-helpers');
|
|
|
|
const router = require('../../lib/router-async').create();
|
|
const {castToInteger} = require('../../lib/helpers');
|
|
|
|
|
|
router.getAsync('/reports/:reportId', passport.loggedIn, async (req, res) => {
|
|
const report = await reports.getByIdWithTemplate(req.context, castToInteger(req.params.reportId));
|
|
report.hash = reports.hash(report);
|
|
return res.json(report);
|
|
});
|
|
|
|
router.postAsync('/reports', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
return res.json(await reports.create(req.context, req.body));
|
|
});
|
|
|
|
router.putAsync('/reports/:reportId', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
const report = req.body;
|
|
report.id = castToInteger(req.params.reportId);
|
|
|
|
await reports.updateWithConsistencyCheck(req.context, report);
|
|
return res.json();
|
|
});
|
|
|
|
router.deleteAsync('/reports/:reportId', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
await reports.remove(req.context, castToInteger(req.params.reportId));
|
|
return res.json();
|
|
});
|
|
|
|
router.postAsync('/reports-table', passport.loggedIn, async (req, res) => {
|
|
return res.json(await reports.listDTAjax(req.context, req.body));
|
|
});
|
|
|
|
router.postAsync('/report-start/:id', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
const id = castToInteger(req.params.id);
|
|
|
|
await shares.enforceEntityPermission(req.context, 'report', id, 'execute');
|
|
|
|
const report = await reports.getByIdWithTemplate(contextHelpers.getAdminContext(), id);
|
|
await shares.enforceEntityPermission(req.context, 'reportTemplate', report.report_template, 'execute');
|
|
|
|
await reportProcessor.start(id);
|
|
res.json();
|
|
});
|
|
|
|
router.postAsync('/report-stop/:id', async (req, res) => {
|
|
const id = castToInteger(req.params.id);
|
|
|
|
await shares.enforceEntityPermission(req.context, 'report', id, 'execute');
|
|
|
|
const report = await reports.getByIdWithTemplate(contextHelpers.getAdminContext(), id);
|
|
await shares.enforceEntityPermission(req.context, 'reportTemplate', report.report_template, 'execute');
|
|
|
|
await reportProcessor.stop(id);
|
|
res.json();
|
|
});
|
|
|
|
router.getAsync('/report-content/:id', async (req, res) => {
|
|
const id = castToInteger(req.params.id);
|
|
|
|
await shares.enforceEntityPermission(req.context, 'report', id, 'viewContent');
|
|
|
|
const report = await reports.getByIdWithTemplate(contextHelpers.getAdminContext(), id);
|
|
res.sendFile(reportHelpers.getReportContentFile(report));
|
|
});
|
|
|
|
router.getAsync('/report-output/:id', async (req, res) => {
|
|
const id = castToInteger(req.params.id);
|
|
|
|
await shares.enforceEntityPermission(req.context, 'report', id, 'viewOutput');
|
|
|
|
const report = await reports.getByIdWithTemplate(contextHelpers.getAdminContext(), id);
|
|
res.sendFile(reportHelpers.getReportOutputFile(report));
|
|
});
|
|
|
|
|
|
module.exports = router; |