git clone https://github.com/rickybloomfield/OuraClaw
T=$(mktemp -d) && git clone --depth=1 https://github.com/rickybloomfield/OuraClaw "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/oura" ~/.claude/skills/rickybloomfield-ouraclaw-oura && rm -rf "$T"
skills/oura/SKILL.mdOura Ring Health Data
You have access to the user's Oura Ring data through the
oura_data tool. Use it to answer health questions and deliver scheduled summaries.
Endpoint Reference
Core (used in daily summaries)
| Endpoint | Returns | Key Fields |
|---|---|---|
| Sleep score & contributors | , , , , , |
| Readiness score & contributors | , , , , |
| Activity score & metrics | , , , , , |
| Detailed sleep periods | , , , , , , , , , , |
| Stress summary | , , |
Additional (available for ad-hoc queries)
| Endpoint | Returns | Key Fields |
|---|---|---|
| Continuous heart rate samples | , , |
| Blood oxygen levels | , |
| Workout sessions | , , , , , , |
| Mindfulness/breathing sessions | , , , , |
| User-created tags | , , |
| Cardiovascular age estimate | |
| Resilience score & contributors | , , , |
| VO2 max estimate | , |
| Rest mode periods | , , |
| Recommended sleep times | , , , |
| Ring hardware info | , , , , , |
| User profile | , , , , |
| Tags (deprecated, use ) | , |
Usage Instructions
- Date defaults: If no dates specified, the tool defaults to today's data. Use
andstart_date
inend_date
format for specific ranges.YYYY-MM-DD - Multi-endpoint queries: For comprehensive answers, call multiple endpoints. E.g., "How did I sleep?" should fetch both
(score) anddaily_sleep
(details).sleep - Duration conversion: Sleep/activity durations are in seconds. Convert to hours and minutes:
→27360s
.7h 36m - Null values: Some fields may be
if Oura hasn't computed them yet. Note this gracefully rather than showing "null".null
Score Interpretation
| Range | Label |
|---|---|
| 85+ | Excellent |
| 70–84 | Good |
| 60–69 | Fair |
| Below 60 | Needs attention |
Formatting Guidelines
- Use concise bullet points, not long paragraphs
- Lead with scores and labels (e.g., "Sleep: 82 (Good)")
- Include 2–3 key contributor details per category
- Convert all durations from seconds to Xh Ym format
- Add brief, personalized context when relevant (e.g., "HRV is trending lower than usual")
- Keep summaries scannable — the user may be reading on a phone
- Adapt formatting to the delivery channel — see Channel Formatting Guide below
Channel Formatting Guide
Different messaging channels support different formatting syntax. Use the correct format for the delivery channel. When the channel is unknown or "default", use plain text formatting (safe everywhere).
Plain text — iMessage (bluebubbles), Signal
No text-based formatting syntax is supported. Characters like
*, _, and ~ appear literally.
- Use emoji and whitespace for visual structure
- Use UPPERCASE sparingly for emphasis if needed (e.g., "SLEEP: 82")
- URLs are auto-linked — just include them as plain text
- Use
or|
as inline separators· - Use
(em dash) for inline breaks—
- Bold:
*text* - Italic:
_text_ - Strikethrough:
~text~ - Inline code:
`text` - Lists:
at the start of a line- item - URLs are auto-linked — do NOT use markdown link syntax
[text](url)
Telegram
Supports Markdown-style formatting:
- Bold:
*text* - Italic:
_text_ - Underline:
__text__ - Strikethrough:
~text~ - Links:
[display text](url) - Escape special characters (
,.
,-
,(
,)
, etc.) with!
when they appear outside formatting\
Slack
Uses Slack's mrkdwn syntax (not standard Markdown):
- Bold:
*text* - Italic:
_text_ - Strikethrough:
~text~ - Links:
<url|display text> - Lists:
or- item• item - Do NOT use standard Markdown bold (
) or link syntax (**text**
)[text](url)
Discord
Uses standard Markdown:
- Bold:
**text** - Italic:
*text* - Underline:
__text__ - Strikethrough:
~~text~~ - Links:
[display text](url) - Lists:
- item - Headers:
,#
,##
(at start of line)###
WebChat / Default
Use standard Markdown formatting.
Scheduled Summary Delivery
When producing a scheduled summary (morning or evening), follow these rules:
- Read the template carefully and follow every format rule, including all specified data points, line counts, and examples.
- Send the complete formatted summary as a single message to the channel and target specified in the request. Do not summarize, abbreviate, or rephrase the summary.
- Apply channel-appropriate formatting using the Channel Formatting Guide above based on the channel specified in the request.
Morning Summary Template
When delivering a morning summary, fetch
daily_sleep, sleep (detailed periods), daily_readiness, daily_activity, and daily_stress for today. Also fetch yesterday's daily_activity as a fallback.
Send only the formatted summary — no preamble, intro message, or extra commentary before or after it. Apply the correct formatting syntax for the delivery channel (see Channel Formatting Guide).
Format rules:
- Start with "Good morning!" and today's date
- Sleep: score with label, total sleep time (convert seconds to Xh Ym), key contributors that are notably high or low. From the detailed
endpoint, include lowest resting heart rate, average overnight heart rate, and average HRV. Show deep, REM, and light durations in minutes.sleep - Readiness: score with label, body temperature deviation, HRV balance, recovery index. Call out anything that's dragging the score down.
- Activity: use today's
if available (score, steps, active calories). If score is null or data is missing, use yesterday's activity instead and note that it's yesterday's data.daily_activity - Stress: mention if data is available (normal, high, etc.). If no stress data, skip it.
- End with: "Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — enjoy your day!" (include trailing text after the URL so it renders inline, not as a separate link preview).
- Keep it concise — 8–10 lines max. Use emoji sparingly. Warm but not cheesy.
- Bold the category labels and scores on channels that support bold (e.g.,
on WhatsApp/Telegram/Slack,*Sleep: 82 (Good)*
on Discord). On plain text channels (iMessage, Signal), do not use any formatting markers.**Sleep: 82 (Good)**
Example tone (plain text / iMessage):
Good morning! Here's your recap for Monday, Jan 27. 😴 Sleep: 82 (Good) — 7h 12m total Deep 58m | REM 1h 24m | Light 4h 50m Lowest HR 52 bpm | Avg HR 58 bpm | HRV 42 ms 💪 Readiness: 78 (Good) Body temp +0.1°C | HRV balance solid | Recovery index slightly low 🏃 Activity (yesterday): 74 (Good) — 8,241 steps, 312 active cal Stress: normal range Solid night overall — deep sleep was a bit short but REM made up for it. Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — enjoy your day!
Example tone (WhatsApp / Telegram / Slack):
Good morning! Here's your recap for Monday, Jan 27. 😴 *Sleep: 82 (Good)* — 7h 12m total Deep 58m | REM 1h 24m | Light 4h 50m Lowest HR 52 bpm | Avg HR 58 bpm | HRV 42 ms 💪 *Readiness: 78 (Good)* Body temp +0.1°C | HRV balance solid | Recovery index slightly low 🏃 *Activity (yesterday): 74 (Good)* — 8,241 steps, 312 active cal Stress: normal range Solid night overall — deep sleep was a bit short but REM made up for it. Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — enjoy your day!
Evening Summary Template
When delivering an evening summary, fetch
daily_activity, daily_readiness, daily_stress, and daily_sleep for today. Also fetch yesterday's daily_activity as a fallback in case today's data isn't available yet.
Send only the formatted summary — no preamble, intro message, or extra commentary before or after it. Apply the correct formatting syntax for the delivery channel (see Channel Formatting Guide).
Format rules:
- Start with "Good evening!" and today's date
- Focus on today's activity: score, steps, active calories, total calories. If today's activity score is null or data is missing, use yesterday's activity instead and note that it's yesterday's data. Activity data must always be included — never show "pending" or skip it.
- Include today's readiness and stress.
- Briefly mention last night's sleep score as a one-line recap.
- End with a short, genuine motivational nudge to wind down, then: "Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — sleep well!" (include trailing text after the URL so it renders inline).
- Keep it concise — 6–8 lines max. Use emoji sparingly.
- Bold the category labels and scores on channels that support bold. On plain text channels (iMessage, Signal), do not use any formatting markers.
Example tone (plain text / iMessage):
Good evening! Here's your day in review for Monday, Jan 27. 🏃 Activity: 81 (Good) — 9,432 steps, 387 active cal, 2,145 total cal 📊 Readiness: 78 (Good) | Stress: normal range 😴 Last night's sleep: 82 (Good) Nice active day — you moved well. Wind down soon and aim for a solid bedtime to keep the momentum going. Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — sleep well!
Example tone (WhatsApp / Telegram / Slack):
Good evening! Here's your day in review for Monday, Jan 27. 🏃 *Activity: 81 (Good)* — 9,432 steps, 387 active cal, 2,145 total cal 📊 *Readiness: 78 (Good)* | Stress: normal range 😴 *Last night's sleep: 82 (Good)* Nice active day — you moved well. Wind down soon and aim for a solid bedtime to keep the momentum going. Dive deeper in the Oura app: https://cloud.ouraring.com/app/v1/home — sleep well!
Ad-hoc Query Mapping
Map natural language to endpoints:
| User says | Fetch |
|---|---|
| "How did I sleep?" / "Sleep report" | + |
| "Am I ready to work out?" / "Readiness" | |
| "How active was I?" / "Steps today" | |
| "Stress levels" | |
| "Full health summary" | All endpoints |
| "Last week's sleep" / "trends" | with 7-day date range |
| "Compare this week to last" | Two date ranges, summarize differences |
When the user asks about trends or comparisons, fetch the relevant date range and summarize the pattern (improving, declining, stable) with specific numbers.