Skip to main content

Garmin SSO auth + Connect Python client (maintained fork of matin/garth)

Project description

garth-ng

PyPI version CI Python License: MIT

Garmin SSO auth + Connect Python client — maintained fork of matin/garth

About this fork

garth-ng is a maintained continuation of the original garth library by Matin Tamizi. The original project was deprecated after Garmin changed their auth flow. This fork restores compatibility and continues active development. The package name changed to garth-ng but the import stays import garth — same as Pillow keeping from PIL import Image.

Migrating from garth

Both packages install into the same site-packages/garth/ directory. You must uninstall the original first:

pip uninstall garth
pip install garth-ng

Your code stays unchanged. import garth works exactly as before.

Installation

pip install garth-ng
uv add garth-ng

The garth CLI command is included in the base install — no extras needed.

Quick Start

Login and save session

import garth
from getpass import getpass

garth.login(input("Email: "), getpass("Password: "))
garth.save("~/.garth")

MFA is handled automatically with a terminal prompt. Pass a custom handler if you need one:

garth.login(email, password, prompt_mfa=lambda: input("MFA code: "))

Resume a saved session

import garth

garth.resume("~/.garth")
print(garth.client.username)

Auto-load from environment

export GARTH_HOME=~/.garth
import garth

print(garth.client.username)  # loaded automatically

Or use a base64 token (useful in CI/containers):

export GARTH_TOKEN="eyJvYXV0aF90b2tlbi..."

Generate a token with the CLI:

garth login

For China region:

garth --domain garmin.cn login

Direct API calls

sleep = garth.connectapi(
    f"/wellness-service/wellness/dailySleepData/{garth.client.username}",
    params={"date": "2023-07-05", "nonSleepBufferMinutes": 60},
)

Stats and data

# Daily steps for the last 7 days
garth.DailySteps.list(period=7)

# Stress levels
garth.DailyStress.list("2023-07-23", 2)

# Weekly HRV
garth.DailyHRV.list(period=7)

# Sleep quality
garth.DailySleep.list(period=7)

Available stat types: DailySteps, WeeklySteps, DailyStress, WeeklyStress, DailyHRV, DailySleep, DailyHydration, DailyIntensityMinutes, WeeklyIntensityMinutes, DailyTrainingStatus, WeeklyTrainingStatus, MonthlyTrainingStatus

Available data types: SleepData, HRVData, WeightData, DailyHeartRate, BodyBatteryData, DailyBodyBatteryStress, DailySleepData, DailySummary, Activity, FitnessActivity, GarminScoresData, TrainingReadinessData, MorningTrainingReadinessData

Upload an activity

with open("activity.fit", "rb") as f:
    garth.upload(f)

Configuration

garth.configure(domain="garmin.cn")        # China region
garth.configure(timeout=30)                # Request timeout (seconds)
garth.configure(retries=5, backoff_factor=1.0)  # Retry behavior
garth.configure(proxies={"https": "http://localhost:8888"}, ssl_verify=False)  # Proxy

License

MIT. Original library by Matin Tamizi. Fork maintained by CyberFossa.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

garth_ng-1.0.0a1.tar.gz (2.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

garth_ng-1.0.0a1-py3-none-any.whl (44.1 kB view details)

Uploaded Python 3

File details

Details for the file garth_ng-1.0.0a1.tar.gz.

File metadata

  • Download URL: garth_ng-1.0.0a1.tar.gz
  • Upload date:
  • Size: 2.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for garth_ng-1.0.0a1.tar.gz
Algorithm Hash digest
SHA256 61164349ecb43af6665706e69fd7c803365e9016295382c0ebf05f7407beada3
MD5 9eaa1745ac46c659dbeaaf7c84d7f0b6
BLAKE2b-256 5d699261c268ade7c0375e804b28230f156e61aa80472aa2a65f98b9d577c2ff

See more details on using hashes here.

Provenance

The following attestation bundles were made for garth_ng-1.0.0a1.tar.gz:

Publisher: publish.yml on cyberfossa/garth-ng

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file garth_ng-1.0.0a1-py3-none-any.whl.

File metadata

  • Download URL: garth_ng-1.0.0a1-py3-none-any.whl
  • Upload date:
  • Size: 44.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for garth_ng-1.0.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 42a563230fee15581a0279657b7086bec9797258769f350d1a955d73cc004eb0
MD5 f8bd425d4c16ed76595dc24adf2be1d6
BLAKE2b-256 0485f65ada663674730824738986f080019c9fb6f8e20bdb5ce870129f61c03b

See more details on using hashes here.

Provenance

The following attestation bundles were made for garth_ng-1.0.0a1-py3-none-any.whl:

Publisher: publish.yml on cyberfossa/garth-ng

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page