2016-04-12 22:55:37 +00:00
Oragono is a very early, extremely experimental fork of the [Ergonomadic ](https://github.com/edmund-huber/ergonomadic ) IRC daemon. Ergonomadic looks cool, and this is something I can experiment on. Hopefully most of the stuff I do in this can be merged back into Ergonomadic! Also see the [mammon ](https://github.com/mammon-ircd/mammon ) IRC daemon for something similar written in Python.
2012-04-18 04:23:12 +00:00
2016-04-14 05:31:51 +00:00
This project adheres to [Semantic Versioning ](http://semver.org/ ). For the purposes of versioning, we consider the "public API" to refer to the configuration files, CLI interface and database format.
2015-06-24 04:35:14 +00:00
# Features
2014-02-24 17:41:09 +00:00
2015-06-24 04:35:14 +00:00
* UTF-8 nick and channel names
2016-04-12 13:00:09 +00:00
* [yaml ](http://yaml.org/ ) configuration
2015-06-24 04:35:14 +00:00
* server password (PASS command)
* channels with most standard modes
* IRC operators (OPER command)
* 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
2014-02-24 17:41:09 +00:00
2016-04-13 10:45:09 +00:00
# What about SSL/TLS?
2014-03-01 22:45:23 +00:00
2016-04-13 10:45:09 +00:00
There is inbuilt TLS support using the Go TLS implementation. However,
2015-06-24 04:35:14 +00:00
[stunnel ](https://www.stunnel.org/index.html ) version 4.56 with haproxy's
2016-04-13 10:45:09 +00:00
[PROXY protocol ](http://haproxy.1wt.eu/download/1.5/doc/proxy-protocol.txt )
may also be used. This will allow the server to get the client's original
addresses for hostname lookups.
2014-03-18 22:29:31 +00:00
2015-06-24 04:35:14 +00:00
# Installation
2014-02-09 23:15:02 +00:00
```sh
2014-02-24 17:41:09 +00:00
go get
2014-02-09 23:15:02 +00:00
go install
2016-04-12 22:55:37 +00:00
cp oragono.yaml ircd.yaml
2016-04-12 13:00:09 +00:00
vim ircd.yaml # modify the config file to your liking
2016-04-12 22:55:37 +00:00
oragono initdb
2016-06-15 09:31:39 +00:00
oragono createcerts
2014-02-27 06:25:10 +00:00
```
2015-06-24 04:35:14 +00:00
# Configuration
2014-02-27 06:25:10 +00:00
2016-04-12 22:55:37 +00:00
See the example [`oragono.yaml` ](oragono.yaml ). Passwords are base64-encoded bcrypted byte
2014-03-18 22:29:31 +00:00
strings. You can generate them with the `genpasswd` subcommand.
2014-02-27 06:25:10 +00:00
```sh
2016-04-12 22:55:37 +00:00
oragono genpasswd
2014-02-27 06:25:10 +00:00
```
2015-06-24 04:35:14 +00:00
# Running the server
2014-02-27 06:25:10 +00:00
```sh
2016-04-12 22:55:37 +00:00
oragono run
2013-05-25 04:39:53 +00:00
```
2014-02-27 19:07:21 +00:00
2015-06-24 04:35:14 +00:00
# Credits
2014-03-18 22:29:31 +00:00
2016-04-12 22:55:37 +00:00
* Jeremy Latt, creator of Ergonomadic, < https: // github . com / jlatt >
* Edmund Huber, maintainer of Ergonomadic, < https: // github . com / edmund-huber >
* Niels Freier, added WebSocket support to Ergonomadic, < https: // github . com / stumpyfr >
2015-06-24 04:35:14 +00:00
* apologies to anyone I forgot.
2014-03-18 22:29:31 +00:00
2015-07-02 12:10:19 +00:00
[go-crypto]: https://godoc.org/golang.org/x/crypto
2014-03-18 22:45:51 +00:00
[go-sqlite]: https://github.com/mattn/go-sqlite3