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.1.0.tar.gz (364.4 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.1.0-py3-none-any.whl (153.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for fossilrepo-0.1.0.tar.gz
Algorithm Hash digest
SHA256 c3fe2186baed91eaf7bcc1b7a09f68e43332cdc6ede2022f7875ebe65a5ef76e
MD5 9c5ac02a2df15638eef874974290caca
BLAKE2b-256 fb879d7dccdab8624a2508727355b7ceef8b74550250d3250b6c56580b48fc39

See more details on using hashes here.

Provenance

The following attestation bundles were made for fossilrepo-0.1.0.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.1.0-py3-none-any.whl.

File metadata

  • Download URL: fossilrepo-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 153.9 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.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ae37993a79acd890b4c00d1104b64f35e4cd000b1327467f4a7520feea01c14f
MD5 e1da86ca14b9e18a5e70271adbac909d
BLAKE2b-256 9b5c56604b3a24e705aef75c910cf6205e205544205d0afa12375c8efbb465d1

See more details on using hashes here.

Provenance

The following attestation bundles were made for fossilrepo-0.1.0-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