Numeric conversions for all ids coming in as route req params. Infrastructure for proper error message when dependencies prevent entity deletion.
42 lines
No EOL
1.5 KiB
JavaScript
42 lines
No EOL
1.5 KiB
JavaScript
'use strict';
|
|
|
|
const passport = require('../../lib/passport');
|
|
const lists = require('../../models/lists');
|
|
|
|
const router = require('../../lib/router-async').create();
|
|
const {castToInteger} = require('../../lib/helpers');
|
|
|
|
|
|
router.postAsync('/lists-table', passport.loggedIn, async (req, res) => {
|
|
return res.json(await lists.listDTAjax(req.context, req.body));
|
|
});
|
|
|
|
router.postAsync('/lists-with-segment-by-campaign-table/:campaignId', passport.loggedIn, async (req, res) => {
|
|
return res.json(await lists.listWithSegmentByCampaignDTAjax(req.context, castToInteger(req.params.campaignId), req.body));
|
|
});
|
|
|
|
router.getAsync('/lists/:listId', passport.loggedIn, async (req, res) => {
|
|
const list = await lists.getByIdWithListFields(req.context, castToInteger(req.params.listId));
|
|
list.hash = lists.hash(list);
|
|
return res.json(list);
|
|
});
|
|
|
|
router.postAsync('/lists', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
return res.json(await lists.create(req.context, req.body));
|
|
});
|
|
|
|
router.putAsync('/lists/:listId', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
const entity = req.body;
|
|
entity.id = castToInteger(req.params.listId);
|
|
|
|
await lists.updateWithConsistencyCheck(req.context, entity);
|
|
return res.json();
|
|
});
|
|
|
|
router.deleteAsync('/lists/:listId', passport.loggedIn, passport.csrfProtection, async (req, res) => {
|
|
await lists.remove(req.context, castToInteger(req.params.listId));
|
|
return res.json();
|
|
});
|
|
|
|
|
|
module.exports = router; |