SkillAgentSearch skills...

Fspulse

Monitor file system changes and integrity - scheduled "scans", temporal views, trends, alerts - safely and privately

Install / Use

/learn @gtunes-dev/Fspulse
About this skill

Quality Score

0/100

Category

Operations

Supported Platforms

Universal

README

<p align="center"> <img src="https://raw.githubusercontent.com/gtunes-dev/fspulse/main/assets/brand/icon-256.png" alt="fsPulse" width="128"> </p> <h1 align="center" style="font-weight: 600; font-size: 2em; margin-top: 0.2em;">fsPulse</h1> <p align="center"> <strong>Filesystem monitoring and integrity verification</strong> </p> <p align="center"> <a href="https://gtunes-dev.github.io/fspulse/">Documentation</a> • <a href="https://gtunes-dev.github.io/fspulse/getting_started.html">Getting Started</a> • <a href="https://hub.docker.com/r/gtunesdev/fspulse">Docker Hub</a> • <a href="https://github.com/gtunes-dev/fspulse/releases">Releases</a> </p> <p align="center"> <a href="https://hub.docker.com/r/gtunesdev/fspulse"><img src="https://img.shields.io/docker/pulls/gtunesdev/fspulse" alt="Docker Pulls"></a> <a href="https://github.com/gtunes-dev/fspulse/releases"><img src="https://img.shields.io/github/v/release/gtunes-dev/fspulse" alt="GitHub release"></a> </p>

⚠️ Early Development Notice fsPulse is under active development and is not yet feature-complete. Core functionality is stable, but expect continued evolution and occasional breaking changes. Feedback and issue reports are welcome as we work toward a 1.0 release.


Read-Only Guarantee. fsPulse never modifies your files. It requires only read access to the directories you configure for scanning. Write access is required only for fsPulse's own database, configuration files, and logs — never for your data.

Local-Only Guarantee. fsPulse makes no outbound network requests. All functionality runs entirely on your local system, with no external dependencies or telemetry.

What is fsPulse?

fsPulse is a comprehensive filesystem monitoring and integrity tool that gives you complete visibility into your critical directories. Track your data as it grows and changes over time, detect unexpected modifications, and catch silent threats like bit rot and corruption before they become disasters. fsPulse provides continuous awareness through automated scanning, historical trend analysis, and intelligent alerting.

Your filesystem is constantly evolving—files are added, modified, and deleted. Storage grows. But invisible problems hide beneath the surface: bit rot silently corrupts data, ransomware alters files while preserving timestamps, and you don't realize directories have bloated.

fsPulse gives you continuous awareness of both the visible and invisible:

Monitor Change & Growth:

  • Track directory sizes and growth trends over time
  • Visualize file additions, modifications, and deletions
  • Understand what's changing and when across all scans

Detect Integrity Issues:

  • Content Hashing (SHA2): Catches when file contents change even though metadata stays the same—the signature of bit rot or tampering
  • Format Validation: Reads and validates file structures to detect corruption in FLAC, JPEG, PNG, PDF, and more

Whether you're managing storage capacity, tracking project evolution, or ensuring data integrity, fsPulse provides the visibility and peace of mind that comes from truly knowing the state of your data.

<p align="center"> <img src="https://raw.githubusercontent.com/gtunes-dev/fspulse/main/assets/screenshots/web-scan-progress.png" alt="fsPulse Web UI - Real-time Scan Monitoring" width="90%" style="max-width: 900px;"> <br> <em>Web UI showing real-time scan progress with live statistics</em> </p>

🚀 Key Capabilities

  • Health-at-a-Glance Overview — See the status of all monitored directories immediately: open alerts, last scan times, and overall health
  • Continuous Monitoring — Schedule recurring scans (daily, weekly, monthly, or custom intervals) to track your filesystem automatically
  • Temporal Versioning — Every item's state is tracked over time; browse your filesystem as it appeared at any past scan
  • Size & Growth Tracking — Monitor directory sizes and visualize storage trends over time with dual-format units
  • Change Detection — Track all file additions, modifications, and deletions through version history
  • Integrity Verification — SHA2 hashing detects bit rot and tampering; format validators catch corruption in supported file types
  • Historical Trends — Interactive trend charts show how your data evolves: sizes, counts, changes, and alerts
  • Alert System — Suspect hash changes and validation failures flagged immediately with status management
  • Powerful Query Language — SQL-inspired syntax for filtering, sorting, and analyzing across five data domains
  • Web-First Design — Elegant web UI for all operations including scanning, browsing, querying, and configuration

