Telegram bot that interacts with Cloudflare Workers and utilizes Google Sheets for data storage. No dependencies and no packages are required.
Just create and deploy a worker, create a bot with BotFather, create GoogleCloud free tier account, and set sheets webhook - that's all there's to it. Adress the guide below.
This bot can:
- Retrieve and search data in a google sheet to reply to your search query.
- Provide language toggle for users
- Send messages on
/welcome
,/help
,/stop
, and more - Uses different kinds of telegram inline keyboards
- Replies to the user's "hi", "bye", and "thank you" with a set of multiple responses
- Get Started with Workers
- Installation
- Deploy
- KVs, Secrets and Vars
- Webhook
- What can this bot do? - visit: https://t.me/historic_archivarius_bot
You can check out this small workers beginner course.
# supposing you've got a repo created
$ git clone https://github.com/USERNAME/REPO_NAME && cd REPO_NAME
# might require sudo
$ npm init cloudflare my-worker worker
After I decided to move scripts from my-worker/
into src/
and config files into the project root.
$ git clone https://github.com/KirilStrezikozin/telegram-bot-cf-workers-and-gle-sheets.git
$ cd telegram-bot-cf-workers-and-gle-sheets
To preview worker locally, run the following:
$ npx wrangler dev --remote
# open a link in your browser
To publish local changes to Cloudflare:
-
Make sure you're logged in:
$ npx wrangler login
-
Add your Cloudflare
account_id
towrangler.toml
:# you can view account details $ npx wrangler whoami
-
Deploy your Worker:
$ npx wrangler deploy
-
Connect a new webhook to the bot with the key you received from BotFather:
# in your browser $ <YOUR_WORKER_URL>/setWebhook?bot=<BOT_API_TOKEN>
-
Create secrets:
BOT_API_TOKEN
(from BotFather),BOT_API_SECRET
(info how here),ADMIN_CHAT_ID
(for maintenance messages - you can create it later when you know admin chat id). -
SHEET_API_TOKEN
andSHEET_ID
secrets (great and full guide here, this bot doesn't useg-sheets-api
package though). -
Redeploy and that's it.
-
Secrets and environment variables can be added via the Cloudflare Worker Dashboard. You can also add them via your terminal:
$ npx wrangler secret put <KEY>
-
Add Environmental Variables to
wrangler.toml
. More info here:# wrangler.toml [vars] LANG = "en"
-
Access Secret Keys and Vars. Nice tutorial here:
// ES Worker
env.SOME_API_KEY
// Service Worker
SOME_API_KEY
-
Add and use KVs. More info here:
# add KV namespace $ npx wrangler kv:namespace create <NAMESPACE_BINDING> # put a key-value pair into the namespace $ npx wrangler kv:key put --binding=<NAMESPACE_BINDING> "<KEY>" "<VALUE>"
// Service Worker
const lang = await kv_bot_prefs.get("LANG");
if (lang === null) {
await kv_bot_prefs.put("LANG", "en");
}
Bot can receive updates via an outgoing webhook. More info on webhooks here. src/worker.js
comes with a several functions to set up a webhook. In order for them to work, ensure BOT_API_TOKEN
and BOT_API_SECRET
were added as worker secrets.
-
Set a Webhook
# You can open a link in your browser to set up a webhook directly: https://api.telegram.org/bot<YOUR_BOT_API>/setWebhook?url=<YOUR_WEBHOOK_URL>&secret_token=<YOUR_WEBHOOK_SECRET_TOKEN>
It is recommended to manage Webhooks locally, but this worker also provides the ability to set it from your worker url. For additional security (so that no one else just opens the link and resets the webhook), provide your
BOT_API_TOKEN
asbot
parameter:# In your browser: <YOUR_WORKER_URL>/setWebhook?bot=<BOT_API_TOKEN> # Response: {"ok":true,"result":true,"description":"Webhook was set"}
-
Similarly to 1, use these urls to Delete webhook or get info about it. The returned response is stringified json out of the fetched url request to telegram api.
# In your browser: <YOUR_WORKER_URL>/deleteWebhook?bot=<BOT_API_TOKEN> # Response: {"ok":true,"result":true,"description":"Webhook was deleted"} # In your browser: <YOUR_WORKER_URL>/getWebhookInfo?bot=<BOT_API_TOKEN> # Response: {"ok":true,"result":{"url":"<YOUR_WEBHOOK_URL>","has_custom_certificate":false,"pending_update_count":0}}