-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgh-hook.js
46 lines (43 loc) · 1.57 KB
/
gh-hook.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
const { promisify } = require('util')
const { resolve } = require('path')
const crypto = require('crypto')
const os = require('os')
const micro = require('micro')
const uuid = require('uuid/v4')
const download = require('download')
const consola = require('consola')
const rimraf = promisify(require('rimraf'))
const json = micro.json
const send = micro.send
// Refresh documentation files (pull from GitHub)
module.exports = async function ({ req, res }, getFiles) {
const body = await json(req)
// Only for production
if (!process.env.GH_HOOK_SECRET || !req.headers['x-hub-signature']) {
return send(res, 501)
}
consola.info('Received GitHub Hook', req.headers['x-github-delivery'])
// Check if X-Hub-Signature matches our secret
const hmac = crypto.createHmac('sha1', process.env.GH_HOOK_SECRET)
hmac.update(JSON.stringify(body))
const signature = 'sha1=' + hmac.digest('hex')
if (req.headers['x-hub-signature'] !== signature) {
return send(res, 403, 'Bad signature')
}
// Accept only push hook events
if (req.headers['x-github-event'] === 'ping') {
return send(res, 200, 'OK')
}
// Only push event authorized
if (req.headers['x-github-event'] !== 'push') {
return send(res, 501, 'Not push event')
}
let clonePath = resolve(os.tmpdir(), uuid())
consola.start('Download repository...')
await download('https://github.com/nuxt/docs/archive/master.zip', clonePath, { extract: true })
clonePath = resolve(clonePath, 'docs-master')
await getFiles(clonePath)
consola.success('Docs file updated!')
await rimraf(clonePath)
send(res, 200, 'OK')
}