1
0
Fork 0
mirror of https://github.com/plankanban/planka.git synced 2025-07-21 06:09:43 +02:00
planka/server/api/controllers/cards/update.js

174 lines
3.7 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
const moment = require('moment');
const Errors = {
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
};
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',
2020-04-03 00:35:25 +05:00
custom: (value) => moment(value, moment.ISO_8601, true).isValid(),
allowNull: true,
2019-08-31 04:07:25 +05:00
},
timer: {
type: 'json',
custom: (value) => {
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
},
isSubscribed: {
type: 'boolean',
},
2019-08-31 04:07:25 +05:00
},
exits: {
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, exits) {
2019-08-31 04:07:25 +05:00
const { currentUser } = this.req;
const cardToProjectPath = await sails.helpers
2019-08-31 04:07:25 +05:00
.getCardToProjectPath(inputs.id)
2020-04-03 00:35:25 +05:00
.intercept('pathNotFound', () => Errors.CARD_NOT_FOUND);
2019-08-31 04:07:25 +05:00
2020-05-05 01:30:06 +05:00
let { card, project } = cardToProjectPath;
const { list, board } = cardToProjectPath;
2020-05-05 01:30:06 +05:00
let isUserMemberForProject = await sails.helpers.isUserMemberForProject(
2019-08-31 04:07:25 +05:00
project.id,
currentUser.id,
2019-08-31 04:07:25 +05:00
);
if (!isUserMemberForProject) {
throw Errors.CARD_NOT_FOUND; // Forbidden
}
let toBoard;
if (!_.isUndefined(inputs.boardId)) {
({ board: toBoard, project } = await sails.helpers
.getBoardToProjectPath(inputs.boardId)
.intercept('pathNotFound', () => Errors.BOARD_NOT_FOUND));
2020-05-05 01:30:06 +05:00
isUserMemberForProject = await sails.helpers.isUserMemberForProject(
project.id,
currentUser.id,
);
if (!isUserMemberForProject) {
throw Errors.BOARD_NOT_FOUND; // Forbidden
}
}
let toList;
if (!_.isUndefined(inputs.listId)) {
toList = await List.findOne({
id: inputs.listId,
boardId: (toBoard || board).id,
});
if (!toList) {
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',
2019-08-31 04:07:25 +05:00
'timer',
'isSubscribed',
2019-08-31 04:07:25 +05:00
]);
card = await sails.helpers
.updateCard(card, toBoard, toList, values, board, list, currentUser, this.req)
.intercept('toListMustBePresent', () => Errors.LIST_MUST_BE_PRESENT)
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT);
2019-08-31 04:07:25 +05:00
if (!card) {
throw Errors.CARD_NOT_FOUND;
}
return exits.success({
item: card,
2019-08-31 04:07:25 +05:00
});
},
2019-08-31 04:07:25 +05:00
};