back to home

spacedriveapp / spacedrive

Spacedrive is an open source cross-platform file explorer, powered by a virtual distributed filesystem written in Rust.

37,083 stars
1,214 forks
25 issues
RustTypeScriptSwift

AI Architecture Analysis

This repository is indexed by RepoMind. By analyzing spacedriveapp/spacedrive in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.

Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.

Embed this Badge

Showcase RepoMind's analysis directly in your repository's README.

[![Analyzed by RepoMind](https://img.shields.io/badge/Analyzed%20by-RepoMind-4F46E5?style=for-the-badge)](https://repomind-ai.vercel.app/repo/spacedriveapp/spacedrive)
Preview:Analyzed by RepoMind

Repository Summary (README)

Preview
<p align="center"> <img width="150" height="150" src="packages/assets/images/AppLogoV2.png" alt="Spacedrive Logo"> <h1 align="center">Spacedrive</h1> <p align="center"> A file manager built on a virtual distributed filesystem <br /> <a href="https://spacedrive.com"><strong>spacedrive.com</strong></a> · <a href="https://v2.spacedrive.com"><strong>v2 Documentation</strong></a> · <a href="https://discord.gg/gTaF2Z44f5"><strong>Discord</strong></a> </p> <p align="center"> <a href="https://discord.gg/gTaF2Z44f5"> <img src="https://img.shields.io/discord/949090953497567312?label=Discord&color=5865F2" /> </a> <a href="https://www.gnu.org/licenses/agpl-3.0"> <img src="https://img.shields.io/static/v1?label=Licence&message=AGPL%20v3&color=000" /> </a> <a href="https://github.com/spacedriveapp/spacedrive"> <img src="https://img.shields.io/static/v1?label=Core&message=Rust&color=DEA584" /> </a> <a href="https://github.com/spacedriveapp/spacedrive/tree/main/extensions"> <img src="https://img.shields.io/static/v1?label=Ecosystem&message=WASM&color=63B17A" /> </a> </p> </p>

Spacedrive is an open source cross-platform file manager, powered by a virtual distributed filesystem (VDFS) written in Rust.

Organize files across multiple devices, clouds, and platforms from a single interface. Tag once, access everywhere. Never lose track of where your files are.

[!IMPORTANT] v2.0.0-alpha.1 Released: December 26, 2025

This is Spacedrive v2—a complete ground-up rewrite. After development of the original alpha version stopped in January this year, I rebuilt Spacedrive from scratch with the hard lessons learned.

Current status: Alpha release for macOS and Linux. Windows support coming in alpha.2. Mobile apps (iOS/Android) coming soon.

Download Release · Visit v2.spacedrive.com for complete documentation and guides.

If you're looking for the previous version, see the v1 branch.

The Problem

Computing was designed for a single-device world. The file managers we use today—Finder, Explorer, Files—were built when your data lived in one place: the computer in front of you.

The shift to multi-device computing forced us into cloud ecosystems. Want your files everywhere? Upload them to someone else's servers. The convenience came at a cost: data ownership. This wasn't accidental—centralization was the path of least resistance for solving multi-device sync.

Now AI is accelerating this trend. Cloud services offer intelligent file analysis and semantic search, but only if you upload your data to their infrastructure. As we generate more data and AI becomes more capable, we're giving away more and more to access basic computing conveniences.

The current system isn't built for a world where:

  • You own multiple devices with underutilized compute and storage
  • Local AI models are becoming competitive with cloud alternatives
  • Privacy and data sovereignty matter
  • You shouldn't have to choose between convenience and control

The Vision

Spacedrive is infrastructure for the next era of computing. It's an architecture designed for multi-device environments from the ground up—not cloud services retrofitted with offline support, but local-first sync that scales to the cloud when you want it.

As local AI models improve, Spacedrive becomes the fabric that enables the same insights cloud services offer today, but running on hardware you already own, on data that never leaves your control. This is a long-term project correcting computing's trajectory toward centralization.

The file explorer interface is deliberate. Everyone understands it. It's seen the least innovation in decades. And it has the most potential when you bake distributed computing, content awareness, and local AI into something universally familiar.

How It Works

Spacedrive treats files as first-class objects with content identity, not paths. A photo on your laptop and the same photo on your NAS are recognized as one piece of content. This enables:

  • Content-aware deduplication - Track redundancy across all devices
  • Semantic search - Find files in under 100ms across millions of entries
  • Transactional operations - Preview conflicts, space savings, and outcomes before execution
  • Peer-to-peer sync - No servers, no consensus protocols, no single point of failure
  • Offline-first - Full functionality without internet, syncs when devices reconnect

Files stay where they are. Spacedrive just makes them universally addressable with rich metadata and cross-device intelligence.


Architecture

Spacedrive is built on four core principles:

1. Virtual Distributed Filesystem (VDFS)

Files and folders become first-class objects with rich metadata, independent of their physical location. Every file gets a universal address (SdPath) that works across devices. Content-aware addressing means you can reference files by what they contain, not just where they live.

2. Content Identity System

Adaptive hashing (BLAKE3 with strategic sampling for large files) creates a unique fingerprint for every piece of content. This enables:

  • Deduplication: Recognize identical files across devices
  • Redundancy tracking: Know where your backups are
  • Content-based operations: "Copy this file from wherever it's available"

3. Transactional Actions

Every file operation can be previewed before execution. See exactly what will happen—space savings, conflicts, estimated time—then approve or cancel. Operations become durable jobs that survive network interruptions and device restarts.

4. Leaderless Sync

Peer-to-peer synchronization without central coordinators. Device-specific data (your filesystem index) uses state replication. Shared metadata (tags, ratings) uses a lightweight HLC-ordered log with deterministic conflict resolution. No leader election, no single point of failure.


Core Features

FeatureDescription
Cross-PlatformmacOS, Windows, Linux, iOS, Android
Multi-Device IndexUnified view of files across all your devices
Content AddressingFind optimal file copies automatically (local-first, then LAN, then cloud)
Smart DeduplicationIdentify identical files regardless of name or location
Cloud IntegrationIndex S3, Google Drive, Dropbox as first-class volumes
P2P NetworkingDirect device connections with automatic NAT traversal (Iroh + QUIC)
Semantic TagsGraph-based tagging with hierarchies, aliases, and contextual disambiguation
Action PreviewSimulate any operation before execution
Offline-FirstFull functionality without internet, syncs when devices reconnect
Local BackupP2P backup between your own devices (iOS photo backup available now)
Extension SystemWASM-based plugins for domain-specific functionality

Tech Stack

Core

  • Rust - Entire VDFS implementation (~183k lines)
  • Tokio - Async runtime
  • SQLite + SeaORM - Local-first database with type-safe ORM queries
  • Iroh - P2P networking with QUIC transport, hole-punching, and local discovery
  • BLAKE3 - Fast cryptographic hashing for content identity
  • Wasmer - Sandboxed WASM extension runtime
  • Axum - HTTP/GraphQL server for web and API access
  • OpenDAL - Unified cloud storage abstraction (S3, Google Drive, OneDrive, Dropbox, Azure Blob, GCS)
  • Specta - Auto-generated TypeScript and Swift types from Rust

Cryptography & Security

  • Ed25519 / X25519 - Signatures and key exchange
  • ChaCha20-Poly1305 / AES-GCM - Authenticated encryption
  • Argon2 - Password hashing
  • BIP39 - Mnemonic phrase support for key backup
  • redb - Encrypted key-value store for credentials

Media Processing

  • FFmpeg (via custom sd-ffmpeg crate) - Video thumbnails, audio extraction
  • libheif - HEIF/HEIC image support
  • Pdfium - PDF rendering
  • Whisper - On-device speech recognition (Metal-accelerated on Apple platforms)
  • Blurhash - Compact image placeholders

Interface (shared across web and desktop)

  • React 19 - UI framework
  • Vite - Build tooling
  • TypeScript - Type-safe frontend code
  • TanStack Query - Server state management
  • Zustand - Client state management
  • Radix UI - Accessible headless components
  • Tailwind CSS - Utility-first styling
  • Framer Motion - Animations
  • React Hook Form + Zod - Form management and validation
  • Three.js / React Three Fiber - 3D visualization
  • dnd-kit - Drag and drop
  • TanStack Virtual / TanStack Table - Virtualized lists and tables

Desktop

  • Tauri 2 - Cross-platform desktop shell (macOS, Linux, Windows)

Mobile (React Native)

  • React Native 0.81 + Expo - Cross-platform mobile framework
  • Expo Router - File-based routing
  • NativeWind - Tailwind CSS for React Native
  • React Navigation - Native navigation stack
  • Reanimated - Native-thread animations
  • sd-mobile-core - Rust core bridge via FFI

Architecture Patterns

  • Event-driven design with centralized EventBus
  • CQRS: Actions (mutations) and Queries (reads) with preview-commit-verify
  • Durable jobs with MessagePack serialization and checkpointing
  • Domain-separated sync with clear data ownership boundaries
  • Compile-time operation registration via inventory crate

Project Structure

spacedrive/
├── core/                  # Rust VDFS implementation
│   ├── src/
│   │   ├── domain/        # Core models (Entry, Library, Device, Tag, Volume)
│   │   ├── ops/           # CQRS operations (actions & queries)
│   │   ├── infra/         # Infrastructure (DB, events, jobs, sync)
│   │   ├── service/       # High-level services (network, file sharing, sync)
│   │   ├── crypto/        # Key management and encryption
│   │   ├── device/        # Device identity and configuration
│   │   ├── filetype/      # File type detection and registry
│   │   ├── location/      # Location management and indexing
│   │   ├── library/       # Library lifecycle and operations
│   │   └── volume/        # Volume detection and fingerprinting
│   └── tests/             # Integration tests (pairing, sync, file transfer)
├── apps/
│   ├── cli/               # CLI and daemon entry point
│   ├── server/            # Headless server for Docker/self-hosting
│   ├── tauri/             # Desktop app shell (macOS, Windows, Linux)
│   ├── web/               # Web app (Vite, connects to daemon via WebSocket)
│   ├── mobile/            # React Native mobile app (Expo)
│   ├── api/               # Cloud API server (Bun + Elysia)
│   ├── landing/           # Marketing site and docs (Next.js)
│   ├── ios/               # Native iOS prototype (Swift)
│   ├── macos/             # Native macOS prototype (Swift)
│   └── gpui-photo-grid/   # GPUI media viewer prototype
├── packages/
│   ├── interface/         # Shared React UI (used by web and desktop)
│   ├── ts-client/         # Auto-generated TypeScript client and hooks
│   ├── swift-client/      # Auto-generated Swift client
│   ├── ui/                # Shared component library
│   └── assets/            # Icons and images
├── crates/
│   ├── crypto/            # Cryptographic primitives
│   ├── ffmpeg/            # FFmpeg bindings for video/audio
│   ├── images/            # Image processing (HEIF, PDF, SVG)
│   ├── media-metadata/    # EXIF/media metadata extraction
│   ├── fs-watcher/        # Cross-platform file system watcher
│   ├── sdk/               # WASM extension SDK
│   ├── sdk-macros/        # Extension procedural macros
│   ├── task-system/       # Durable job execution engine
│   ├── sd-client/         # Rust client library
│   └── ...                # actors, fda, log-analyzer, utils
├── extensions/            # WASM extensions (photos, test-extension)
└── docs/                  # Architecture documentation

Extensions

Spacedrive's WASM-based extension system enables specialized functionality while maintaining security and portability.

[!NOTE] The extension system is under active development. A stable SDK API will be available in a future release.

Professional Extensions

ExtensionPurposeKey FeaturesStatus
PhotosAI-powered photo managementFace recognition, place identification, moments, scene classificationIn Progress
ChronicleResearch & knowledge managementDocument analysis, knowledge graphs, AI summariesIn Progress
AtlasDynamic CRM & team knowledgeRuntime schemas, contact tracking, deal pipelinesIn Progress
StudioDigital asset managementScene detection, transcription, proxy generationPlanned
LedgerFinancial intelligenceReceipt OCR, expense tracking, tax preparationPlanned
GuardianBackup & redundancy monitoringContent identity tracking, zero-redundancy alerts, smart backup suggestionsPlanned
CipherSecurity & encryptionPassword manager, file encryption, breach alertsPlanned

Open Source Archive Extensions

ExtensionPurposeProvides Data ForStatus
Email ArchiveGmail/Outlook backupAtlas, Ledger, ChroniclePlanned
Chrome HistoryBrowsing history backupChroniclePlanned
Spotify ArchiveListening historyAnalyticsPlanned
GPS TrackerLocation timelinePhotos, AnalyticsPlanned
Tweet ArchiveTwitter backupChronicle, AnalyticsPlanned
GitHub TrackerRepository trackingChroniclePlanned

Getting Started

Prerequisites

  • Rust 1.81+ (rustup)
  • Bun 1.3+ (bun.sh) - For Tauri desktop app

Quick Start with Desktop App (Tauri)

Spacedrive runs as a daemon (sd-daemon) that manages your libraries and P2P connections. The Tauri desktop app can launch its own daemon instance, or connect to a daemon started by the CLI.

# Clone the repository
git clone https://github.com/spacedriveapp/spacedrive
cd spacedrive

# Install dependencies
bun install
cargo run -p xtask -- setup  # generates .cargo/config.toml with aliases
cargo build # builds all core and apps (including the daemon and cli)

# Copy dependencies into the debug Folder ( probably windows only )
Copy-Item -Path "apps\.deps\lib\*.dll" -Destination "target\debug" -ErrorAction SilentlyContinue
Copy-Item -Path "apps\.deps\bin\*.dll" -Destination "target\debug" -ErrorAction SilentlyContinue

# Run the desktop app (automatically starts daemon)
cd apps/tauri
bun run tauri:dev

Quick Start with CLI

The CLI can manage libraries and run a persistent daemon that other apps connect to:

# Build and run the CLI
cargo run -p sd-cli -- --help

# Start the daemon (runs in background)
cargo run -p sd-cli -- daemon start

# Create a library
cargo run -p sd-cli -- library create "My Library"

# Add a location to index
cargo run -p sd-cli -- location add ~/Documents

# Search indexed files
cargo run -p sd-cli -- search .

# Now launch Tauri app - it will connect to the running daemon

Running Tests

Spacedrive has a comprehensive test suite covering single-device operations and multi-device networking scenarios.

# Run all tests
cargo test --workspace

# Run specific test
cargo test test_device_pairing --nocapture

# Run with detailed logging
RUST_LOG=debug cargo test test_name --nocapture

# Run core tests only
cargo test -p sd-core

See the Testing Guide for detailed documentation on:

  • Integration test framework
  • Multi-device subprocess testing
  • Event monitoring patterns
  • Test helpers and utilities

All integration tests are in core/tests/ including device pairing, sync, file transfer, and job execution tests.

Development Commands

# Run all tests
cargo test

# Run tests for specific package
cargo test -p sd-core

# Build CLI in release mode
cargo build -p sd-cli --release

# Format code
cargo fmt

# Run lints
cargo clippy

Privacy & Security

Spacedrive is local-first. Your data stays on your devices.

  • End-to-End Encryption: All P2P traffic encrypted via QUIC/TLS
  • At-Rest Encryption: Libraries can be encrypted on disk (SQLCipher)
  • No Telemetry: Zero tracking or analytics in the open source version
  • Self-Hostable: Run your own relay servers and cloud cores
  • Data Sovereignty: You control where your data lives

Optional cloud integration (Spacedrive Cloud) is available for backup and remote access, but it's never required. The cloud service runs unmodified Spacedrive core as a standard P2P device—no special privileges, no custom APIs.


Documentation


Get Involved

  • Star the repo to support the project
  • Join Discord to chat with developers and community
  • Read the v2 Documentation for guides and API reference
  • Read the Whitepaper for the full technical vision
  • Build an Extension - Check out the SDK docs