1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-19 21:29:43 +02:00
planka/server/api/controllers/comment-actions/delete.js

77 lines
1.6 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
const Errors = {
NOT_ENOUGH_RIGHTS: {
notEnoughRights: 'Not enough rights',
},
2019-08-31 04:07:25 +05:00
COMMENT_ACTION_NOT_FOUND: {
2020-04-03 00:35:25 +05:00
commentActionNotFound: 'Comment action not found',
},
2019-08-31 04:07:25 +05:00
};
module.exports = {
inputs: {
id: {
type: 'string',
regex: /^[0-9]+$/,
required: true,
},
2019-08-31 04:07:25 +05:00
},
exits: {
notEnoughRights: {
responseType: 'forbidden',
},
2020-04-03 00:35:25 +05:00
commentActionNotFound: {
responseType: 'notFound',
},
2019-08-31 04:07:25 +05:00
},
async fn(inputs) {
2019-08-31 04:07:25 +05:00
const { currentUser } = this.req;
const path = await sails.helpers.actions
.getProjectPath({
id: inputs.id,
type: Action.Types.COMMENT_CARD,
})
.intercept('pathNotFound', () => Errors.COMMENT_ACTION_NOT_FOUND);
2019-08-31 04:07:25 +05:00
let { action } = path;
const { board, project } = path;
2019-08-31 04:07:25 +05:00
const isProjectManager = await sails.helpers.users.isProjectManager(currentUser.id, project.id);
2019-08-31 04:07:25 +05:00
if (!isProjectManager) {
if (action.userId !== currentUser.id) {
throw Errors.COMMENT_ACTION_NOT_FOUND; // Forbidden
}
const boardMembership = await BoardMembership.findOne({
boardId: board.id,
userId: currentUser.id,
});
2019-08-31 04:07:25 +05:00
if (!boardMembership) {
throw Errors.COMMENT_ACTION_NOT_FOUND; // Forbidden
}
if (boardMembership.role !== BoardMembership.Roles.EDITOR && !boardMembership.canComment) {
throw Errors.NOT_ENOUGH_RIGHTS;
}
2019-08-31 04:07:25 +05:00
}
2022-12-26 21:10:50 +01:00
action = await sails.helpers.actions.deleteOne.with({
board,
record: action,
request: this.req,
});
2019-08-31 04:07:25 +05:00
if (!action) {
throw Errors.COMMENT_ACTION_NOT_FOUND;
}
return {
item: action,
};
},
2019-08-31 04:07:25 +05:00
};