ergo/README.md

70 lines
2.1 KiB
Markdown
Raw Normal View History

2015-06-24 06:35:14 +02:00
Ergonomadic (anagram of "go IRC daemon") is an IRC daemon written from scratch
in Go. Pull requests and issues are welcome.
2012-04-18 06:23:12 +02:00
2015-06-24 06:35:14 +02:00
Discussion at:
* host/port: irc.skub.club:6697, use SSL
* password: smellyoulater
* #darwin
2012-04-18 06:23:12 +02:00
2015-06-24 06:35:14 +02:00
# Features
2015-06-24 06:35:14 +02:00
* follows the RFCs where possible
* UTF-8 nick and channel names
* [gcfg](https://code.google.com/p/gcfg/) gitconfig-style configuration
* server password (PASS command)
* channels with most standard modes
* IRC operators (OPER command)
* haproxy [PROXY protocol][proxy-proto] header for hostname setting
* passwords stored in [bcrypt][go-crypto] format
* channels that [persist][go-sqlite] between restarts (+P)
* messages are queued in the same order to all connected clients
2015-06-24 06:35:14 +02:00
# What about SSL/TLS support?
2014-03-01 23:45:23 +01:00
2014-03-18 23:29:31 +01:00
Go has a not-yet-verified-as-safe TLS 1.2 implementation. Sadly, many popular
IRC clients will negotiate nothing newer than SSLv2. If you want to use SSL to
2015-06-24 06:35:14 +02:00
protect traffic, I recommend using
[stunnel](https://www.stunnel.org/index.html) version 4.56 with haproxy's
[PROXY protocol][proxy-proto]. This will allow the server to get the client's
original addresses for hostname lookups.
2014-03-18 23:29:31 +01:00
2015-06-24 06:35:14 +02:00
# What about federation?
2014-03-18 23:29:31 +01:00
IRC federation solves a problem that was more likely to occur on the internet of
1991 than today. We are exploring alternatives to federation that avoid nickname
and channel sync issues created during netsplits.
2014-03-01 23:45:23 +01:00
2015-06-24 06:35:14 +02:00
# Installation
2014-02-10 00:15:02 +01:00
```sh
go get
2014-02-10 00:15:02 +01:00
go install
2014-03-13 20:40:33 +01:00
ergonomadic initdb -conf ergonomadic.conf
2014-02-27 07:25:10 +01:00
```
2015-06-24 06:35:14 +02:00
# Configuration
2014-02-27 07:25:10 +01:00
See the example [`ergonomadic.conf`](ergonomadic.conf). Passwords are base64-encoded bcrypted byte
2014-03-18 23:29:31 +01:00
strings. You can generate them with the `genpasswd` subcommand.
2014-02-27 07:25:10 +01:00
```sh
2014-03-13 20:40:33 +01:00
ergonomadic genpasswd 'hunter2!'
2014-02-27 07:25:10 +01:00
```
2015-06-24 06:35:14 +02:00
# Running the server
2014-02-27 07:25:10 +01:00
```sh
2014-03-13 20:40:33 +01:00
ergonomadic run -conf ergonomadic.conf
```
2014-02-27 20:07:21 +01:00
2015-06-24 06:35:14 +02:00
# Credits
2014-03-18 23:29:31 +01:00
2015-06-24 06:35:14 +02:00
* Jeremy Latt, creator, <https://github.com/jlatt>
* Edmund Huber, maintainer, <https://github.com/edmund-huber>
* Niels Freier, added WebSocket support, <https://github.com/stumpyfr>
* apologies to anyone I forgot.
2014-03-18 23:29:31 +01:00
2014-03-18 23:45:51 +01:00
[go-crypto]: http://godoc.org/code.google.com/p/go.crypto
[go-sqlite]: https://github.com/mattn/go-sqlite3
[proxy-proto]: http://haproxy.1wt.eu/download/1.5/doc/proxy-protocol.txt