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-11-05 18:01:42 +05:00
|
|
|
},
|
2019-08-31 04:07:25 +05:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
inputs: {
|
|
|
|
id: {
|
2019-10-10 02:51:54 +05:00
|
|
|
type: 'string',
|
|
|
|
regex: /^[0-9]+$/,
|
2019-11-05 18:01:42 +05:00
|
|
|
required: true,
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
listId: {
|
2019-10-10 02:51:54 +05:00
|
|
|
type: 'string',
|
2019-11-05 18:01:42 +05:00
|
|
|
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: {
|
2019-11-05 18:01:42 +05:00
|
|
|
type: 'number',
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
name: {
|
|
|
|
type: 'string',
|
2019-11-05 18:01:42 +05:00
|
|
|
isNotEmptyString: true,
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
description: {
|
|
|
|
type: 'string',
|
|
|
|
isNotEmptyString: true,
|
2019-11-05 18:01:42 +05:00
|
|
|
allowNull: true,
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
2019-10-05 06:12:36 +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(),
|
2019-11-05 18:01:42 +05:00
|
|
|
allowNull: true,
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
timer: {
|
|
|
|
type: 'json',
|
2020-04-03 00:35:25 +05:00
|
|
|
custom: (value) =>
|
2020-02-03 18:42:31 +05:00
|
|
|
_.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: {
|
2019-11-05 18:01:42 +05:00
|
|
|
type: 'boolean',
|
|
|
|
},
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
|
|
|
|
exits: {
|
2020-04-03 00:35:25 +05:00
|
|
|
cardNotFound: {
|
|
|
|
responseType: 'notFound',
|
|
|
|
},
|
|
|
|
listNotFound: {
|
2019-11-05 18:01:42 +05:00
|
|
|
responseType: 'notFound',
|
|
|
|
},
|
2019-08-31 04:07:25 +05:00
|
|
|
},
|
|
|
|
|
2019-11-05 18:01:42 +05:00
|
|
|
async fn(inputs, exits) {
|
2019-08-31 04:07:25 +05:00
|
|
|
const { currentUser } = this.req;
|
|
|
|
|
2019-11-05 18:01:42 +05:00
|
|
|
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;
|
2020-05-09 05:30:52 +05:00
|
|
|
const { list, board } = cardToProjectPath;
|
2019-11-05 18:01:42 +05:00
|
|
|
|
2020-05-05 01:30:06 +05:00
|
|
|
let isUserMemberForProject = await sails.helpers.isUserMemberForProject(
|
2019-08-31 04:07:25 +05:00
|
|
|
project.id,
|
2019-11-05 18:01:42 +05:00
|
|
|
currentUser.id,
|
2019-08-31 04:07:25 +05:00
|
|
|
);
|
|
|
|
|
|
|
|
if (!isUserMemberForProject) {
|
|
|
|
throw Errors.CARD_NOT_FOUND; // Forbidden
|
|
|
|
}
|
|
|
|
|
|
|
|
let toList;
|
2020-05-09 05:30:52 +05:00
|
|
|
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
|
|
|
|
2020-05-09 05:30:52 +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',
|
2019-10-05 06:12:36 +05:00
|
|
|
'dueDate',
|
2019-08-31 04:07:25 +05:00
|
|
|
'timer',
|
2019-11-05 18:01:42 +05:00
|
|
|
'isSubscribed',
|
2019-08-31 04:07:25 +05:00
|
|
|
]);
|
|
|
|
|
2020-05-09 05:30:52 +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({
|
2019-11-05 18:01:42 +05:00
|
|
|
item: card,
|
2019-08-31 04:07:25 +05:00
|
|
|
});
|
2019-11-05 18:01:42 +05:00
|
|
|
},
|
2019-08-31 04:07:25 +05:00
|
|
|
};
|