Receive a webhook event in Node with NodeFetch
In this guide, we'll show you how you can receive a notification via a POST request on your server once the conversion was done. This allows you to trigger a massive amount of conversion without having to wait on their results, and get notified once they are done.
For this guide, we are going to use the "webhook" parameter when sending a request to PDFShift. It expects a URL to which the POST request will be sent once the conversion is done.
Here's a sample:
const fetch = require('node-fetch');
// You can get an API key at https://pdfshift.io
api_key = 'sk_xxxxxxxxxxxx'
params = {
source: 'https://www.example.com',
webhook: 'https://enyygzdj8jy9b.x.pipedream.net/'
}
const response = await fetch('https://api.pdfshift.io/v3/convert/pdf', {
method: 'post',
headers: {
'Authorization': 'Basic ' + Buffer.from('api:' + api_key).toString('base64'),
'Content-Type': 'application/json'
},
body: JSON.stringify(params)
});
if (!response.ok) {
throw new Error(`HTTP error! status: ${response.status}`);
}
console.log('The PDF document was generated and you will receive an event on your webhook once it is done.');
(Please note that the webhook requires a valid API key)
We used Requestbin.com to generate a endpoint that will receive our POST event, but you can set your own endpoint with custom parameters.
When sending the above request to PDFShift, the response will be immediate with a status code of 202 (Request accepted), with the following JSON body:
Once the conversion is actually done at PDFShift, you will receive a POST request containing the following JSON body:
{
"success": true,
"url": "https://pdfshift.s3.amazonaws.com/d/2/2024-03/39775239d74d4accbabb709800f034d2/8a3ec881-fa69-4059-9c71-0f40c633317e.pdf",
"filesize": 34980,
"duration": 1058,
"response": {
"status-code": 200,
"content-length": 0,
"requests": 0,
"duration": 934.5173301696777
},
"executed": "2024-03-06T09:10:10.981098",
"pdf_pages": 1
}
It might occur that the conversion fails, for instance if PDFShift can't access the page or if there is any parameter that cause the loading page to fail (page taking to long to load, etc).
In this case, the POST request will contain the following JSON body:
This can be useful if you don't need to wait for the conversion to continue your process. For instance, when generating all the invoices from last month's payment, you can trigger the conversions and save the PDF on your webhook's destination. This way, you can continue your process without having to wait for the conversion to be done.
For further details on the webhook
property and its usage, please refer to our dedicated documentation.
We hope this guide was helpful. If you have any questions or noticed any issues on the code above,
feel free to drop us a line.