Skip to content

Commit

Permalink
Merge branch 'GlitchSecure-slack-bot-integration'
Browse files Browse the repository at this point in the history
  • Loading branch information
meltyshev committed Apr 7, 2024
2 parents 39e320f + 4df2bec commit bcacfa8
Show file tree
Hide file tree
Showing 6 changed files with 95 additions and 0 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@
}
},
"dependencies": {
"axios": "^1.6.2",
"concurrently": "^8.2.2",
"husky": "^8.0.3",
"lint-staged": "^15.1.0"
Expand Down
7 changes: 7 additions & 0 deletions server/api/controllers/cards/create.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
const moment = require('moment');
const services = require('../../services/slack');

const Errors = {
NOT_ENOUGH_RIGHTS: {
Expand Down Expand Up @@ -109,6 +110,12 @@ module.exports = {
})
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT);

const cardUrl = services.buildCardUrl(card);
const messageText = cardUrl + ' was created by ' + currentUser.name + ' 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,
};
Expand Down
7 changes: 7 additions & 0 deletions server/api/controllers/cards/delete.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
const services = require('../../services/slack');

const Errors = {
NOT_ENOUGH_RIGHTS: {
notEnoughRights: 'Not enough rights',
Expand Down Expand Up @@ -55,6 +57,11 @@ module.exports = {
throw Errors.CARD_NOT_FOUND;
}

const messageText = '*' + card.name + '* was deleted by ' + currentUser.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,
};
Expand Down
14 changes: 14 additions & 0 deletions server/api/controllers/cards/update.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
const moment = require('moment');
const services = require('../../services/slack');

const Errors = {
NOT_ENOUGH_RIGHTS: {
Expand Down Expand Up @@ -175,6 +176,8 @@ module.exports = {
'isSubscribed',
]);

const cardPositionBefore = card.position;

card = await sails.helpers.cards.updateOne
.with({
board,
Expand All @@ -195,6 +198,17 @@ module.exports = {
throw Errors.CARD_NOT_FOUND;
}

const cardPositionAfter = card.position;
const cardMoved = cardPositionBefore !== cardPositionAfter;

if (cardMoved) {
const cardUrl = services.buildCardUrl(card);
const messageText = cardUrl + ' was moved by ' + currentUser.name + ' to *' + nextList.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,
};
Expand Down
8 changes: 8 additions & 0 deletions server/api/controllers/comment-actions/create.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
const services = require('../../services/slack');

const Errors = {
NOT_ENOUGH_RIGHTS: {
notEnoughRights: 'Not enough rights',
Expand Down Expand Up @@ -64,6 +66,12 @@ module.exports = {
request: this.req,
});

const cardUrl = services.buildCardUrl(card);
const messageText = '*' + currentUser.name + '* commented on ' + cardUrl + ':\n>' + inputs.text;
services.sendSlackMessage(messageText)
.then(() => { console.log('Slack message sent successfully.'); })
.catch((error) => { console.error('Failed to send Slack message:', error.message); });

return {
item: action,
};
Expand Down
58 changes: 58 additions & 0 deletions server/api/services/slack.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
const axios = require('axios');
const slackPostUrl = 'https://slack.com/api/chat.postMessage';
const channelId = process.env.SLACK_CHANNEL_ID;
const slackAPIToken = process.env.SLACK_BOT_TOKEN;
const plankaProdUrl = process.env.BASE_URL;

async function sendSlackMessage(messageText) {
if (!slackAPIToken) {
throw new Error('No Slack BOT token found');
}

console.log('Sending to Slack');

const postData = {
blocks: [ {
type: 'section',
text: {
type: 'mrkdwn',
text: messageText,
},
}]
};

try {
const config = {
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${slackAPIToken}`,
},
};

axios.post(slackPostUrl, { ...postData, channel: channelId }, config)
.then(response => {
console.log('Slack response:', response.data);
})
.catch(error => {
console.error('Error sending to Slack:', error.message);
});

console.log('Slack response:', response.data);
return response.data;
} catch (error) {
console.error('Error sending to Slack:', error.message);
throw error;
}
}

function buildCardUrl(card) {
const url = plankaProdUrl + '/cards/' + card.id;
const cardUrl = '<' + url + '|' + card.name + '>';
console.log(cardUrl);
return cardUrl;
}

module.exports = {
sendSlackMessage,
buildCardUrl
};

0 comments on commit bcacfa8

Please sign in to comment.