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/create.js

123 lines
2.7 KiB
JavaScript
Raw Normal View History

2019-08-31 04:07:25 +05:00
const moment = require('moment');
const services = require('../../services/custom');
2019-08-31 04:07:25 +05:00
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
},
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;
2022-12-26 21:10:50 +01:00
const { list } = await sails.helpers.lists
.getProjectPath(inputs.listId)
.intercept('pathNotFound', () => Errors.LIST_NOT_FOUND);
2019-08-31 04:07:25 +05:00
const boardMembership = await BoardMembership.findOne({
2022-12-26 21:10:50 +01:00
boardId: list.boardId,
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', '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({
values: {
...values,
list,
creatorUser: currentUser,
},
request: this.req,
})
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT);
2019-08-31 04:07:25 +05:00
const cardUrl = services.buildCardUrl(card);
const messageText = cardUrl + ' was created by ' + currentUser.username + ' in *' + list.name + '*';
services.sendSlackMessage(messageText)
.then(() => { console.log('Slack message sent successfully.'); })
.catch((error) => { console.error('Failed to send Slack message:', error.message); });
return {
item: card,
};
},
2019-08-31 04:07:25 +05:00
};