Skip to content

Instantly share code, notes, and snippets.

@the-vampiire
Last active October 26, 2018 20:34
Show Gist options
  • Select an option

  • Save the-vampiire/e31f1d6ac6df1e52c34a17d4fc4a7bce to your computer and use it in GitHub Desktop.

Select an option

Save the-vampiire/e31f1d6ac6df1e52c34a17d4fc4a7bce to your computer and use it in GitHub Desktop.
github securing your app webhook example in node js and express
const crypto = require('crypto');
const createComparisonSignature = (body) => {
const hmac = crypto.createHmac('sha1', process.env.OCTO_WIZARD_HOOK_SECRET);
const self_signature = hmac.update(JSON.stringify(body)).digest('hex');
return `sha1=${self_signature}`; // shape in GitHub header
}
const compareSignatures = (signature, comparison_signature) => {
const source = Buffer.from(signature);
const comparison = Buffer.from(comparison_signature);
return crypto.timingSafeEqual(source, comparison); // constant time comparison
}
const verifyGithubPayload = (req, res, next) => {
const { headers, body } = req;
const signature = headers['x-hub-signature'];
const comparison_signature = createComparisonSignature(body);
if (!compareSignatures(signature, comparison_signature)) {
return res.status(401).send('Mismatched signatures');
}
const { action, ...payload } = body;
req.event_type = headers['x-github-event']; // one of: https://developer.github.com/v3/activity/events/types/
req.action = action;
req.payload = payload;
next();
}
module.exports = verifyGithubPayload;
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment