Search...Search plugins and themes...
⌘K
Sign in
  • Get started
  • Download
  • Pricing
  • Enterprise
  • Account
  • Obsidian
  • Overview
  • Sync
  • Publish
  • Canvas
  • Mobile
  • Web Clipper
  • CLI
  • Learn
  • Help
  • Developers
  • Changelog
  • About
  • Roadmap
  • Blog
  • Resources
  • System status
  • License overview
  • Terms of service
  • Privacy policy
  • Security
  • Community
  • Plugins
  • Themes
  • Discord
  • Forum / 中文论坛
  • Merch store
  • Brand guidelines
Follow us
DiscordTwitterBlueskyThreadsMastodonYouTubeGitHub
© 2026 Obsidian

Garmin Health Sync

fcandifcandi360 downloads

Sync Garmin Connect health data into your Daily Notes as frontmatter properties.

Add to Obsidian
Garmin Health Sync screenshot
Garmin Health Sync screenshot
  • Overview
  • Scorecard
  • Updates14

English · Deutsch · 中文 · 日本語 · Español · Français

Garmin Health Sync

Sync steps, sleep, heart rate, stress, activities and more from Garmin Connect into Obsidian Daily Notes — as frontmatter properties you can query with Dataview.

Desktop only. This plugin uses Electron's BrowserWindow for Garmin Connect authentication and does not work on mobile.

Note: This plugin uses Garmin Connect's internal web API through an Electron browser session — there is no official third-party API available.

Features

  • Auto-sync on startup — checks the last 7 days and fills in any missing health data
  • Manual sync — sync any open Daily Note via command palette
  • Backfill — bulk-sync a date range (e.g. the last 3 months)
  • 20+ metrics — steps, sleep score, HRV, stress, body battery, SpO2, weight, and more
  • Activity tracking — each workout appears as a human-readable summary
  • Workout location — reverse-geocoded place name from your first GPS activity
  • Smart detection — automatically picks up your Daily Notes path and format from Periodic Notes or the core Daily Notes plugin
  • Subdirectory support — finds existing Daily Notes in nested folders (e.g. Journal/2024-07/)
  • Language auto-detection — UI language is set from your Obsidian language (EN, DE, ZH, JA, ES, FR)
  • Optional structured data — machine-readable trainings field for advanced Dataview queries
  • Property prefix — optionally adds an ohs_ prefix to all frontmatter properties to avoid naming conflicts with other plugins

Frontmatter Output

Metrics

---
steps: 15185
resting_hr: 69
sleep_score: 81
sleep_duration: 7h 43min
hrv: 39
stress: 30
vo2_max: 48
workout_location: Bad Honnef, Germany
---

Activities

Each workout is written as a frontmatter key with a summary string:

---
hiking: 8.2 km · 157min · Ø105 bpm · 696 kcal
e_bike: 22.1 km · 65min · Ø112 bpm · 420 kcal
---

Only days with actual workouts get activity keys. The plugin never touches your note content — it only adds or updates frontmatter properties.

Trainings (optional, machine-readable)

Enable "Machine-readable trainings" in settings to add a structured trainings field for Dataview queries:

---
trainings:
  - type: hiking
    category: outdoor
    distance_km: 8.2
    duration_min: 157
    avg_hr: 105
    calories: 696
  - type: e_bike
    category: cycling
    distance_km: 22.1
    duration_min: 65
    avg_hr: 112
    calories: 420
---

Requirements

  • Obsidian Desktop (Windows, macOS, Linux) — the plugin does not work on mobile
  • Garmin account with access to Garmin Connect
  • Daily Notes or Periodic Notes plugin enabled (or configure the path manually in settings)

Installation

From Community Plugins (recommended)

  1. Open Obsidian Settings → Community Plugins → Browse
  2. Search for "Garmin Health Sync"
  3. Install and enable the plugin
  4. Log in to Garmin Connect in the plugin settings

Manual

  1. Download main.js and manifest.json from the latest release
  2. Create a folder .obsidian/plugins/garmin-health-sync/ in your vault
  3. Copy both files into that folder
  4. Enable the plugin in Settings → Community Plugins

Usage

Auto-sync

On every Obsidian startup, the plugin checks the last 7 days and fills in any missing health data automatically. No action needed.

Manual sync

Open a Daily Note and run Garmin Health Sync: Sync current note from the Command Palette (Cmd/Ctrl+P).

Backfill historical data

Have years of Garmin data? You can bulk-sync any date range:

  1. Open the Command Palette (Cmd/Ctrl+P)
  2. Search for "Backfill health data"
  3. Pick a start and end date
  4. The plugin fetches all data for that range with rate-limiting to avoid API throttling

Activity Key Normalization

Garmin's typeKey values are normalized to cleaner canonical keys:

Provider Key Canonical Key Category
e_bike_fitness e_bike cycling
e_bike_mountain e_mtb cycling
resort_skiing_snowboarding skiing winter
backcountry_skiing_snowboarding backcountry_skiing winter
stand_up_paddleboarding sup water
fitness_equipment gym_equipment gym

All other Garmin keys pass through unchanged (e.g. hiking, running, cycling, swimming, strength_training, yoga, ...).

Activity Categories

Each activity is assigned a category:

Category Examples
cycling cycling, e_bike, e_mtb, mountain_biking, indoor_cycling, road_biking
running running, trail_running, treadmill, ultra_run
walking walking, indoor_walking
outdoor hiking, mountaineering, rock_climbing, bouldering
swimming swimming, pool_swimming, open_water_swimming
winter skiing, backcountry_skiing, cross_country_skiing, snowboarding
water sup, rowing, kayaking, surfing, sailing
gym strength_training, gym_equipment, elliptical, yoga, pilates, hiit
racket tennis, badminton, squash, table_tennis, pickleball
team soccer, basketball, volleyball, rugby
other golf, meditation, multi_sport

Data & Privacy

This plugin makes network requests to two external services:

  • Garmin Connect — a browser window authenticates with Garmin Connect using your credentials. No password is stored by the plugin. Local plugin data may store Garmin session data, including session cookies, so the plugin can restore the browser session without asking you to log in again. Treat this session data like a login token: its lifetime is controlled by Garmin, and it may be included in backups or sync tools if they include Obsidian plugin data. Using Logout clears the stored Garmin session data on this device.
  • Nominatim (OpenStreetMap) — if the "Workout location" feature is enabled, the GPS coordinates of your first activity are sent to nominatim.openstreetmap.org for reverse geocoding. You can disable this in settings under Workout location.

No data is sent to any other server.

Development

npm install
npm run dev    # watch mode
npm run build  # production build
89%
HealthExcellent
ReviewSatisfactory
About
Sync Garmin Connect health data — steps, sleep, heart rate, stress, activities and more — directly into Obsidian Daily Notes as frontmatter properties ready for Dataview queries. Backfill date ranges, auto-sync recent days, and add human-readable workout summaries plus optional machine-readable training fields while leaving note content untouched (desktop only).
ImportPropertiesDates
Details
Current version
0.9.9
Last updated
2 days ago
Created
3 months ago
Updates
14 releases
Downloads
360
Compatible with
Obsidian 1.5.4+
Platforms
Desktop only
License
0BSD
Report bugRequest featureReport plugin
Author
fcandifcandi
github.com/fcandi
GitHubfcandi
  1. Community
  2. Plugins
  3. Import
  4. Garmin Health Sync

Related plugins

Update modified date

Automatically update a frontmatter modified date field when the file is modified.

Weread

Sync Tencent Weread highlights and annotations.

ICS

Add events from calendar ics on the web to daily notes on demand. Includes vdir support. Daily Planner, Templater and Dataview friendly.

Slurp

Slurps webpages and saves them as clean, uncluttered Markdown.

Importer

Import data from Notion, Evernote, Apple Notes, Microsoft OneNote, Google Keep, Bear, Roam, and HTML files.

Advanced Canvas

Supercharge your canvas experience. Create presentations, flowcharts and more.

Meta Bind

Make your notes interactive with inline input fields, metadata displays, and buttons.

Day Planner

Day planning from a task list in a Markdown note with enhanced time block functionality.

Multi Properties

Add properties to multiple notes at once. Either right-click a folder or select multiple notes and right-click the selection.

Tasks

Track tasks across your vault. Supports due dates, recurring tasks, done dates, sub-set of checklist items, and filtering.