pastel.codes/routes/contact.js

73 lines
2.6 KiB
JavaScript
Raw Normal View History

2020-06-29 10:09:10 +01:00
var express = require('express');
2020-07-01 12:10:30 +01:00
var rate_limit = require("express-rate-limit")
2020-06-29 10:09:10 +01:00
const {verify} = require('hcaptcha');
const nodemailer = require('nodemailer')
var router = express.Router();
const sgMail = require('@sendgrid/mail');
sgMail.setApiKey(process.env.SENDGRID_API_KEY);
2020-07-01 12:10:30 +01:00
const contact_rate_limit = rate_limit({
windowMs: 10 * 60 * 1000, // 10 minutes
2020-07-01 12:20:30 +01:00
max: 5, // limit each IP to 10 requests per windowMs
2020-07-01 12:10:30 +01:00
message: "Too many contact requests, try again later.",
handler: function (req, res /*, next*/) {
res.render('error', {
title: "Error",
message: "Too many contact requests, try again later.",
error: {status: null}
})
2020-07-01 12:10:30 +01:00
},
});
2020-06-29 10:09:10 +01:00
// POST route from contact form
router.post('/', contact_rate_limit, (req, res) => {
2020-07-01 15:19:12 +01:00
const TO_MAIL_USER = process.env.TO_MAIL_USER
const FROM_MAIL_USER = process.env.FROM_MAIL_USER
2020-06-29 10:09:10 +01:00
const HCAPTCHA_KEY = process.env.HCAPTCHA_KEY
2020-07-01 16:22:49 +01:00
const REPLY_TO_MAIL = process.env.REPLY_TO_MAIL
2020-06-29 10:09:10 +01:00
const token = req.body["g-recaptcha-response"];
2020-07-01 12:10:30 +01:00
const ip = req.headers['x-forwarded-for'] || req.connection.remoteAddress;
2020-06-29 10:09:10 +01:00
verify(HCAPTCHA_KEY, token)
.then((data) => {
if (data.success === true) {
const msg = {
2020-07-01 15:19:12 +01:00
to: TO_MAIL_USER,
from: FROM_MAIL_USER,
2020-06-29 10:09:10 +01:00
subject: 'New message from contact form at pastel.codes',
2020-07-01 12:10:30 +01:00
text: `${req.body.firstname} ${req.body.lastname} (${req.body.email})\nsays: ${req.body.message}\n\nip: ${ip}`
};
2020-06-29 10:09:10 +01:00
sgMail
.send(msg)
.then(() => {
res.render('contact', {
message: "I will get back to you soon!",
success: "Make sure the email is from ",
2020-07-01 16:22:49 +01:00
email: REPLY_TO_MAIL
})
})
.catch(error => {
2020-06-29 10:09:10 +01:00
console.log(error)
res.render('error', {message: "Email did not send"})
});
2020-06-29 10:09:10 +01:00
} else {
// // rerender with same info in the text box and show error message
res.render('contact', {message: "Captcha failed, try again"});
2020-06-29 10:09:10 +01:00
}
})
.catch(error => {
console.log(error);
res.render('contact', {message: "Something wrong happened, try again later"});
2020-06-29 10:09:10 +01:00
});
})
/* GET home page. */
router.get('/', function (req, res, next) {
res.render('contact', {title: 'Contact', description: "Contact me!"});
2020-06-29 10:09:10 +01:00
});
module.exports = router;