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.0a2.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.0a2-py3-none-any.whl (47.3 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for garth_ng-1.0.0a2.tar.gz
Algorithm Hash digest
SHA256 05ce638267bcd43c2260411cd78e0a2dc3677a100ba7a2c600c3887421fde799
MD5 6864fadd55911ada452da6948f63d91d
BLAKE2b-256 cc6a78b489e3d5116aee75a2b9880f1f5bf59a01ea6e22408478ce1d1444a5fe

See more details on using hashes here.

Provenance

The following attestation bundles were made for garth_ng-1.0.0a2.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.0a2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for garth_ng-1.0.0a2-py3-none-any.whl
Algorithm Hash digest
SHA256 8a594caeb0496cec5abeba92e1015dddef1a445a93b5c132d05dfa90a987aea5
MD5 b0b7e69871ca287d7c980a6ff560cc94
BLAKE2b-256 bfe9b7c5b8e088919df284c56e9e7d2b04b6069d52ff507463472d6a91f200d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for garth_ng-1.0.0a2-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