Garmin SSO auth + Connect client
Project description
Garth
Garmin SSO auth + Connect client
Background
Garth is meant for personal use and follows the philosiphy that your data is your data. You should be able to download it and analyze it in the way that you'd like. In my case, that means processing with Google Colab, Pandas, Matplotlib, etc.
There are already a few Garmin Connect libraries. Why write another?
Authentication
The most important reasoning is to build a library with authentication that works on Google Colab and doesn't require tools like Cloudscraper. Garth, in comparison:
- Uses the same embedded SSO as the mobile app
- Only requires
requests
as a dependency - Supports MFA
- Supports saving and resuming sessions to avoid the need to log in each time you run a script, which is particularly useful if you have MFA enabled
- Appears to be working on Google Colab thus far 🤞🏽
Python 3.10+
Google Colab, currently, uses 3.10. We should take advantage of all the goodies that come along with it. If you need to use an earlier version of Python, there are other libraries that will meet your needs. There's no intetion to backport.
JSON vs HTML
Using garth.connectapi()
allows you to make requests routed to the Connect API
and receive JSON vs needing to parse HTML. You can use the same endpoints the
mobile app uses.
This also goes back to authentication. Garth manages the necessary Bearer Authentication (along with auto-refresh) necessary to make requests routed to the Connect API.
Instructions
Install
python -m pip install garth
Authenticate and save session
import garth
from getpass import getpass
email = input("Enter email address: ")
password = getpass("Enter password: ")
# If there's MFA, you'll be prompted during the login
garth.login(email, password)
garth.save("~/.garth")
Configure
Set domain for China
garth.configure(domain="garmin.cn")
Proxy through Charles
garth.configure(proxies={"https": "http://localhost:8888"}, ssl_verify=False)
Attempt to resume session
import garth
from garth import GarthException
from requests import HTTPError
garth.resume("~/.garth")
try:
garth.client.auth_token.refresh()
except (GarthException, HTTPError):
# Session is expired. You'll need to log in again
Connect API
Wellness
sleep = garth.connectapi(
f"/wellness-service/wellness/dailySleepData/{garth.client.username}",
params={"date": "2023-07-05", "nonSleepBufferMinutes": 60),
)
list(sleep.keys())
[
"dailySleepDTO",
"sleepMovement",
"remSleepData",
"sleepLevels",
"sleepRestlessMoments",
"restlessMomentsCount",
"wellnessSpO2SleepSummaryDTO",
"wellnessEpochSPO2DataDTOList",
"wellnessEpochRespirationDataDTOList",
"sleepStress"
]
Usersummary
stress = garth.connectapi(f"/usersummary-service/stats/stress/weekly/2023-07-05/52")
{
"calendarDate": "2023-07-13",
"values": {
"highStressDuration": 2880,
"lowStressDuration": 10140,
"overallStressLevel": 33,
"restStressDuration": 30960,
"mediumStressDuration": 8760
}
}
Google Colabs
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file garth-0.2.0.tar.gz
.
File metadata
- Download URL: garth-0.2.0.tar.gz
- Upload date:
- Size: 84.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4c39b464a5abd0a9e7586376a0d868af4b7d0b99412a3b62187f91c552dd65e0 |
|
MD5 | 4acfc04e723829e87e32587f0a938c6a |
|
BLAKE2b-256 | 6cada2380be9ea58db31ae122493588c712d5b64810a463fdf7f5387ae764fcf |
File details
Details for the file garth-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: garth-0.2.0-py3-none-any.whl
- Upload date:
- Size: 7.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 09af1da4f6826cec9e763114bfab9efc9105ccbd3c40ee38c3acaf8583bac6a4 |
|
MD5 | 388b682bceda742d52e02d1623227b34 |
|
BLAKE2b-256 | a3faa5e0cb8b0623057e05d0d6bc882da277536f9bb0b4dc8efab49ac66a41e0 |