-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathworker.js
More file actions
57 lines (48 loc) · 1.83 KB
/
Copy pathworker.js
File metadata and controls
57 lines (48 loc) · 1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
'use strict';
const axios = require('axios');
const retry = require('./lib/retry');
const RESPONSE_TIMEOUT_AFTER_MS = 10000;
module.exports.consume = async event => {
const messageData = JSON.parse(event.Records[0].body);
const messageId = event.Records[0].messageId;
const payload = messageData.payload;
const eventType = messageData.eventType || null;
const url = messageData.url;
const headerName = process.env.HEADER_NAME || 'Shotstack';
const config = {
headers: {
['X-' + headerName + '-Event-Type']: eventType,
['X-' + headerName + '-Attempt']: messageData.attempt || 1,
'User-Agent': headerName + '-Webhook/1.0',
'Content-Type': 'application/json'
},
timeout: RESPONSE_TIMEOUT_AFTER_MS
}
try {
console.log('Sending callback to: ', url);
console.log('Payload: ', payload);
const response = await axios.post(url, payload, config);
if (response.status < 200 || response.status >= 400) {
try {
const requeued = await retry.requeue(messageData, messageId);
console.log(requeued);
} catch (error) {
console.log(error);
}
}
console.log('Callback successfully delivered.')
} catch (error) {
if (error.code && error.code === 'ECONNABORTED') {
console.error('Response exceeded timeout of : ' + RESPONSE_TIMEOUT_AFTER_MS + 'ms');
}
if (error.response && error.response.status) {
console.error('Callback POST failed with status code: ' + error.response.status);
}
try {
const requeued = await retry.requeue(messageData, messageId);
console.log(requeued);
} catch (error) {
console.log(error);
}
}
};