expressCart/routes/payments/stripe.js

115 lines
4.5 KiB
JavaScript
Raw Normal View History

2019-07-12 18:06:34 +10:00
const express = require('express');
const common = require('../../lib/common');
2019-06-15 15:58:19 +10:00
const { indexOrders } = require('../../lib/indexing');
2019-07-12 18:06:34 +10:00
const numeral = require('numeral');
const stripe = require('stripe')(common.getPaymentConfig().secretKey);
const router = express.Router();
2018-01-07 04:55:48 +10:00
// The homepage of the site
router.post('/checkout_action', (req, res, next) => {
2019-07-12 18:06:34 +10:00
const db = req.app.db;
const config = req.app.config;
const stripeConfig = common.getPaymentConfig();
2018-01-07 04:55:48 +10:00
// charge via stripe
stripe.charges.create({
amount: numeral(req.session.totalCartAmount).format('0.00').replace('.', ''),
currency: stripeConfig.stripeCurrency,
source: req.body.stripeToken,
description: stripeConfig.stripeDescription
}, (err, charge) => {
if(err){
console.info(err.stack);
req.session.messageType = 'danger';
req.session.message = 'Your payment has declined. Please try again';
req.session.paymentApproved = false;
req.session.paymentDetails = '';
res.redirect('/pay');
return;
}
// order status
let paymentStatus = 'Paid';
if(charge.paid !== true){
paymentStatus = 'Declined';
}
// new order doc
2019-07-12 18:06:34 +10:00
const orderDoc = {
2018-01-07 04:55:48 +10:00
orderPaymentId: charge.id,
orderPaymentGateway: 'Stripe',
orderPaymentMessage: charge.outcome.seller_message,
orderTotal: req.session.totalCartAmount,
orderEmail: req.body.shipEmail,
orderFirstname: req.body.shipFirstname,
orderLastname: req.body.shipLastname,
orderAddr1: req.body.shipAddr1,
orderAddr2: req.body.shipAddr2,
orderCountry: req.body.shipCountry,
orderState: req.body.shipState,
orderPostcode: req.body.shipPostcode,
orderPhoneNumber: req.body.shipPhoneNumber,
orderComment: req.body.orderComment,
2018-01-07 04:55:48 +10:00
orderStatus: paymentStatus,
orderDate: new Date(),
orderProducts: req.session.cart
};
// insert order into DB
2019-10-29 18:26:30 +10:00
db.orders.insertOne(orderDoc, (err, newDoc) => {
2018-01-07 04:55:48 +10:00
if(err){
console.info(err.stack);
}
// get the new ID
2019-11-04 16:39:05 +10:00
const newId = newDoc.insertedId;
2018-01-07 04:55:48 +10:00
// add to lunr index
2019-06-15 15:56:51 +10:00
indexOrders(req.app)
2018-01-07 22:14:17 +10:00
.then(() => {
// if approved, send email etc
if(charge.paid === true){
// set the results
req.session.messageType = 'success';
req.session.message = 'Your payment was successfully completed';
req.session.paymentEmailAddr = newDoc.ops[0].orderEmail;
2018-01-07 22:14:17 +10:00
req.session.paymentApproved = true;
req.session.paymentDetails = '<p><strong>Order ID: </strong>' + newId + '</p><p><strong>Transaction ID: </strong>' + charge.id + '</p>';
2018-01-07 04:55:48 +10:00
2018-01-07 22:14:17 +10:00
// set payment results for email
2019-07-12 18:06:34 +10:00
const paymentResults = {
2018-01-07 22:14:17 +10:00
message: req.session.message,
messageType: req.session.messageType,
paymentEmailAddr: req.session.paymentEmailAddr,
paymentApproved: true,
paymentDetails: req.session.paymentDetails
};
2018-01-07 04:55:48 +10:00
2018-01-07 22:14:17 +10:00
// clear the cart
if(req.session.cart){
req.session.cart = null;
req.session.orderId = null;
req.session.totalCartAmount = 0;
}
2018-01-07 04:55:48 +10:00
2018-01-07 22:14:17 +10:00
// send the email with the response
2018-01-22 07:20:46 +10:00
// TODO: Should fix this to properly handle result
2018-01-07 22:14:17 +10:00
common.sendEmail(req.session.paymentEmailAddr, 'Your payment with ' + config.cartTitle, common.getEmailTemplate(paymentResults));
2018-01-07 04:55:48 +10:00
2018-01-07 22:14:17 +10:00
// redirect to outcome
res.redirect('/payment/' + newId);
}else{
// redirect to failure
req.session.messageType = 'danger';
req.session.message = 'Your payment has declined. Please try again';
req.session.paymentApproved = false;
req.session.paymentDetails = '<p><strong>Order ID: </strong>' + newId + '</p><p><strong>Transaction ID: </strong>' + charge.id + '</p>';
res.redirect('/payment/' + newId);
}
});
2018-01-07 04:55:48 +10:00
});
});
});
module.exports = router;