mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-03 16:42:38 +01:00
fix #283 (remove unnecessary log.Fatal)
The server should never crash during rehash, even if the config is invalid.
This commit is contained in:
parent
a72de2f4d2
commit
3c12fb6254
@ -7,7 +7,6 @@ package irc
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
|
||||||
"net"
|
"net"
|
||||||
"runtime/debug"
|
"runtime/debug"
|
||||||
"strconv"
|
"strconv"
|
||||||
@ -82,8 +81,8 @@ type Client struct {
|
|||||||
vhost string
|
vhost string
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewClient returns a client with all the appropriate info setup.
|
// NewClient sets up a new client and starts its goroutine.
|
||||||
func NewClient(server *Server, conn net.Conn, isTLS bool) *Client {
|
func NewClient(server *Server, conn net.Conn, isTLS bool) {
|
||||||
now := time.Now()
|
now := time.Now()
|
||||||
config := server.Config()
|
config := server.Config()
|
||||||
fullLineLenLimit := config.Limits.LineLen.Tags + config.Limits.LineLen.Rest
|
fullLineLenLimit := config.Limits.LineLen.Tags + config.Limits.LineLen.Rest
|
||||||
@ -114,15 +113,17 @@ func NewClient(server *Server, conn net.Conn, isTLS bool) *Client {
|
|||||||
}
|
}
|
||||||
if config.Server.CheckIdent && !utils.AddrIsUnix(conn.RemoteAddr()) {
|
if config.Server.CheckIdent && !utils.AddrIsUnix(conn.RemoteAddr()) {
|
||||||
_, serverPortString, err := net.SplitHostPort(conn.LocalAddr().String())
|
_, serverPortString, err := net.SplitHostPort(conn.LocalAddr().String())
|
||||||
|
if err != nil {
|
||||||
|
server.logger.Error("internal", "bad server address", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
serverPort, _ := strconv.Atoi(serverPortString)
|
serverPort, _ := strconv.Atoi(serverPortString)
|
||||||
if err != nil {
|
|
||||||
log.Fatal(err)
|
|
||||||
}
|
|
||||||
clientHost, clientPortString, err := net.SplitHostPort(conn.RemoteAddr().String())
|
clientHost, clientPortString, err := net.SplitHostPort(conn.RemoteAddr().String())
|
||||||
clientPort, _ := strconv.Atoi(clientPortString)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
server.logger.Error("internal", "bad client address", err.Error())
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
clientPort, _ := strconv.Atoi(clientPortString)
|
||||||
|
|
||||||
client.Notice(client.t("*** Looking up your username"))
|
client.Notice(client.t("*** Looking up your username"))
|
||||||
resp, err := ident.Query(clientHost, serverPort, clientPort, IdentTimeoutSeconds)
|
resp, err := ident.Query(clientHost, serverPort, clientPort, IdentTimeoutSeconds)
|
||||||
@ -141,8 +142,6 @@ func NewClient(server *Server, conn net.Conn, isTLS bool) *Client {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
go client.run()
|
go client.run()
|
||||||
|
|
||||||
return client
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (client *Client) resetFakelag() {
|
func (client *Client) resetFakelag() {
|
||||||
|
@ -410,17 +410,17 @@ func (conf *Config) Operators(oc map[string]*OperClass) (map[string]*Oper, error
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TLSListeners returns a list of TLS listeners and their configs.
|
// TLSListeners returns a list of TLS listeners and their configs.
|
||||||
func (conf *Config) TLSListeners() map[string]*tls.Config {
|
func (conf *Config) TLSListeners() (map[string]*tls.Config, error) {
|
||||||
tlsListeners := make(map[string]*tls.Config)
|
tlsListeners := make(map[string]*tls.Config)
|
||||||
for s, tlsListenersConf := range conf.Server.TLSListeners {
|
for s, tlsListenersConf := range conf.Server.TLSListeners {
|
||||||
config, err := tlsListenersConf.Config()
|
config, err := tlsListenersConf.Config()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(err)
|
return nil, err
|
||||||
}
|
}
|
||||||
config.ClientAuth = tls.RequestClientCert
|
config.ClientAuth = tls.RequestClientCert
|
||||||
tlsListeners[s] = config
|
tlsListeners[s] = config
|
||||||
}
|
}
|
||||||
return tlsListeners
|
return tlsListeners, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// LoadConfig loads the given YAML configuration file.
|
// LoadConfig loads the given YAML configuration file.
|
||||||
|
@ -124,7 +124,9 @@ func (logger *Manager) ApplyConfig(config []LoggingConfig) error {
|
|||||||
stdoutWriteLock: &logger.stdoutWriteLock,
|
stdoutWriteLock: &logger.stdoutWriteLock,
|
||||||
fileWriteLock: &logger.fileWriteLock,
|
fileWriteLock: &logger.fileWriteLock,
|
||||||
}
|
}
|
||||||
if typeMap["userinput"] || typeMap["useroutput"] || (typeMap["*"] && !(excludedTypeMap["userinput"] && excludedTypeMap["useroutput"])) {
|
ioEnabled := typeMap["userinput"] || typeMap["useroutput"] || (typeMap["*"] && !(excludedTypeMap["userinput"] && excludedTypeMap["useroutput"]))
|
||||||
|
// raw I/O is only logged at level debug;
|
||||||
|
if ioEnabled && logConfig.Level == LogDebug {
|
||||||
atomic.StoreUint32(&logger.loggingRawIO, 1)
|
atomic.StoreUint32(&logger.loggingRawIO, 1)
|
||||||
}
|
}
|
||||||
if sLogger.MethodFile.Enabled {
|
if sLogger.MethodFile.Enabled {
|
||||||
@ -177,13 +179,6 @@ func (logger *Manager) Error(logType string, messageParts ...string) {
|
|||||||
logger.Log(LogError, logType, messageParts...)
|
logger.Log(LogError, logType, messageParts...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fatal logs the given message as an error message, then exits.
|
|
||||||
func (logger *Manager) Fatal(logType string, messageParts ...string) {
|
|
||||||
logger.Error(logType, messageParts...)
|
|
||||||
logger.Error("FATAL", "Fatal error encountered, application exiting")
|
|
||||||
os.Exit(1)
|
|
||||||
}
|
|
||||||
|
|
||||||
type fileMethod struct {
|
type fileMethod struct {
|
||||||
Enabled bool
|
Enabled bool
|
||||||
Filename string
|
Filename string
|
||||||
|
@ -20,6 +20,11 @@ func servCmdRequiresAuthEnabled(server *Server) bool {
|
|||||||
return server.AccountConfig().AuthenticationEnabled
|
return server.AccountConfig().AuthenticationEnabled
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func nsGroupEnabled(server *Server) bool {
|
||||||
|
conf := server.Config()
|
||||||
|
return conf.Accounts.AuthenticationEnabled && conf.Accounts.NickReservation.Enabled
|
||||||
|
}
|
||||||
|
|
||||||
const nickservHelp = `NickServ lets you register and login to an account.
|
const nickservHelp = `NickServ lets you register and login to an account.
|
||||||
|
|
||||||
To see in-depth help for a specific NickServ command, try:
|
To see in-depth help for a specific NickServ command, try:
|
||||||
@ -55,7 +60,7 @@ same user account, letting you reclaim your nickname.`,
|
|||||||
GROUP links your current nickname with your logged-in account, preventing other
|
GROUP links your current nickname with your logged-in account, preventing other
|
||||||
users from changing to it (or forcing them to rename).`,
|
users from changing to it (or forcing them to rename).`,
|
||||||
helpShort: `$bGROUP$b links your current nickname to your user account.`,
|
helpShort: `$bGROUP$b links your current nickname to your user account.`,
|
||||||
enabled: servCmdRequiresAccreg,
|
enabled: nsGroupEnabled,
|
||||||
authRequired: true,
|
authRequired: true,
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -10,7 +10,6 @@ import (
|
|||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
|
||||||
"math/rand"
|
"math/rand"
|
||||||
"net"
|
"net"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -328,8 +327,8 @@ func (server *Server) checkBans(ipaddr net.IP) (banned bool, message string) {
|
|||||||
// IRC protocol listeners
|
// IRC protocol listeners
|
||||||
//
|
//
|
||||||
|
|
||||||
// createListener starts the given listeners.
|
// createListener starts a given listener.
|
||||||
func (server *Server) createListener(addr string, tlsConfig *tls.Config) *ListenerWrapper {
|
func (server *Server) createListener(addr string, tlsConfig *tls.Config) (*ListenerWrapper, error) {
|
||||||
// make listener
|
// make listener
|
||||||
var listener net.Listener
|
var listener net.Listener
|
||||||
var err error
|
var err error
|
||||||
@ -342,7 +341,7 @@ func (server *Server) createListener(addr string, tlsConfig *tls.Config) *Listen
|
|||||||
listener, err = net.Listen("tcp", addr)
|
listener, err = net.Listen("tcp", addr)
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal(server, "listen error: ", err)
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
// throw our details to the server so we can be modified/killed later
|
// throw our details to the server so we can be modified/killed later
|
||||||
@ -385,7 +384,7 @@ func (server *Server) createListener(addr string, tlsConfig *tls.Config) *Listen
|
|||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
return &wrapper
|
return &wrapper, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// generateMessageID returns a network-unique message ID.
|
// generateMessageID returns a network-unique message ID.
|
||||||
@ -899,7 +898,7 @@ func (server *Server) applyConfig(config *Config, initial bool) (err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// we are now open for business
|
// we are now open for business
|
||||||
server.setupListeners(config)
|
err = server.setupListeners(config)
|
||||||
|
|
||||||
if !initial {
|
if !initial {
|
||||||
// push new info to all of our clients
|
// push new info to all of our clients
|
||||||
@ -914,7 +913,7 @@ func (server *Server) applyConfig(config *Config, initial bool) (err error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (server *Server) setupPprofListener(config *Config) {
|
func (server *Server) setupPprofListener(config *Config) {
|
||||||
@ -1024,15 +1023,20 @@ func (server *Server) loadDatastore(config *Config) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (server *Server) setupListeners(config *Config) {
|
func (server *Server) setupListeners(config *Config) (err error) {
|
||||||
logListener := func(addr string, tlsconfig *tls.Config) {
|
logListener := func(addr string, tlsconfig *tls.Config) {
|
||||||
server.logger.Info("listeners",
|
server.logger.Info("listeners",
|
||||||
fmt.Sprintf("now listening on %s, tls=%t.", addr, (tlsconfig != nil)),
|
fmt.Sprintf("now listening on %s, tls=%t.", addr, (tlsconfig != nil)),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tlsListeners, err := config.TLSListeners()
|
||||||
|
if err != nil {
|
||||||
|
server.logger.Error("rehash", "failed to reload TLS certificates, aborting rehash", err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// update or destroy all existing listeners
|
// update or destroy all existing listeners
|
||||||
tlsListeners := config.TLSListeners()
|
|
||||||
for addr := range server.listeners {
|
for addr := range server.listeners {
|
||||||
currentListener := server.listeners[addr]
|
currentListener := server.listeners[addr]
|
||||||
var stillConfigured bool
|
var stillConfigured bool
|
||||||
@ -1068,7 +1072,13 @@ func (server *Server) setupListeners(config *Config) {
|
|||||||
if !exists {
|
if !exists {
|
||||||
// make new listener
|
// make new listener
|
||||||
tlsConfig := tlsListeners[newaddr]
|
tlsConfig := tlsListeners[newaddr]
|
||||||
server.listeners[newaddr] = server.createListener(newaddr, tlsConfig)
|
listener, listenerErr := server.createListener(newaddr, tlsConfig)
|
||||||
|
if listenerErr != nil {
|
||||||
|
server.logger.Error("rehash", "couldn't listen on", newaddr, listenerErr.Error())
|
||||||
|
err = listenerErr
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
server.listeners[newaddr] = listener
|
||||||
logListener(newaddr, tlsConfig)
|
logListener(newaddr, tlsConfig)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1078,8 +1088,8 @@ func (server *Server) setupListeners(config *Config) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var usesStandardTLSPort bool
|
var usesStandardTLSPort bool
|
||||||
for addr := range config.TLSListeners() {
|
for addr := range tlsListeners {
|
||||||
if strings.Contains(addr, "6697") {
|
if strings.HasSuffix(addr, ":6697") {
|
||||||
usesStandardTLSPort = true
|
usesStandardTLSPort = true
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
@ -1087,6 +1097,8 @@ func (server *Server) setupListeners(config *Config) {
|
|||||||
if 0 < len(tlsListeners) && !usesStandardTLSPort {
|
if 0 < len(tlsListeners) && !usesStandardTLSPort {
|
||||||
server.logger.Warning("startup", "Port 6697 is the standard TLS port for IRC. You should (also) expose port 6697 as a TLS port to ensure clients can connect securely")
|
server.logger.Warning("startup", "Port 6697 is the standard TLS port for IRC. You should (also) expose port 6697 as a TLS port to ensure clients can connect securely")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// elistMatcher takes and matches ELIST conditions
|
// elistMatcher takes and matches ELIST conditions
|
||||||
|
Loading…
Reference in New Issue
Block a user