Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/caarmen/slack-health-bot
Slack notifications for limited Withings and Fitbit data
https://github.com/caarmen/slack-health-bot
Last synced: 12 days ago
JSON representation
Slack notifications for limited Withings and Fitbit data
- Host: GitHub
- URL: https://github.com/caarmen/slack-health-bot
- Owner: caarmen
- License: mit
- Created: 2023-04-29T21:39:11.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2025-02-01T15:53:54.000Z (19 days ago)
- Last Synced: 2025-02-01T16:31:38.585Z (19 days ago)
- Language: Python
- Homepage:
- Size: 554 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# slack-health-bot: Slack notifications for limited Withings and Fitbit data
Pushes messages to a pre-selected Slack channel, when users log new weight data in Withings or new sleep or activity data in Fitbit.
[data:image/s3,"s3://crabby-images/f7b23/f7b2300a3d8635465915a28c03af642451c31bcc" alt="GitHub Workflow Status (with branch)"](https://github.com/caarmen/slack-health-bot/actions/workflows/check.yml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/e700a/e700abe07d8b022e00882bfa8c48c46c4de1963f" alt="GitHub"](https://github.com/caarmen/slack-health-bot/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/8fbca/8fbcaf110ad9b563431b103e47ea171969384ac9" alt="GitHub release (latest by date)"](https://github.com/caarmen/slack-health-bot/releases)[data:image/s3,"s3://crabby-images/e1206/e1206f8fc17e6489537d8fdb632106781b27570b" alt="GitHub repo size"](https://github.com/caarmen/slack-health-bot/archive/refs/heads/main.zip)
data:image/s3,"s3://crabby-images/744b4/744b400d7f06a680f545a38d22cda98dab0405f4" alt="GitHub language count"
[data:image/s3,"s3://crabby-images/24034/2403452c832e7ddfca9d9543b0a4c684638e4b2c" alt="GitHub Release Date"](https://github.com/caarmen/slack-health-bot/releases)
[data:image/s3,"s3://crabby-images/0a8d9/0a8d91a9f032d60f801d6270c10064849c7321bf" alt="GitHub commit activity"](https://github.com/caarmen/slack-health-bot/commits/main)
[data:image/s3,"s3://crabby-images/f062c/f062c2940c9bb39eb2f21e2bfc02c3a630a92d51" alt="GitHub last commit"](https://github.com/caarmen/slack-health-bot/commits/main)[data:image/s3,"s3://crabby-images/d4565/d4565910b0b34f9f22f80c9b50384db65d81212c" alt="GitHub Repo stars"](https://github.com/caarmen/slack-health-bot/stargazers)
[data:image/s3,"s3://crabby-images/cefd0/cefd09be9ef518a89dd7f6f162789e4c04f23df7" alt="GitHub forks"](https://github.com/caarmen/slack-health-bot/forks)## Configuration
* Create an application in the [Withings developer dashboard](https://developer.withings.com/dashboard/).
* Create an application in the [Fitbit developer dashboard](https://dev.fitbit.com/apps/).
* Create an application [on Slack](https://api.slack.com/apps), with a webhook to post messages to a specific channel.
* Copy the `.env.template` file to `.env`, and modify the values.
* [Optional]: Copy the `config/app-custom.yaml.template` file to `app-custom.yaml`, and override any values which are defined in `config/app-default.yaml`.## Retrieve the docker image
Retrieve the image:
```
docker pull ghcr.io/caarmen/slack-health-bot:latest
```## Run the docker image
Create a folder on the host where the database will be saved: `/path/to/data/`.
Run the docker image.
```
docker run --detach --publish 8000:8000 -v `pwd`/.env:/app/.env -v `pwd`/app-custom.yaml:/app/config/app-custom.yaml -v /path/to/data/:/tmp/data ghcr.io/caarmen/slack-health-bot
```## Using the application
### Withings
* Open the following url in a browser: http://your-server/v1/withings-authorization/your-slack-alias
- Change `your-server` with the address on which the server is available.
- Change `your-slack-alias` with your slack username.
* Authorize the app in the Withings screen.
* Log a new weight measurement in your Withings account.
- After a couple of minutes, you should see a message in the configured slack channel saying:
> New weight from @`your-slack-alias`: XX kg#### Forcing a measurement to be pushed to slack
You can force a measurement to be posted to slack, by simulating Withings calling the webhook:
```
curl --location 'http://your-server/withings-notification-webhook/' \
--form 'userid="1234567"' \
--form 'startdate="1680377444"' \
--form 'enddate="1682969444"'
```### Fitbit
* Open the following url in a browser: http://your-server/v1/fitbit-authorization/your-slack-alias
- Change `your-server` with the address on which the server is available.
- Change `your-slack-alias` with your slack username.
* Authorize the app in the Fitbit screen.
* Log a new sleep measurement or activity in your Fitbit account.
- After the polling period (if polling is enabled), or after a the webhook is called,
you should see a message in the configured slack channel saying (for the sleep example):
> New sleep from @`your-slack-alias`:
>
> • Went to bed at 22:17
>
> • Woke up at 7:59
>
> • Total sleep: 8h 31m
>
> • Awake: 1h 11m
>
> • Score: 96You can find your userid in the database file:
```
sqlite3 -header -column /path/to/slackhealthbot.db \
"select
slack_alias,
withings_users.oauth_userid as withings_userid,
fitbit_users.oauth_userid as fitbit_userid
from users
left outer join withings_users on users.id = withings_users.user_id
left outer join fitbit_users on users.id = fitbit_users.user_id;"
```