Skip to main content

Self-hosted Fossil SCM forge — code hosting, issues, wiki, and continuous backups in one command.

Project description

Fossilrepo

Self-hosted Fossil forge with a modern web interface.

Fossilrepo wraps Fossil SCM with a Django + HTMX management layer, replacing Fossil's built-in web UI with a GitHub/GitLab-caliber experience while preserving everything that makes Fossil unique: single-file repos, built-in wiki, tickets, forum, and technotes.

Why Fossilrepo?

Fossil is the most underrated version control system. Every repository is a single SQLite file containing your code, wiki, tickets, forum, and technotes. No external services, no complex setup. But its web UI hasn't changed since 1998.

Fossilrepo fixes that. You get:

  • A modern dark/light UI built with Django, HTMX, Alpine.js, and Tailwind CSS
  • GitHub-style code browser with line numbers, blame, history, and syntax highlighting
  • Timeline with DAG graph showing fork/merge connectors and color-coded branches
  • Full ticket CRUD with filters, comments, and CSV export
  • Wiki with Markdown + Fossil markup + Pikchr diagram rendering
  • Forum with threaded discussions
  • Releases with file attachments and markdown changelogs
  • Git mirror sync to GitHub/GitLab via OAuth
  • Clone/push/pull over HTTP and SSH through Django's auth layer
  • Webhook dispatch with HMAC signing and delivery logs
  • Omnibus Docker image with Fossil compiled from source

All while Fossil remains the source of truth. Fossilrepo reads .fossil files directly via SQLite for speed, and uses the fossil CLI for writes to preserve artifact integrity.

Stack

Layer Technology
Backend Django 5 (Python 3.12+)
Frontend HTMX 2.0 + Alpine.js 3 + Tailwind CSS (CDN)
Database PostgreSQL 16 (app data) + SQLite (Fossil repos)
Cache/Broker Redis 7
Jobs Celery + Redis
Auth Session-based (httpOnly cookies)
SCM Fossil 2.24 (compiled from source in Docker)
Linter Ruff

Quick Start

git clone https://github.com/ConflictHQ/fossilrepo.git
cd fossilrepo
docker compose up -d --build

# Run migrations and seed sample data
docker compose exec backend python manage.py migrate
docker compose exec backend python manage.py seed

# Open the app
open http://localhost:8000

Default users: admin / admin (superuser) and viewer / viewer (read-only).

Features

Code Browser

  • Directory navigation with breadcrumbs
  • Syntax-highlighted source view with line numbers and permalinks
  • Blame with age-based coloring (newest = brand red, oldest = gray)
  • File history, raw download, rendered preview for Markdown/HTML

Timeline

  • DAG graph with fork/merge connectors, color-coded branches
  • Merge commit diamonds, leaf indicators
  • Keyboard navigation (j/k/Enter), HTMX infinite scroll
  • RSS feed

Diffs

  • Unified and side-by-side view (toggle with localStorage preference)
  • Syntax highlighting via highlight.js
  • Line-level permalinks
  • Compare any two checkins

Tickets

  • Filter by status, type, priority, severity
  • Full CRUD: create, edit, close/reopen, comment
  • CSV export
  • Pagination with configurable page size

Wiki

  • Markdown + Fossil wiki markup + raw HTML
  • Pikchr diagram rendering
  • Right-sidebar table of contents
  • Create and edit pages

Forum

  • Threaded discussions (Fossil-native + Django-backed posts)
  • Create threads, post replies
  • Markdown body with preview

Releases

  • Versioned releases with tag names and markdown changelogs
  • File attachments with download counts
  • Draft and prerelease support

Sync

  • Pull from upstream Fossil remotes
  • Git mirror to GitHub/GitLab (OAuth or SSH key auth)
  • Clone/push/pull over HTTP via fossil http CGI proxy
  • SSH push via restricted sshd (port 2222)
  • Configurable sync modes: on-change, scheduled, both

