Consider:
fastify.get("/paynow", (request, reply) => {
let data = {
TXN_AMOUNT: '10', // Request amount
ORDER_ID: 'ORDER_123455', // Any unique order id
CUST_ID: 'CUST_1238w4' // Any unique customer id
}
// Create Paytm Payment
paytm.createPayment(config, data, function (err, data) {
if (err) {
// Handle error
}
// Store the URL and checksum
let url = data.url;
let checksum = data.checksum;
// Delete it from the data object
delete data.url;
delete data.checksum;
/* Prepare HTML Form and Submit to Paytm */
reply.type('text/html');
reply.raw.writeHead(200, { 'Content-Type': 'text/html' });
reply.header('Content-Type', 'application/x-www-form-urlencoded');
reply.header("Access-Control-Allow-Origin", "*");
reply.header("Access-Control-Expose-Headers", "Content-Range");
reply.header(
"Access-Control-Allow-Headers",
"Origin, X-Requested-With, Content-Type, Accept, Authorization"
);
reply.raw.write('<html>');
reply.raw.write('<head>');
reply.raw.write('<title>Merchant Checkout Page</title>');
reply.raw.write('</head>');
reply.raw.write('<body>');
reply.raw.write('<center><h1>Please do not refresh this page...</h1></center>');
reply.raw.write('<form method="post" action="' + url + '" name="paytm_form">');
for (var x in data) {
reply.raw.write('<input type="hidden" name="' + x + '" value="' + data[x] + '">');
}
reply.raw.write('<input type="hidden" name="CHECKSUMHASH" value="' + checksum + '">');
reply.raw.write('</form>');
reply.raw.write('<script type="text/javascript">');
reply.raw.write('document.paytm_form.submit();');
reply.raw.write('</script>');
reply.raw.write('</body>');
reply.raw.write('</html>');
reply.raw.write('ok')
reply.raw.end();
});
});
fastify.post('/true', (request, reply) => {
console.log('*')
paytm.validate(config, request.body, function (err, data) {
console.log(data)
if (err) {
// Handle error
console.log(err)
}
if (data.status == 'verified') {
// Mark payment done in your db
}
});
});
The Paynow API is working fine, but when it redirects to /true route, it is giving an error:
{"statusCode":415,"code":"FST_ERR_CTP_INVALID_MEDIA_TYPE","error":"Unsupported Media Type","message":"Unsupported Media Type: application/x-www-form-urlencoded"}
I think it is related to Fastify. I really don't know as it is my first project with Fastify. How can I fix it?
Fastify, out of the box, parse only application/json
payload.
To manage forms you need to add these plugins to your project
application/x-www-form-urlencoded
multipart/form-data
(aka file upload)