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

128 lines
2.5 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
LIST_NOT_FOUND: {
2020-04-03 00:35:25 +05:00
listNotFound: 'List not found',
},
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: {
listId: {
type: 'string',
regex: /^[0-9]+$/,
2022-12-26 21:10:50 +01:00
required: true,
},
2019-08-31 04:07:25 +05:00
position: {
type: 'number',
},
name: {
type: 'string',
required: 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,
2019-08-31 04:07:25 +05:00
},
dueCompleted: {
type: 'boolean',
},
stopwatch: {
2019-08-31 04:07:25 +05:00
type: 'json',
custom: stopwatchValidator,
},
2019-08-31 04:07:25 +05:00
},
exits: {
notEnoughRights: {
responseType: 'forbidden',
},
2020-04-03 00:35:25 +05:00
listNotFound: {
responseType: 'notFound',
},
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 { list, board, project } = await sails.helpers.lists
2022-12-26 21:10:50 +01:00
.getProjectPath(inputs.listId)
.intercept('pathNotFound', () => Errors.LIST_NOT_FOUND);
2019-08-31 04:07:25 +05:00
const boardMembership = await BoardMembership.findOne({
boardId: board.id,
userId: currentUser.id,
});
2019-08-31 04:07:25 +05:00
if (!boardMembership) {
2022-12-26 21:10:50 +01:00
throw Errors.LIST_NOT_FOUND; // Forbidden
2019-08-31 04:07:25 +05:00
}
if (boardMembership.role !== BoardMembership.Roles.EDITOR) {
throw Errors.NOT_ENOUGH_RIGHTS;
}
const values = _.pick(inputs, [
'position',
'name',
'description',
'dueDate',
'dueCompleted',
'stopwatch',
]);
2019-08-31 04:07:25 +05:00
2022-12-26 21:10:50 +01:00
const card = await sails.helpers.cards.createOne
.with({
project,
board,
2022-12-26 21:10:50 +01:00
values: {
...values,
list,
creatorUser: currentUser,
},
request: this.req,
})
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT);
2019-08-31 04:07:25 +05:00
return {
item: card,
};
},
2019-08-31 04:07:25 +05:00
};