X-Git-Url: http://www.git.cypherpunks.ru/?a=blobdiff_plain;f=daemon.go;h=30d458bd83a10b3a19c716a3081e8e88edb250b9;hb=60bd9cec0bea6457b64299e14de4c61c8e9082cf;hp=1f979ce6ea4f7c4dd295c5f4924b8ab477bdd845;hpb=41f96494948d1f9f1e0c3066099e0bd9ad0ee8dd;p=goircd.git diff --git a/daemon.go b/daemon.go index 1f979ce..30d458b 100644 --- a/daemon.go +++ b/daemon.go @@ -21,6 +21,7 @@ import ( "fmt" "io/ioutil" "log" + "net" "regexp" "sort" "strings" @@ -98,7 +99,13 @@ func (daemon *Daemon) SendWhois(client *Client, nicknames []string) { continue } found = true - client.ReplyNicknamed("311", c.nickname, c.username, c.conn.RemoteAddr().String(), "*", c.realname) + h := c.conn.RemoteAddr().String() + h, _, err := net.SplitHostPort(h) + if err != nil { + log.Printf("Can't parse RemoteAddr %q: %v", h, err) + h = "Unknown" + } + client.ReplyNicknamed("311", c.nickname, c.username, h, "*", c.realname) client.ReplyNicknamed("312", c.nickname, daemon.hostname, daemon.hostname) subscriptions := []string{} for _, room := range daemon.rooms { @@ -370,7 +377,7 @@ func (daemon *Daemon) Processor(events <-chan ClientEvent) { target := strings.ToLower(cols[0]) for c := range daemon.clients { if c.nickname == target { - msg = fmt.Sprintf(":%s %s %s :%s", client, command, c.nickname, cols[1]) + msg = fmt.Sprintf(":%s %s %s %s", client, command, c.nickname, cols[1]) c.Msg(msg) break }