health-check

$npx mdskill add terrylica/cc-skills/health-check

> **Self-Evolving Skill**: This skill improves through use. If instructions are wrong, parameters drifted, or a workaround was needed — fix this file immediately, don't defer. Only update for real, reproducible issues.

SKILL.md

.github/skills/health-checkView on GitHub ↗
---
name: health-check
description: Diagnose the po Pushover plugin and check remaining monthly quota. Runs a full self-test (credential resolution via 1Password/Keychain, /users/validate.json, quota, expected custom sounds present, deps bun/uv/chrome, audit log) and reports message quota remaining. Use when the user asks if Pushover is working, why a notification failed, how many messages are left, or wants a health/diagnostic check. TRIGGERS - pushover health, po doctor, pushover not working, pushover quota, messages left, diagnose pushover.
---

# health-check

> **Self-Evolving Skill**: This skill improves through use. If instructions are wrong, parameters drifted, or a workaround was needed — fix this file immediately, don't defer. Only update for real, reproducible issues.

Self-test + quota for the po plugin, via the TS core.

```bash
env -u HTTPS_PROXY -u HTTP_PROXY bun "${CLAUDE_PLUGIN_ROOT}/skills/_lib/pushover_core.ts" doctor   # full self-test (JSON)
env -u HTTPS_PROXY -u HTTP_PROXY bun "${CLAUDE_PLUGIN_ROOT}/skills/_lib/pushover_core.ts" quota     # {limit, remaining, reset}
```

`doctor` checks: creds (op→Keychain), `/users/validate.json`, monthly quota, the expected custom sounds
(`po_fanfare`/`po_uplift`/`po_celebrate`), deps (bun/uv/Chrome), and the audit log size. `quota` prints
remaining messages and warns when below `quota_warn_remaining` (see `pushover_api_limits.json`).

## Reliability primitives (apply to every send)

- **Limits SSoT** — `skills/_lib/pushover_api_limits.json` is the single source for all Pushover limits/rules
  (message 1024, title 250, url 512, attachment 5 MB, sound <500 KB/≤30 s, app name 20, desc 500,
  html⊕monospace, priority-2 needs retry+expire). Edit there, nowhere else.
- **Preflight** — `pushover_core.ts` validates every send against `pushover_api_limits.json` and turns Pushover's _silent_
  failures into explicit output: **refuses** (url>512, attachment>5 MB, html+monospace) — override with
  `--force` — and **warns** (message/title truncation, sound not in account).
- **Audit trail** — every send appends a UUID-keyed JSONL line to `~/.local/state/pushover/po-audit.jsonl`
  (`ts, uuid, app, priority, status, request, receipt, remaining, message_len, errors`). Retrieve with
  `grep <uuid> ~/.local/state/pushover/po-audit.jsonl | jq .`.
- **Quota guard** — each send reads `X-Limit-App-Remaining` and warns when low.
- **Retry/backoff** — transient network / 5xx are retried (×3, backoff) before failing.

## Post-Execution Reflection

After this skill completes, check before closing:

1. **Did the check surface real failures (credentials, quota, dependencies) with no false green?** If a broken subsystem reported healthy, fix the check.
2. **Was remaining quota reported accurately?** A stale or wrong quota reading needs fixing before it misleads.

Only update if the issue is real and reproducible — not speculative.

More from terrylica/cc-skills