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.1.0.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.1.0-py3-none-any.whl (65.8 kB view details)

Uploaded Python 3

File details

Details for the file garth_ng-1.1.0.tar.gz.

File metadata

  • Download URL: garth_ng-1.1.0.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.1.0.tar.gz
Algorithm Hash digest
SHA256 337434d0bddd58ac4889aeaa790e969e74a9db0ecaa6e5b38995fe1027f741d8
MD5 786a2b5411577dd60a8600689f239bef
BLAKE2b-256 822b39ea2248e77b7c97bdb81885a83317c15afaa6231f022d36c70a809045f2

See more details on using hashes here.

Provenance

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

Publisher: release.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.1.0-py3-none-any.whl.

File metadata

  • Download URL: garth_ng-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 65.8 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.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d467fe736f559846cca6bb8db038204d3170fd3998c60b4d1fea92e28b3c6646
MD5 fb53a9569a5aed5c49a0ca71fc96b1c8
BLAKE2b-256 d98b5fdd2388027ee8a759fdaebe7d743216a9fc72dce3b6937092a746d48e41

See more details on using hashes here.

Provenance

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

Publisher: release.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