Fitness Dial is a Django app that connects to Withings API and fetches your fitness data for most of the supported devices. The data is stored in a PostgreSQL database and can be viewed using the provided Grafana dashboard. If exposed on the Internet, it can also serve as a notification endpoint for receiving data notifications from Withings API. Additionally, it supports manual imports of nutritional data as provided by MyFtinessPal in a form of CSV files.
This is a work in progress project and all the necessary guides will be added/updated in the near future.
To deploy the stack as is (the DB, Django API, Celery workers, Celery flower for monitoring, RabbitMQ, Grafana and the "Fake Withings API") run:
docker compose -f dc-fitness-dial-dev.yml -p fitness-dial up -d
This will build all the required images (or pull them from the registry) and start all the containers.
The default configuration allows making "fake" request using the mock Withings API which just returns
some random data for some endpoints, rather than connecting to the actual API. If you want to use it with the real Withings API
you will need to adjust the WITHINGS_API_URL
environment variable and point to the correct URL.
Before using though, you still need to adjust a couple of things - see below.
- Exec into RabbitMQ container and adjust the password for the management user in case it doesn't work.
docker exec -it rabbitmq /bin/bash
rabbitmqctl list_users
rabbitmqctl change_password <user> <new password>
- Create a user for the fitness-dial container (according to the values set for Celery broker in vars-dev.env file:
rabbitmqctl add_user testuser pwd123
- Go to localhost:15672, log in as the management user
- Go to Admin tab:
- select your new user in the table below
- set * permissions to / virtual host
- Exec into the web container
- Run
python manage.py migrate
to prepare the DB for first use - Open the interactive shell and create a user:
python manage.py shell
from connector.models import WithingsAuthentication, APIUser
from django.utils import timezone
from datetime import timedelta
now = timezone.now()
user = APIUser(
first_name='Test',
last_name='User',
email='test@user.com',
user_id=123,
demo=False,
height=1.65,
date_of_birth=now
)
user.save()
auth = WithingsAuthentication(
access_token="faketoken",
refresh_token="fakerefreshtoken",
expires_in=360000,
valid_from=now,
valid_to=now+timedelta(seconds=360000),
scope=["user.metrics","user.activity"],
token_type="Bearer",
user=user,
demo=False,
expired=False
)
auth.save()
- Create a DB user for Grafana (you can use pgAdmin).
- Grant SELECT permissions to the newly created user (you can use the Grant Wizard in pgAdmin).
- Log in to Grafana at localhost:3000 using the default credentials (admin/admin) - change password when prompted.
- Add a new PostgreSQL data source in the Configuration tab and adjust the values according to the ones set via environment variables:
- host:
db:5432
- database:
test
- user/password: as created in step 1.
- TLS/SSL Mode:
disable
- host:
- Create a new dashboard using the provided template:
- in the Dashboards/Manage tab click on Import
- select Upload JSON file and select the template
- adjust the name and folder, if desired, and Import
- alternatively, you can copy the contents of the template to the Import via panel json field and continue as described above