soju forked to be LESS SHIT
5b10348957
Some clients will queue up multiple AUTHENTICATE commands without waiting for a reply to avoid some roundtrips. However that means the traffic looks like so: AUTHENTICATE <mechanism> AUTHENTICATE <base64 blob containing credentials> soju will fail the first command, and will behave as if no SASL authentication was in progress when interpreting the second one. This means we'll echo back the security-sensitive base64 blob to the client in the error message, which is definitely not great. Stop doing that. |
||
---|---|---|
cmd | ||
config | ||
contrib | ||
database | ||
doc | ||
identd | ||
msgstore | ||
xirc | ||
.build.yml | ||
.editorconfig | ||
.gitignore | ||
certfp.go | ||
config.in | ||
conn.go | ||
downstream.go | ||
go.mod | ||
go.sum | ||
irc_test.go | ||
irc.go | ||
LICENSE | ||
Makefile | ||
net_go113.go | ||
net_go116.go | ||
rate.go | ||
README.md | ||
server_test.go | ||
server.go | ||
service_test.go | ||
service.go | ||
upstream.go | ||
user.go |
soju
soju is a user-friendly IRC bouncer. soju connects to upstream IRC servers on behalf of the user to provide extra functionality. soju supports many features such as multiple users, numerous IRCv3 extensions, chat history playback and detached channels. It is well-suited for both small and large deployments.
Usage
Building and installing
Dependencies:
- Go
- BSD or GNU make
- a C89 compiler (optional, for SQLite)
- scdoc (optional, for man pages)
For end users, a Makefile
is provided:
make
sudo make install
For development, you can use go run ./cmd/soju
as usual.
To link with the system libsqlite3, set GOFLAGS="-tags=libsqlite3"
. To disable
SQLite support, set GOFLAGS="-tags=nosqlite"
.
Contributing
Send patches on the mailing list or on GitHub, report bugs on the issue tracker. Discuss in #soju on Libera Chat.
License
AGPLv3, see LICENSE.
Copyright (C) 2020 The soju Contributors