Webhooks

  • Outbound webhooks on checkin, ticket, wiki, and release events
  • HMAC-SHA256 signed payloads
  • Exponential backoff retry (3 attempts)
  • Delivery log with response status and timing

Organization

  • Single-org model with teams and members
  • User CRUD: create, edit, deactivate, change password
  • Team management with member assignment
  • Project-level team roles: read, write, admin
  • Project visibility: public, internal, private

Infrastructure

  • Omnibus Docker image (Fossil compiled from source)
  • Caddy for SSL termination and subdomain routing
  • Litestream for continuous SQLite-to-S3 replication
  • Celery Beat for scheduled metadata sync and upstream checks
  • Encrypted credential storage (Fernet/AES-128-CBC at rest)

Architecture

Browser
  |
  v
Django 5 + HTMX + Alpine.js + Tailwind CSS
  |
  |-- FossilReader (direct SQLite reads from .fossil files)
  |-- FossilCLI (subprocess wrapper for write operations)
  |-- fossil http (CGI proxy for clone/push/pull)
  |
  |-- PostgreSQL 16 (orgs, users, teams, projects, settings)
  |-- Redis 7 (Celery broker, cache)
  |-- Celery (background sync, webhooks, notifications)
  |
  v
.fossil files (SQLite — code + wiki + tickets + forum + technotes)
  |
  v
Litestream --> S3 (continuous backup)

No separate frontend service. Django serves everything: templates, static files, and HTMX partials.

Configuration

All runtime settings are configurable via Django admin (Constance):

Setting Default Description
SITE_NAME Fossilrepo Display name
FOSSIL_DATA_DIR /data/repos Where .fossil files live
FOSSIL_BINARY_PATH fossil Path to the fossil binary
FOSSIL_STORE_IN_DB false Store .fossil snapshots via Django file storage
FOSSIL_S3_TRACKING false Track S3/Litestream replication
GIT_SYNC_MODE disabled Default sync mode for new mirrors
GIT_SYNC_SCHEDULE */15 * * * * Default cron for scheduled sync

See .env.example for all environment variables and .env.production.example for production configuration.

Development

# Local development (without Docker)
uv sync --all-extras
DJANGO_DEBUG=true POSTGRES_HOST=localhost uv run python manage.py runserver

# Run tests
DJANGO_DEBUG=true uv run pytest

# Lint
ruff check . && ruff format --check .

See CONTRIBUTING.md for the full development guide and bootstrap.md for codebase conventions.

License

MIT License. See LICENSE for details.


Built by CONFLICT. Fossilrepo is open source under the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fossilrepo-0.0.9.tar.gz (365.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fossilrepo-0.0.9-py3-none-any.whl (154.2 kB view details)

Uploaded Python 3

File details

Details for the file fossilrepo-0.0.9.tar.gz.

File metadata

  • Download URL: fossilrepo-0.0.9.tar.gz
  • Upload date:
  • Size: 365.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fossilrepo-0.0.9.tar.gz
Algorithm Hash digest
SHA256 25fc8e094b091cdb2c87bbe0662213a91b05cf803620552c59602b44edb27a5e
MD5 7853102156c64cd6c08bcb3f030c71b6
BLAKE2b-256 0a9532088adae53ced1e271e06d983dd1d8323bce7e5ddb40d2380cf634339a3

See more details on using hashes here.

Provenance

The following attestation bundles were made for fossilrepo-0.0.9.tar.gz:

Publisher: publish.yaml on ConflictHQ/fossilrepo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fossilrepo-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: fossilrepo-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 154.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fossilrepo-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 53bdaaf7be84f4a85eef015eadb6b347b8ea1563a1081433da7cd86daa06f065
MD5 5411fd98a4630a2967d1a6dff82d3502
BLAKE2b-256 b0eb5613803c1cb12c9e851d6ea76584bdfb545c6f18dcd0b9c00f84363caca3

See more details on using hashes here.

Provenance

The following attestation bundles were made for fossilrepo-0.0.9-py3-none-any.whl:

Publisher: publish.yaml on ConflictHQ/fossilrepo

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page