chore: replace axios by fetch

Fix lint errors too
pull/676/head
Matthieu Bollot 2 years ago
parent 9b6766cff6
commit 4e02efa0ee
No known key found for this signature in database
GPG Key ID: 426E24F35CBB5BC2

@ -56,7 +56,6 @@
} }
}, },
"dependencies": { "dependencies": {
"axios": "^1.6.2",
"concurrently": "^8.2.2", "concurrently": "^8.2.2",
"husky": "^8.0.3", "husky": "^8.0.3",
"lint-staged": "^15.1.0" "lint-staged": "^15.1.0"

@ -111,10 +111,10 @@ module.exports = {
.intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT); .intercept('positionMustBeInValues', () => Errors.POSITION_MUST_BE_PRESENT);
const cardUrl = services.buildCardUrl(card); const cardUrl = services.buildCardUrl(card);
const messageText = cardUrl + ' was created by ' + currentUser.name + ' in *' + list.name + '*'; const messageText = `${cardUrl} was created by ${currentUser.name} in *${list.name}*`;
services.sendSlackMessage(messageText) services.sendSlackMessage(messageText).catch((error) => {
.then(() => { console.log('Slack message sent successfully.'); }) throw new Error('Failed to send Slack message:', error.message);
.catch((error) => { console.error('Failed to send Slack message:', error.message); }); });
return { return {
item: card, item: card,

@ -56,10 +56,10 @@ module.exports = {
throw Errors.CARD_NOT_FOUND; throw Errors.CARD_NOT_FOUND;
} }
const messageText = '*' + card.name + '* was deleted by ' + currentUser.name; const messageText = `*${card.name}* was deleted by ${currentUser.name}`;
services.sendSlackMessage(messageText) services.sendSlackMessage(messageText).catch((error) => {
.then(() => { console.log('Slack message sent successfully.'); }) throw new Error('Failed to send Slack message:', error.message);
.catch((error) => { console.error('Failed to send Slack message:', error.message); }); });
return { return {
item: card, item: card,

@ -203,10 +203,10 @@ module.exports = {
if (cardMoved) { if (cardMoved) {
const cardUrl = services.buildCardUrl(card); const cardUrl = services.buildCardUrl(card);
const messageText = cardUrl + ' was moved by ' + currentUser.name + ' to *' + nextList.name + '*'; const messageText = `${cardUrl} was moved by ${currentUser.name} to *${nextList.name}*`;
services.sendSlackMessage(messageText) services.sendSlackMessage(messageText).catch((error) => {
.then(() => { console.log('Slack message sent successfully.'); }) throw new Error('Failed to send Slack message:', error.message);
.catch((error) => { console.error('Failed to send Slack message:', error.message); }); });
} }
return { return {

@ -67,10 +67,10 @@ module.exports = {
}); });
const cardUrl = services.buildCardUrl(card); const cardUrl = services.buildCardUrl(card);
const messageText = '*' + currentUser.name + '* commented on ' + cardUrl + ':\n>' + inputs.text; const messageText = `*${currentUser.name}* commented on ${cardUrl}:\n>${inputs.text}`;
services.sendSlackMessage(messageText) services.sendSlackMessage(messageText).catch((error) => {
.then(() => { console.log('Slack message sent successfully.'); }) throw new Error('Failed to send Slack message:', error.message);
.catch((error) => { console.error('Failed to send Slack message:', error.message); }); });
return { return {
item: action, item: action,

@ -1,58 +1,61 @@
const axios = require('axios');
const slackPostUrl = 'https://slack.com/api/chat.postMessage'; const slackPostUrl = 'https://slack.com/api/chat.postMessage';
const channelId = process.env.SLACK_CHANNEL_ID; const channelId = process.env.SLACK_CHANNEL_ID;
const slackAPIToken = process.env.SLACK_BOT_TOKEN; const slackAPIToken = process.env.SLACK_BOT_TOKEN;
const plankaProdUrl = process.env.BASE_URL; const plankaProdUrl = process.env.BASE_URL;
async function sendSlackMessage(messageText) { async function sendSlackMessage(messageText) {
if (!slackAPIToken) { if (!slackAPIToken) {
throw new Error('No Slack BOT token found'); throw new Error('No Slack BOT token found');
} }
console.log('Sending to Slack'); const postData = {
blocks: [
const postData = { {
blocks: [ { type: 'section',
type: 'section', text: {
text: { type: 'mrkdwn',
type: 'mrkdwn', text: messageText,
text: messageText,
},
}]
};
try {
const config = {
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${slackAPIToken}`,
}, },
}; },
],
axios.post(slackPostUrl, { ...postData, channel: channelId }, config) channel: channelId,
.then(response => { };
console.log('Slack response:', response.data);
}) const config = {
.catch(error => { headers: {
console.error('Error sending to Slack:', error.message); 'Content-Type': 'application/json; charset=utf-8',
}); Authorization: `Bearer ${slackAPIToken}`,
},
console.log('Slack response:', response.data); };
return response.data;
} catch (error) { const response = await fetch(slackPostUrl, {
console.error('Error sending to Slack:', error.message); method: 'POST',
throw error; headers: config.headers,
} body: JSON.stringify(postData),
});
if (!response.ok) {
sails.log.Error('Error sending to Slack :', response.error);
return Promise.reject(response);
} }
function buildCardUrl(card) { const responseText = await new Response(response.body).text();
const url = plankaProdUrl + '/cards/' + card.id; const jsonBody = JSON.parse(responseText);
const cardUrl = '<' + url + '|' + card.name + '>'; if (!jsonBody.ok) {
console.log(cardUrl); sails.log.Error('Error sending to Slack :', jsonBody.error);
return cardUrl; return Promise.reject(response);
} }
module.exports = { return response;
sendSlackMessage, }
buildCardUrl
}; function buildCardUrl(card) {
const url = `${plankaProdUrl}/cards/${card.id}`;
const cardUrl = `<${url}|${card.name}>`;
return cardUrl;
}
module.exports = {
sendSlackMessage,
buildCardUrl,
};

Loading…
Cancel
Save