dispatch/server/irc.go

89 lines
1.9 KiB
Go
Raw Normal View History

2016-01-04 18:26:32 +00:00
package server
import (
2016-01-11 20:04:57 +00:00
"crypto/tls"
"encoding/hex"
"fmt"
2020-06-16 01:04:27 +00:00
"log"
"net"
"strings"
2016-01-11 20:04:57 +00:00
"github.com/khlieng/dispatch/pkg/irc"
"github.com/khlieng/dispatch/storage"
2020-06-16 01:04:27 +00:00
"golang.org/x/net/proxy"
2016-01-04 18:26:32 +00:00
)
func createNickInUseHandler(i *irc.Client, state *State) func(string) string {
return func(nick string) string {
newNick := nick + "_"
if newNick == i.GetNick() {
state.sendJSON("nick_fail", NickFail{
2020-06-15 08:58:51 +00:00
Network: i.Host(),
})
}
state.sendJSON("error", IRCError{
2020-06-15 08:58:51 +00:00
Network: i.Host(),
Message: fmt.Sprintf("Nickname %s is unavailable, trying %s instead", nick, newNick),
})
return newNick
}
}
2020-06-15 08:58:51 +00:00
func connectIRC(network *storage.Network, state *State, srcIP []byte) *irc.Client {
2018-12-11 09:51:20 +00:00
cfg := state.srv.Config()
2020-06-15 23:22:23 +00:00
2020-06-15 08:58:51 +00:00
ircCfg := network.IRCConfig()
2020-06-15 23:22:23 +00:00
ircCfg.AutoCTCP = cfg.AutoCTCP
2018-12-11 09:51:20 +00:00
2020-06-15 08:58:51 +00:00
if ircCfg.TLS {
2020-05-23 07:42:20 +00:00
ircCfg.TLSConfig = &tls.Config{
InsecureSkipVerify: !cfg.VerifyCertificates,
}
if cert := state.user.GetCertificate(); cert != nil {
ircCfg.TLSConfig.Certificates = []tls.Certificate{*cert}
}
}
2020-05-23 07:42:20 +00:00
if cfg.HexIP {
ircCfg.Username = hex.EncodeToString(srcIP)
2020-05-23 06:05:37 +00:00
}
2020-06-15 08:58:51 +00:00
if ircCfg.ServerPassword == "" &&
2020-05-23 07:42:20 +00:00
cfg.Defaults.ServerPassword != "" &&
2020-06-15 08:58:51 +00:00
ircCfg.Host == cfg.Defaults.Host {
2020-06-04 00:28:41 +00:00
ircCfg.ServerPassword = cfg.Defaults.ServerPassword
}
2020-06-16 01:04:27 +00:00
if cfg.Proxy.Enabled && strings.ToLower(cfg.Proxy.Protocol) == "socks5" {
addr := net.JoinHostPort(cfg.Proxy.Host, cfg.Proxy.Port)
var auth *proxy.Auth
if cfg.Proxy.Username != "" {
auth = &proxy.Auth{
User: cfg.Proxy.Username,
Password: cfg.Proxy.Password,
}
}
dialer, err := proxy.SOCKS5("tcp", addr, auth, irc.DefaultDialer)
if err != nil {
log.Println(err)
} else {
ircCfg.Dialer = dialer
}
}
2020-06-15 08:58:51 +00:00
i := irc.NewClient(ircCfg)
2020-05-23 07:42:20 +00:00
i.Config.HandleNickInUse = createNickInUseHandler(i, state)
2020-06-15 08:58:51 +00:00
state.setNetwork(network.Host, state.user.NewNetwork(network, i))
2020-05-23 07:42:20 +00:00
i.Connect()
go newIRCHandler(i, state).run()
return i
}