Skip to content

Telegram bot written in Go that helps you report and track your daily calories consumption.

License

Notifications You must be signed in to change notification settings

lelika1/foodbot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Foodbot

Foodbot is a Telegram bot written in Go that helps you report and track your daily calories consumption.

How to run Foodbot

In order to run Foodbot you have to create a telegram bot and get an authorization token for it.

Since we rely on SQLite, you also need to install binary dependencies for mattn/go-sqlite3, as described in their README.

After that, you can simply go run to build and start Foodbot:

go run github.com/lelika1/foodbot/cmd/foodbot $TGBOT_AUTH_TOKEN $PATH_TO_DB

Bot usage

When you start talking to the bot for the first time from a new Telegram account, it will ask you about your daily calories limit (it can later be changed using /limit command).

After this short registration phase you can use the following commands:

  • /add - start a flow for reporting new food you ate.
    • The bot will ask the name of a particular dish. It suggests you a couple of dishes you reported most recently. It helps adding food faster.
    • For every dish Foodbot remembers all possible nutrition values (calories/100g) and suggest you to either pick an existing one, or enter a new one.
    • The last step - enter the amount of food you ate in grams.
  • /stat - report statistics about what you ate today and how many calories you still have.
  • /stat7 - a high-level report for the past 7 days to see which days you were in limits and which days you overate.
  • /limit - change you current daily calorie limit
  • /cancel - escape from a multi-staged command without commiting its results.

Implementation details

We use go-telegram-bot-api/telegram-bot-api library to implement a telegram bot.

The main loop of the programm processes updates from the Telegram API one by one, updating data for the user and their in-memory state. We persist user state into SQLite to be able to handle program restarts.

Since we need to support multiple users concurrently talking to the bot as well as processing multi-stage commands (i.e. /add, during which the users answers several questions one after another), we have to maintain a state machine of the conversation explicitly. Relevant code is in internal/foodbot/user.go.

Foodbot can store data in any SQL database since we work against a standard sql.DB interface.

For simplicity, we register mattn/go-sqlite3 SQL driver and store data in a SQLite database file on disc. This can be abstracted easily changed though.

About

Telegram bot written in Go that helps you report and track your daily calories consumption.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages