soju - IRC bouncer
soju is a user-friendly IRC bouncer. It connects to upstream IRC servers on
behalf of the user to provide extra features.
- Multiple separate users sharing the same bouncer, each with their own
- Clients connecting to multiple upstream servers via a single connection to
- Sending the backlog (messages received while the user was disconnected from
the bouncer), with per-client buffers
When joining a channel, the channel will be saved and automatically joined on
the next connection. When registering or authenticating with NickServ, the
credentials will be saved and automatically used on the next connection if the
server supports SASL. When parting a channel with the reason "detach", the
channel will be detached instead of being left.
When all clients are disconnected from the bouncer, the user is automatically
marked as away.
soju supports two connection modes:
- Single upstream mode: one downstream connection maps to one upstream
connection. To enable this mode, connect to the bouncer with the username
"<username>/<network>". If the bouncer isn't connected to the upstream
server, it will get automatically added. Then channels can be joined and
parted as if you were directly connected to the upstream server.
- Multiple upstream mode: one downstream connection maps to multiple upstream
connections. Channels and nicks are suffixed with the network name. To join
a channel, you need to use the suffix too: _/join #channel/network_. Same
applies to messages sent to users.
For per-client history to work, clients need to indicate their name. This can
be done by adding a "@<client>" suffix to the username.
Show help message and quit.
Path to the config file. If unset, a default config file is used.
Enable debug logging (this will leak sensitive information such as
Listening URI (default: ":6697").
# CONFIG FILE
The config file has one directive per line.
tls cert.pem key.pem
The following directives are supported:
Listening URI (default: ":6697").
The following URIs are supported:
- _[ircs://][host][:port]_ listens with TLS over TCP (default port if
- _irc+insecure://[host][:port]_ listens with plain-text over TCP (default
port if omitted: 6667)
- _wss://[host][:port]_ listens for WebSocket connections over TLS (default
- _ws+insecure://[host][:port]_ listens for plain-text WebSocket
connections (default port: 80)
- _ident://[host][:port]_ listens for plain-text ident connections (default
If the scheme is omitted, "ircs" is assumed. If multiple *listen*
directives are specified, soju will listen on each of them.
Server hostname (default: system hostname).
*tls* <cert> <key>
Enable TLS support. The certificate and the key files must be PEM-encoded.
*sql* <driver> <source>
Set the SQL driver settings. The only supported driver is "sqlite3". The
source is the path to the SQLite database file. By default, the path to the
database file is "soju.db".
Path to the bouncer logs root directory, or empty to disable logging. By
default, logging is disabled.
List of allowed HTTP origins for WebSocket listeners. The parameters are
interpreted as shell patterns, see *glob*(7).
Allow the specified IPs to act as a proxy. Proxys have the ability to
overwrite the remote and local connection addresses (via the X-Forwarded-\*
HTTP header fields). The special name "localhost" accepts the loopback
addresses 127.0.0.0/8 and ::1/128. By default, all IPs are rejected.
# IRC SERVICE
soju exposes an IRC service called *BouncerServ* to manage the bouncer.
Commands can be sent via regular private messages
(_/msg BouncerServ <command> [args...]_). Commands may be written in full or
abbreviated form, for instance *network* can be abbreviated as *net* or just
Show a list of commands. If _command_ is specified, show a help message for
*network create* *-addr* <addr> [options...]
Connect to a new network at _addr_. _-addr_ is mandatory.
_addr_ supports several connection types:
- _[ircs://]<host>[:port]_ connects with TLS over TCP
- _irc+insecure://<host>[:port]_ connects with plain-text TCP
- _irc+unix:///<path>_ connects to a Unix socket
Other options are:
Short network name. This will be used instead of _addr_ to refer to the
Connect with the specified username. By default, the nickname is used.
Connect with the specified server password.
Connect with the specified real name. By default, the nickname is used.
Connect with the specified nickname. By default, the account's username
*network update* <name> [options...]
Update an existing network. The options are the same as the
_network create_ command.
When this command is executed, soju will disconnect and re-connect to the
*network delete* <name>
Disconnect and delete a network.
Show a list of saved networks and their current status.
*channel update* <name> [options...]
Update the options of an existing channel.
Set when to relay messages from detached channels to the user with a BouncerServ NOTICE.
Relay any message from this channel when detached.
Relay only messages mentioning you when detached.
Don't relay any messages from this channel when detached.
Currently same as *highlight*. This is the default behaviour.
Set when to automatically reattach to detached channels.
Reattach to this channel when any message is received.
Reattach to this channel when any message mentioning you is received.
Never automatically reattach to this channel.
Currently same as *none*. This is the default behaviour.
Automatically detach this channel after the specified duration has elapsed without receving any message corresponding to *-detach-on*.
Example duration values: *1h30m*, *30s*, *2.5h*.
Setting this value to 0 will disable this behaviour, i.e. this channel will never be automatically detached. This is the default behaviour.
Set when to reset the auto-detach timer used by *-detach-after*, causing it to wait again for the auto-detach duration timer before detaching.
Joining, reattaching, sending a message, or changing any channel option will reset the timer, in addition to the messages specified by the mode.
Receiving any message from this channel will reset the auto-detach timer.
Receiving any message mentioning you from this channel will reset the auto-detach timer.
Receiving messages from this channel will not reset the auto-detach timer. Sending messages or joining the channel will still reset the timer.
Currently same as *message*. This is the default behaviour.
*certfp generate* [options...] <network name>
Generate self-signed certificate and use it for authentication (via SASL
Generates a RSA-3072 private key by default.
Private key algoritm to use. Valid values are: rsa, ecdsa, ed25519.
ecdsa uses NIST P-521 curve.
Size of RSA key to generate. Ignored for other key types.
*certfp fingerprint* <network name>
Show SHA-1 and SHA-256 fingerprints for the certificate
currently used with the network.
*sasl set-plain* <network name> <username> <password>
Set SASL PLAIN credentials.
*sasl reset* <network name>
Disable SASL authentication and remove stored credentials.
*user create* -username <username> -password <password> [-admin]
Create a new soju user. Only admin users can create new accounts.
*change-password* <new password>
Change current user password.
Maintained by Simon Ser <email@example.com>, who is assisted by other
open-source contributors. For more information about soju development, see