Disk Guardian
/install disk-guardian
disk-guardian
S.M.A.R.T. drive health scanner for macOS and Linux.
Scripts
All scripts are in scripts/. Run them in sequence or pipe them together:
cd ~/.openclaw/workspace/skills/disk-guardian/scripts
# Full pipeline (may need sudo on Linux):
python3 scan_drives.py | python3 parse_smart.py | python3 report.py
# With sudo (required on many Linux systems):
python3 scan_drives.py --sudo | python3 parse_smart.py | python3 report.py
# Save report to file:
python3 scan_drives.py | python3 parse_smart.py | python3 report.py --output ~/disk-report.md
# Record scan to history and get trend analysis:
python3 scan_drives.py | python3 parse_smart.py | python3 history.py --record
Data is stored in ~/.openclaw/workspace/disk-guardian/ by default. Use --data-dir to override on any script.
Workflow
- Run
scan_drives.py— detects drives and runssmartctl -aon each. Outputs JSON. - Pipe to
parse_smart.py— extracts health attributes, assesses status (Good/Warning/Critical). - Pipe to
report.py— generates markdown report with risk rankings and recommendations. - Optionally pipe to
history.py --recordto log the scan and get trend alerts.
Prerequisites
smartctl must be installed:
- macOS:
brew install smartmontools - Linux:
sudo apt install smartmontoolsorsudo dnf install smartmontools
If smartctl is missing, scan_drives.py will output the install command and exit gracefully.
Script Details
scan_drives.py
- macOS: uses
diskutil listto find whole disks, thensmartctl -a /dev/diskN - Linux: uses
lsblkto find block devices, thensmartctl -a /dev/sdX --sudo: prepend sudo to smartctl commands (needed on Linux without udev rules)- Outputs JSON:
{os, smartctl_path, drives_found, scan_results: [{device, smartctl_output|error}]}
parse_smart.py
- Detects drive type: NVMe, SSD, or HDD
- SATA/SSD: parses attribute table, extracts Reallocated Sector Count, Current Pending Sector, Uncorrectable Errors, Temperature, Power-On Hours, Read Error Rate, Seek Error Rate, and more
- NVMe: parses health log for Available Spare, Percentage Used, Media Errors, Unsafe Shutdowns, Critical Warning
- Assigns health_status: Good / Warning / Critical
--input FILE: read from file instead of stdin--raw FILE --device NAME: parse a single raw smartctl text dump
history.py
--record: append current scan to~/.openclaw/workspace/disk-guardian/history.json--trends: analyze stored history for concerning patterns (rising reallocated sectors, climbing temps, declining NVMe spare)--list [--limit N]: show last N entries per device--data-dir PATH: use alternate storage location--device /dev/diskN: filter output to one device
report.py
- Generates markdown with drive inventory table, per-drive status, risk ranking with scores, human-readable flag explanations, trend alerts, and recommendations
- Risk ranking accounts for health status, flag severity, trend alerts, and drive age (power-on hours)
--output FILE: save report to file instead of printing--trends FILE: load pre-computed trend JSON
SMART Attribute Reference
See references/smart-attributes.md for plain-English explanations of the 10 most critical SMART attributes and NVMe health indicators. Read it when explaining specific attributes to the user or when triaging a flagged drive.
Edge Cases
- smartctl not installed:
scan_drives.pyprints install instructions and exits with code 2 - Permission denied: Output includes hint to use
--sudo; on Linux, add user todiskgroup as permanent fix - Virtual drives (VMware, loop devices): smartctl will return errors; these are captured and included in error entries
- NVMe vs SATA: drive type auto-detected; NVMe uses health log fields instead of attribute table
- Corrupt history:
history.pybacks up the file and starts fresh automatically
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install disk-guardian - After installation, invoke the skill by name or use
/disk-guardian - Provide required inputs per the skill's parameter spec and get structured output
What is Disk Guardian?
Run S.M.A.R.T. diagnostics on all drives, parse health indicators, maintain a history log, and flag drives showing early failure patterns. Generates health s... It is an AI Agent Skill for Claude Code / OpenClaw, with 116 downloads so far.
How do I install Disk Guardian?
Run "/install disk-guardian" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Disk Guardian free?
Yes, Disk Guardian is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Disk Guardian support?
Disk Guardian is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Disk Guardian?
It is built and maintained by New Age Investments (@newageinvestments25-byte); the current version is v1.0.0.