From 7c3505aab9e89c7df5808657401a2552c5100482 Mon Sep 17 00:00:00 2001 From: Jannis R Date: Wed, 7 Mar 2018 16:04:31 +0100 Subject: [PATCH] support web hooks --- index.js | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/index.js b/index.js index 22293a8..56cf50f 100644 --- a/index.js +++ b/index.js @@ -21,7 +21,11 @@ if (!TOKEN) { process.exit(1) } - +const HOSTNAME = process.env.HOSTNAME +if (!HOSTNAME) { + console.error('Missing HOSTNAME env var.') + process.exit(1) +} const parseCmd = (msg) => { if ('string' !== typeof msg.text) return null @@ -37,7 +41,18 @@ const error = `\ *Oh snap! An error occured.* Report this to my creator @derhuerst to help making this bot better.` -const api = new Api(TOKEN, {polling: true}) +let api +if (process.env.NODE_ENV === 'production') { + console.info('using web hooks at ' + HOSTNAME) + api = new Api(TOKEN, {polling: false}) + api.setWebHook(HOSTNAME, { + certificate: `/etc/letsencrypt/live/${HOSTNAME}/fullchain.pem` + }) +} else { + console.info('using polling') + api = new Api(TOKEN, {polling: true}) +} + api.on('message', async (msg) => { log(msg) const user = msg.from ? msg.from.id : msg.chat.id