Skip to content

Latest commit

 

History

History
32 lines (21 loc) · 1.92 KB

README.md

File metadata and controls

32 lines (21 loc) · 1.92 KB

Withings-Garmin-MFA

Since there was no single project that downloaded data from Withings, sent that data to Garmin Connect, AND handled Garmins MFA, I decided to merge multiple projects together to get it working fully automated end to end!

Note that this is very clunky and isn't optimized/still has lingering code from both repos that isn't being used, but maybe eventually (if I can find extra time), that'll be taken care of :)

Best bet is to use this with docker (similar to withings-sync) as I've only tested with this method:

docker build -t withings-sync-mfa

docker run --name withings -v $HOME:/root --interactive --tty withings-sync-mfa --garmin-username='YOUR_USERNAME' --garmin-password='YOUR_PASSWORD' --fromdate='2023-07-17' --garmin-mfa True --email-login 'YOUR_ACTUAL_LOGIN_TO_YOUR_EMAIL' --email-password 'YOUR_EMAILS_PASSWORD' --email-server "imap.gmail.com"

You can then use a scheduler (cron) to run the container every X amount of time (or you can run manually at any time) using:

docker start -i withings

It's recommeded to not run more than once every hour or so, as Garmin will restrict your IP after too many consecutive pings (although, this program saves your session for a while, so you should be fine!)

NOTE: If you want MFA to work, this requires:

  • SMS MFA must be disabled/Email MFA must be default
  • You to be able to login to your email server to retrieve the MFA code.
    • I use gmail, and to login to the imap server, gmail requires an application password. This can be obtained from:
      • Google Account Settings > Security > 2-Step Verification (turned on) > App Passwords
  • You must not have another, old MFA email marked as unread in your inbox. This will cause the program to pull the wrong code.

Credits

The following projects are referenced/used in this repository: