port range checking added
This commit is contained in:
parent
48983c2abf
commit
6e0280dae6
12
irc.go
12
irc.go
@ -26,6 +26,7 @@ import (
|
||||
"log"
|
||||
"net"
|
||||
"os"
|
||||
"strconv"
|
||||
"strings"
|
||||
"time"
|
||||
)
|
||||
@ -341,6 +342,15 @@ func (irc *Connection) Connect(server string) error {
|
||||
if (len(irc.server) - 1) == strings.Index(irc.server, ":") {
|
||||
return errors.New("port missing")
|
||||
}
|
||||
// check for valid range
|
||||
ports := strings.Split(irc.server, ":")[1]
|
||||
port, err := strconv.Atoi(ports)
|
||||
if nil != err {
|
||||
return errors.New("extracting port failed")
|
||||
}
|
||||
if !((port >= 0) && (port <= 65535)) {
|
||||
return errors.New("port number outside valid range")
|
||||
}
|
||||
if nil == irc.Log {
|
||||
return errors.New("'Log' points to nil")
|
||||
}
|
||||
@ -351,7 +361,7 @@ func (irc *Connection) Connect(server string) error {
|
||||
return errors.New("empty 'user'")
|
||||
}
|
||||
|
||||
var err error
|
||||
// var err error
|
||||
if irc.UseTLS {
|
||||
if irc.netsock, err = net.DialTimeout("tcp", irc.server, irc.Timeout); err == nil {
|
||||
irc.socket = tls.Client(irc.netsock, irc.TLSConfig)
|
||||
|
18
irc_test.go
18
irc_test.go
@ -12,6 +12,7 @@ func TestConnection(t *testing.T) {
|
||||
irccon.Debug = true
|
||||
err := irccon.Connect("irc.freenode.net:6667")
|
||||
if err != nil {
|
||||
t.Log(err.Error())
|
||||
t.Fatal("Can't connect to freenode.")
|
||||
}
|
||||
irccon.AddCallback("001", func(e *Event) { irccon.Join("#go-eventirc") })
|
||||
@ -36,6 +37,7 @@ func TestConnectionSSL(t *testing.T) {
|
||||
irccon.UseTLS = true
|
||||
err := irccon.Connect("irc.freenode.net:7000")
|
||||
if err != nil {
|
||||
t.Log(err.Error())
|
||||
t.Fatal("Can't connect to freenode.")
|
||||
}
|
||||
irccon.AddCallback("001", func(e *Event) { irccon.Join("#go-eventirc") })
|
||||
@ -81,6 +83,22 @@ func TestConnectionMissingPort(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func TestConnectionNegativePort(t *testing.T) {
|
||||
irccon := IRC("go-eventirc", "go-eventirc")
|
||||
err := irccon.Connect("chat.freenode.net:-1")
|
||||
if err == nil {
|
||||
t.Fatal("negative port number not detected")
|
||||
}
|
||||
}
|
||||
|
||||
func TestConnectionTooLargePort(t *testing.T) {
|
||||
irccon := IRC("go-eventirc", "go-eventirc")
|
||||
err := irccon.Connect("chat.freenode.net:65536")
|
||||
if err == nil {
|
||||
t.Fatal("too large port number not detected")
|
||||
}
|
||||
}
|
||||
|
||||
func TestConnectionMissingLog(t *testing.T) {
|
||||
irccon := IRC("go-eventirc", "go-eventirc")
|
||||
irccon.Log = nil
|
||||
|
Loading…
Reference in New Issue
Block a user