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

147 lines
3 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
},
LIST_NOT_FOUND: {
2020-04-03 00:35:25 +05:00
listNotFound: 'List 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
},
listId: {
type: 'string',
regex: /^[0-9]+$/,
2019-08-31 04:07:25 +05:00
},
2020-05-05 01:30:06 +05:00
boardId: {
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',
2020-04-03 00:35:25 +05:00
custom: (value) =>
_.isPlainObject(value) &&
_.size(value) === 2 &&
(_.isNull(value.startedAt) || moment(value.startedAt, moment.ISO_8601, true).isValid()) &&
_.isFinite(value.total),
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',
},
listNotFound: {
responseType: 'notFound',
},
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 toList;
let toBoard;
2019-08-31 04:07:25 +05:00
if (!_.isUndefined(inputs.listId) && inputs.listId !== list.id) {
toList = await List.findOne({
id: inputs.listId,
2020-05-05 01:30:06 +05:00
boardId: inputs.boardId || card.boardId,
2019-08-31 04:07:25 +05:00
});
if (!toList) {
throw Errors.LIST_NOT_FOUND;
}
2020-05-05 01:30:06 +05:00
({ board: toBoard, project } = await sails.helpers
2020-05-05 01:30:06 +05:00
.getListToProjectPath(toList.id)
.intercept('pathNotFound', () => Errors.LIST_NOT_FOUND));
isUserMemberForProject = await sails.helpers.isUserMemberForProject(
project.id,
currentUser.id,
);
if (!isUserMemberForProject) {
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,
values,
toList,
toBoard,
list,
board,
currentUser,
this.req,
);
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
};