📚 Documentation

Quick start instructions are below, but full documentation is available in book form:

👉 fsPulse Documentation

Key sections:

  • Getting Started — Installation, Docker deployment, and first steps
  • Interface — Complete guide to Home, Browse, Alerts, Trends, History, Roots, Schedules, Data Explorer, and Settings
  • Scanning Concepts — How scans work, hashing, and validation
  • Query Syntax — Powerful filtering and data exploration
  • Configuration — Customizing fsPulse behavior

🐳 Quick Start with Docker

docker run -d \
  --name fspulse \
  -p 8080:8080 \
  -v fspulse-data:/data \
  -v ~/Documents:/roots/documents:ro \
  gtunesdev/fspulse:latest

Access the web UI at http://localhost:8080

The Docker Deployment Guide provides complete coverage including Docker Compose examples, NAS deployments, and detailed configuration options.


⚡ Running fsPulse

Start the fsPulse server:

fspulse

Or explicitly:

fspulse serve

Open http://127.0.0.1:8080 in your browser to access the web interface.

All functionality is available through the web UI:

  • Health overview with root status and alert counts at a glance
  • Configure and manage scan roots and schedules
  • Monitor task progress in real-time
  • Browse your filesystem with tree, folder, and search views
  • Filter by integrity status: hash state, validation state, and change type
  • View point-in-time snapshots and compare across scans
  • Query and explore your data across five domains
  • Manage alerts and validation issues

Configuration

fsPulse is configured through environment variables or a config file:

# Example: Change port and enable debug logging
export FSPULSE_SERVER_PORT=9090
export FSPULSE_LOGGING_FSPULSE=debug
fspulse

See the Configuration Guide for all available settings.


🖥️ Interface Highlights

The interface is organized into two navigation groups — primary pages for everyday use, and utility pages for configuration and advanced analysis:

Primary:

  • Home — Health overview showing root status, open alerts, active tasks, and recent activity at a glance
  • Browse — Navigate your filesystem with tree, folder, and search views, integrity filters, inline detail panels, and side-by-side comparison across scans or roots
  • Alerts — Filter, flag, and dismiss integrity issues with context-aware views, batch operations, and status tracking
  • Trends — Interactive charts tracking file sizes, counts, change activity, and alert patterns over time

Utility:

  • History — Complete scan and task activity log with filtering
  • Roots — Add, remove, and scan monitored directories
  • Schedules — Create and manage automated scan schedules
  • Data Explorer — Visual query builder and free-form query interface across five data domains
  • Settings — Edit configuration, view database stats and system info
<!-- Screenshots: These screenshots need to be updated to reflect the new UI --> <!-- TODO: Replace these with current screenshots showing the new navigation and pages --> <p align="center"> <img src="https://raw.githubusercontent.com/gtunes-dev/fspulse/main/assets/screenshots/web-browse-tree.png" alt="fsPulse Browse Page - Filesystem Tree" width="90%" style="max-width: 900px;"> <br> <em>Browse page showing filesystem hierarchy navigation</em> </p> <p align="center"> <img src="https://raw.githubusercontent.com/gtunes-dev/fspulse/main/assets/screenshots/web-browse-detail.png" alt="fsPulse Browse Page - Item Detail Panel" width="90%" style="max-width: 900px;"> <br> <em>Item detail panel showing metadata, validation status, and version history</em> </p>

📦 Installation Options

fsPulse can be installed in several ways depending on your preferences and environment:

Docker Hub (Recommended)

Pull the official image and run:

docker pull gtunesdev/fspulse:latest
docker run -d --name fspulse -p 8080:8080 -v fspulse-data:/data gtunesdev/fspulse:latest

Multi-architecture support: linux/amd64, linux/arm64

See the Docker Deployment Guide for complete instructions.

Cargo (crates.io)

Install via Rust's package manager:

cargo install fspulse

Requires Rust toolchain installed on your system.

Pre-built Binaries

Download platform-specific binaries from GitHub Releases.

Available for: Linux, macOS, Windows

macOS builds include both Intel (x86_64) and Apple Silicon (ARM64) binaries.

Note: All web UI assets are embedded in the binary—no external files or dependencies required.

Build from Source

Clone the repository and use the build script:

git clone https://github.com/gtunes-dev/fspulse.git
cd fspulse
./scr
View on GitHub
GitHub Stars6
CategoryOperations
Updated2d ago
Forks0

Languages

Rust

Security Score

75/100

Audited on Mar 18, 2026

No findings