user d2144fc029 feat: add Containerfile and podman-compose setup
Host network mode for direct access to SOCKS5 proxy on localhost.
Config volume mounted from ./config. Makefile targets: build, up,
down, logs.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-19 18:34:48 +01:00

bouncer

IRC bouncer with SOCKS5 proxy support and persistent message backlog.

Features

  • Connect to multiple IRC networks simultaneously
  • All outbound connections routed through SOCKS5 proxy
  • Stealth connect: registers with a random pronounceable nick and generic identity
  • Probation window: waits 15s after registration to detect K-lines before revealing real nick
  • Persistent message backlog (SQLite) with replay on reconnect
  • Multiple clients can attach to the same network session
  • Password authentication
  • TLS support for IRC server connections
  • Automatic reconnection with exponential backoff
  • Local DNS resolution with multi-address failover

Quick Start

cd ~/git/bouncer
make dev

cp config/bouncer.example.toml config/bouncer.toml
$EDITOR config/bouncer.toml

bouncer -c config/bouncer.toml -v

Connect

From your IRC client, connect to 127.0.0.1:6667 with:

PASS networkname:yourpassword

Where networkname matches a [networks.NAME] section in your config.

How It Works

IRC Client(s) --> [bouncer:6667] --> Router --> [SOCKS5:1080] --> IRC Server(s)
                                       |
                                    Backlog
                                   (SQLite)
  1. Bouncer connects to IRC server via SOCKS5 with a random identity
  2. Survives 15s probation (K-line detection)
  3. Switches to your configured nick
  4. Joins configured channels
  5. Clients connect to bouncer, receive backlog replay and channel state

Documentation

Document Description
docs/INSTALL.md Prerequisites and setup
docs/USAGE.md Comprehensive guide
docs/CHEATSHEET.md Quick reference
docs/DEBUG.md Troubleshooting

Development

make dev      # Install with dev deps
make test     # Run tests
make lint     # Run linter
make fmt      # Format code
Description
No description provided
Readme 403 KiB
Languages
Python 99.6%
Makefile 0.3%
Dockerfile 0.1%