Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andreipradan/telegrambot
A telegram bot to interactively check OFFICIAL COVID-19 stats for Romania and other countries.
https://github.com/andreipradan/telegrambot
covid-19 covid19 google-cloud-functions google-cloud-platform google-cloud-run telegram telegram-bot telegram-channel telegrambot
Last synced: 7 days ago
JSON representation
A telegram bot to interactively check OFFICIAL COVID-19 stats for Romania and other countries.
- Host: GitHub
- URL: https://github.com/andreipradan/telegrambot
- Owner: andreipradan
- License: mit
- Created: 2020-03-20T00:40:06.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-17T23:23:15.000Z (9 months ago)
- Last Synced: 2024-04-28T03:23:06.603Z (9 months ago)
- Topics: covid-19, covid19, google-cloud-functions, google-cloud-platform, google-cloud-run, telegram, telegram-bot, telegram-channel, telegrambot
- Language: HTML
- Homepage: https://telegrambot.pradan.dev/
- Size: 410 KB
- Stars: 7
- Watchers: 1
- Forks: 0
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Welcome to telegrambot π
> A Flask project to interactively check OFFICIAL COVID-19 stats for Romania and other countries.
>[![doc](https://storage.googleapis.com/telegrambot/static/images/website_preview.png)](https://coronavirus.pradan.dev/)
#### Telegram channel: https://coronavirus.pradan.dev/channel/
>[![doc](https://storage.googleapis.com/telegrambot/static/images/covid_updates_channel.png)](https://coronavirus.pradan.dev/channel/)#### Telegram bot: https://coronavirus.pradan.dev/bot/
>[![doc](docs/inline.png)](https://coronavirus.pradan.dev/bot/)## Setup
#### Prerequisites:
- Create a new telegram bot by sending the `/newbot` command to BotFather [here](https://t.me/botfather)
- give it a `name`: e.g. MyExtraordinaryBot (does not need to end in "Bot")
- give it a `username`: e.g. my_extraordinary_bot (this one does need to end in "bot")
- write down your `token` that BotFather gives you at the end. You will need it later on#### Steps
1. Start the Flask local server:
```sh
$ TOKEN= python flask_app.py
```
2. [Ngrok](https://ngrok.com/)Telegram bots need a **https URL** as a callback for sending update events. Details [here](https://core.telegram.org/bots/api#getting-updates)
Ngrok is a great utility used for exposing your localhost to a publicly accessible https URL
- sign up here https://dashboard.ngrok.com/signup
- install `ngrok` and set it up using these four simple steps here: https://dashboard.ngrok.com/get-started
- run it locally: `ngrok http 5000`
- this will start a session and forward your localhost port 5000 to an online tunnel
- copy the output of the https tunnel e.g. ![doc](docs/ngrok.png)
3. Set the webhook URL for your telegram bot using the [config/webhook.py](config/webhook.py) script
```sh
$ python config/webhook.py --token=1234567890:ABCD-aBsadfASDFasfdb-v
Current webhook url: is not set up$ python config/webhook.py --token=1234567890:ABCD-aBsadfASDFasfdb-v --set
INFO:root:Current webhook url: https://5efg4d21.ngrok.io/1234567890:ABCD-aBsadfASDFasfdb-v
```
- replace the host and token with your own
- your telegram bot should now be pointed to your newly created public URL that is tunneling to your localhost 5000 port4. Data source setup
The telegrambot pull all of its data from mongodb collections
Configure a MongoDB database:
- Steps for setting up mongo db locally [here](https://docs.mongodb.com/manual/installation/)
- Steps for setting up a remote mongo db cluster [here](https://docs.atlas.mongodb.com/getting-started/)
- set the MONGO_DB_HOST env variable with the MongoDB Atlas connection string
- set the DATABASE_NAME on the environment (optional => defaults to "telegrambot_db")5. Populate database with initial data
```shell script
python config/sync_data.py --all
```
- `python config/sync_data.py --help` for the complete list of parameters#### Troubleshooting:
1. Make sure you've set the correct TOKEN when starting the Flask server
- the callback url contains your bot's token so if the TOKEN environment variable is not set correctly, when using the bot you will see a lot of 404s in the server console from the telegram bot trying to post callbacks (respond to commands) to an invalid URL2. Make sure ngrok is tunneling your localhost:
- you can do this by navigating to the https URL that ngrok provided - directly into your browser3. Make sure you've set the correct webhook URL.
```shell script
> python config/webhook.py --token=1234567890:ABCD-aBsadfASDFasfdb-v
Current webhook url: https://5efg4d21.ngrok.io/1234567890:ABCD-aBsadfASDFasfdb-v
```
- should be the ngrok provided HTTPS URL + your telegram bot token## Run tests
```sh
pytest tests --cov .
```
- for html coverage report add `--cov-report=html`## Upcoming features
- English keys
- More data sources
- Charts and diagrams for historical data, stats based on gender, age, etc.
- Storing historical data for Global regions/countries (currently only today's statistics)
- TBD: more google cloud commands## Frontend
https://github.com/afourmy/flask-gentelella
## Data sources
- https://datelazi.ro/
- https://stirioficiale.ro/
- https://worldometers.info/
- Johns Hopkins Covid-19 repository: https://github.com/CSSEGISandData/COVID-19## Author
π€ **Andrei PrΔdan**
* Website: [pradan.dev](https://pradan.dev/)
* Github: [andreipradan](https://github.com/andreipradan)
* LinkedIn: [andreipradan](https://linkedin.com/in/andreipradan)## π€ Contributing
Contributions, issues and feature requests are welcome!
Feel free to check the [issues page](https://github.com/andreipradan/telegrambot/issues)## Show your support
Give a βοΈ if this project helped you!
***
_This README was generated with β€οΈ by [readme-md-generator](https://github.com/kefranabg/readme-md-generator)_