2016-06-28 08:37:58 +02:00
# Oragono
2016-08-14 06:27:33 +02:00
Oragono is an IRC daemon written in Go. It's an early, experimental fork of the [Ergonomadic ](https://github.com/edmund-huber/ergonomadic ) IRC daemon.
Also see the [mammon ](https://github.com/mammon-ircd/mammon ) IRC daemon for a similar project written in Python instead.
2012-04-18 06:23:12 +02:00
2016-06-28 08:37:58 +02:00
---
[![Go Report Card ](https://goreportcard.com/badge/github.com/DanielOaks/oragono )](https://goreportcard.com/report/github.com/DanielOaks/oragono)
---
2016-04-14 07:31:51 +02: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.
2016-06-28 08:34:48 +02:00
*NOTE: Things are probably very broken right now. The `THEATER` command does not work, and I'm currently most of the way through rearchitecting the command handling. It should be finished apart from the `THEATER` command, but things are probably still broken.*
2016-06-28 08:37:58 +02:00
## Features
2014-02-24 18:41:09 +01:00
2015-06-24 06:35:14 +02:00
* UTF-8 nick and channel names
2016-04-12 15:00:09 +02:00
* [yaml ](http://yaml.org/ ) configuration
2016-08-14 06:27:33 +02:00
* native TLS/SSL support
* server password (`PASS` command)
2015-06-24 06:35:14 +02:00
* channels with most standard modes
2016-08-14 06:27:33 +02:00
* IRC operators
* ident lookups for usernames
2015-06-24 06:35:14 +02:00
* passwords stored in [bcrypt][go-crypto] format
* channels that [persist][go-sqlite] between restarts (+P)
2016-09-07 13:35:43 +02:00
* client accounts and SASL
2016-08-14 06:27:33 +02:00
* IRCv3 support
2014-02-24 18:41:09 +01:00
2016-08-14 06:27:33 +02:00
### What about TLS/SSL?
2014-03-01 23:45:23 +01:00
2016-04-13 12:45:09 +02:00
There is inbuilt TLS support using the Go TLS implementation. However,
2015-06-24 06:35:14 +02:00
[stunnel ](https://www.stunnel.org/index.html ) version 4.56 with haproxy's
2016-04-13 12:45:09 +02: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 23:29:31 +01:00
2016-06-28 08:37:58 +02:00
## Installation
2014-02-10 00:15:02 +01:00
```sh
2014-02-24 18:41:09 +01:00
go get
2014-02-10 00:15:02 +01:00
go install
2016-04-13 00:55:37 +02:00
cp oragono.yaml ircd.yaml
2016-04-12 15:00:09 +02:00
vim ircd.yaml # modify the config file to your liking
2016-04-13 00:55:37 +02:00
oragono initdb
2016-08-13 10:17:40 +02:00
oragono mkcerts
2014-02-27 07:25:10 +01:00
```
2016-08-14 06:27:33 +02:00
**Note:** This installation will give you unsigned certificates only suitable for teting purposes.
For real crets, look into [Let's Encrypt ](https://letsencrypt.org/ ).
2016-06-28 08:37:58 +02:00
## Configuration
2014-02-27 07:25:10 +01:00
2016-06-19 01:58:23 +02:00
See the example [`oragono.yaml` ](oragono.yaml ). Passwords are stored using bcrypt. You can generate encrypted password strings for use in the config with the `genpasswd` subcommand.
2014-02-27 07:25:10 +01:00
```sh
2016-04-13 00:55:37 +02:00
oragono genpasswd
2014-02-27 07:25:10 +01:00
```
2016-06-28 08:37:58 +02:00
## Running the server
2014-02-27 07:25:10 +01:00
```sh
2016-04-13 00:55:37 +02:00
oragono run
2013-05-25 06:39:53 +02:00
```
2014-02-27 20:07:21 +01:00
2016-06-28 08:37:58 +02:00
## Credits
2014-03-18 23:29:31 +01:00
2016-04-13 00:55:37 +02: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 >
2016-06-16 11:40:25 +02:00
* Daniel Oakley, maintainer of Oragono, < https: // github . com / DanielOaks >
2015-06-24 06:35:14 +02:00
* apologies to anyone I forgot.
2014-03-18 23:29:31 +01:00
2015-07-02 14:10:19 +02:00
[go-crypto]: https://godoc.org/golang.org/x/crypto
2014-03-18 23:45:51 +01:00
[go-sqlite]: https://github.com/mattn/go-sqlite3