1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-18 20:59:44 +02:00
planka/server/api/controllers/cards/update.js

203 lines
4.2 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
const moment = require('moment');
const Errors = {
NOT_ENOUGH_RIGHTS: {
notEnoughRights: 'Not enough rights',
},
2019-08-31 04:07:25 +05:00
CARD_NOT_FOUND: {
2020-04-03 00:35:25 +05:00
cardNotFound: 'Card not found',
2019-08-31 04:07:25 +05:00
},
BOARD_NOT_FOUND: {
boardNotFound: 'Board not found',
},
2019-08-31 04:07:25 +05:00
LIST_NOT_FOUND: {
2020-04-03 00:35:25 +05:00
listNotFound: 'List not found',
},
LIST_MUST_BE_PRESENT: {
listMustBePresent: 'List must be present',
},
POSITION_MUST_BE_PRESENT: {
positionMustBePresent: 'Position must be present',
},
2019-08-31 04:07:25 +05:00
};
2022-12-26 21:10:50 +01:00
const dueDateValidator = (value) => moment(value, moment.ISO_8601, true).isValid();
const stopwatchValidator = (value) => {
2022-12-26 21:10:50 +01:00
if (!_.isPlainObject(value) || _.size(value) !== 2) {
return false;
}
if (
!_.isNull(value.startedAt) &&
_.isString(value.startedAt) &&
!moment(value.startedAt, moment.ISO_8601, true).isValid()
) {
return false;
}
if (!_.isFinite(value.total)) {
return false;
}
return true;
};
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
},
boardId: {
type: 'string',
regex: /^[0-9]+$/,
2019-08-31 04:07:25 +05:00
},
listId: {
2020-05-05 01:30:06 +05:00
type: 'string',
regex: /^[0-9]+$/,
},
2020-04-23 03:02:53 +05:00
coverAttachmentId: {
type: 'string',
regex: /^[0-9]+$/,
allowNull: true,
},
2019-08-31 04:07:25 +05:00
position: {
type: 'number',
2019-08-31 04:07:25 +05:00
},
name: {
type: 'string',
isNotEmptyString: true,
2019-08-31 04:07:25 +05:00
},
description: {
type: 'string',
isNotEmptyString: true,
allowNull: true,
2019-08-31 04:07:25 +05:00
},
dueDate: {
2019-08-31 04:07:25 +05:00
type: 'string',
2022-12-26 21:10:50 +01:00
custom: dueDateValidator,
allowNull: true,
2019-08-31 04:07:25 +05:00
},
stopwatch: {
2019-08-31 04:07:25 +05:00
type: 'json',
custom: stopwatchValidator,
2019-08-31 04:07:25 +05:00
},
isSubscribed: {
type: 'boolean',
},
2019-08-31 04:07:25 +05:00
},
exits: {
notEnoughRights: {
responseType: 'forbidden',
},
2020-04-03 00:35:25 +05:00
cardNotFound: {
responseType: 'notFound',
},
boardNotFound: {
responseType: 'notFound',
},
2020-04-03 00:35:25 +05:00
listNotFound: {
responseType: 'notFound',
},
listMustBePresent: {
responseType: 'unprocessableEntity',
},
positionMustBePresent: {
responseType: 'unprocessableEntity',
},
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.cards
.getProjectPath(inputs.id)
2020-04-03 00:35:25 +05:00
.intercept('pathNotFound', () => Errors.CARD_NOT_FOUND);
2019-08-31 04:07:25 +05:00
let { card } = path;
const { list, board } = path;
let boardMembership = await BoardMembership.findOne({
boardId: board.id,
userId: currentUser.id,
});
2019-08-31 04:07:25 +05:00
if (!boardMembership) {
2019-08-31 04:07:25 +05:00
throw Errors.CARD_NOT_FOUND; // Forbidden
}
if (boardMembership.role !== BoardMembership.Roles.EDITOR) {
throw Errors.NOT_ENOUGH_RIGHTS;
}
let nextBoard;
if (!_.isUndefined(inputs.boardId)) {
({ board: nextBoard } = await sails.helpers.boards
.getProjectPath(inputs.boardId)
.intercept('pathNotFound', () => Errors.BOARD_NOT_FOUND));
2020-05-05 01:30:06 +05:00
boardMembership = await BoardMembership.findOne({
boardId: nextBoard.id,
userId: currentUser.id,
});
2020-05-05 01:30:06 +05:00
if (!boardMembership) {
throw Errors.BOARD_NOT_FOUND; // Forbidden
}
if (boardMembership.role !== BoardMembership.Roles.EDITOR) {
throw Errors.NOT_ENOUGH_RIGHTS;
}
}
let nextList;
if (!_.isUndefined(inputs.listId)) {
nextList = await List.findOne({
id: inputs.listId,
boardId: (nextBoard || board).id,
});
if (!nextList) {
2020-05-05 01:30:06 +05:00
throw Errors.LIST_NOT_FOUND; // Forbidden
}
2019-08-31 04:07:25 +05:00
}
const values = _.pick(inputs, [
2020-04-23 03:02:53 +05:00
'coverAttachmentId',
2019-08-31 04:07:25 +05:00
'position',
'name',
'description',
'dueDate',
'stopwatch',
'isSubscribed',
2019-08-31 04:07:25 +05:00
]);
2022-12-26 21:10:50 +01:00
card = await sails.helpers.cards.updateOne
.with({
board,
list,
record: card,
values: {
...values,
board: nextBoard,
list: nextList,
},
user: currentUser,
request: this.req,
})
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT)
.intercept('listMustBeInValues', () => Errors.LIST_MUST_BE_PRESENT);
2019-08-31 04:07:25 +05:00
if (!card) {
throw Errors.CARD_NOT_FOUND;
}
return {
item: card,
};
},
2019-08-31 04:07:25 +05:00
};