2012-04-07 11:44:59 -07:00
|
|
|
package irc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
2014-02-08 22:06:10 -08:00
|
|
|
"io"
|
2013-05-11 14:43:06 -07:00
|
|
|
"log"
|
2012-04-07 11:44:59 -07:00
|
|
|
"net"
|
2012-12-08 22:54:58 -08:00
|
|
|
"strings"
|
2012-04-07 11:44:59 -07:00
|
|
|
)
|
|
|
|
|
|
|
|
// Adapt `net.Conn` to a `chan string`.
|
2012-04-17 18:16:57 -07:00
|
|
|
func StringReadChan(conn net.Conn) <-chan string {
|
2012-04-07 11:44:59 -07:00
|
|
|
ch := make(chan string)
|
2012-04-07 23:32:08 -07:00
|
|
|
reader := bufio.NewReader(conn)
|
2012-04-07 11:44:59 -07:00
|
|
|
go func() {
|
2014-02-08 17:10:04 -08:00
|
|
|
defer close(ch)
|
2012-04-07 11:44:59 -07:00
|
|
|
for {
|
2014-02-08 22:06:10 -08:00
|
|
|
line, err := reader.ReadString('\n')
|
2012-04-07 11:44:59 -07:00
|
|
|
if err != nil {
|
2014-02-08 22:06:10 -08:00
|
|
|
if err != io.EOF {
|
|
|
|
log.Printf("%s → %s error: %s", conn.RemoteAddr(), conn.LocalAddr(), err)
|
|
|
|
}
|
2012-04-07 11:44:59 -07:00
|
|
|
break
|
|
|
|
}
|
2013-05-11 14:43:06 -07:00
|
|
|
if DEBUG_NET {
|
2014-02-08 17:43:59 -08:00
|
|
|
log.Printf("%s → %s %s", conn.RemoteAddr(), conn.LocalAddr(), line)
|
2013-05-11 14:43:06 -07:00
|
|
|
}
|
2014-02-08 22:06:10 -08:00
|
|
|
|
|
|
|
ch <- strings.TrimSpace(line)
|
2012-04-07 11:44:59 -07:00
|
|
|
}
|
|
|
|
}()
|
2012-04-07 23:32:08 -07:00
|
|
|
return ch
|
|
|
|
}
|
2012-04-07 11:44:59 -07:00
|
|
|
|
2014-02-08 22:06:10 -08:00
|
|
|
func maybeLogWriteError(conn net.Conn, err error) bool {
|
|
|
|
if err != nil {
|
|
|
|
if err != io.EOF {
|
|
|
|
log.Printf("%s ← %s error: %s", conn.RemoteAddr(), conn.LocalAddr(), err)
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2012-04-17 18:16:57 -07:00
|
|
|
func StringWriteChan(conn net.Conn) chan<- string {
|
2012-04-07 23:32:08 -07:00
|
|
|
ch := make(chan string)
|
|
|
|
writer := bufio.NewWriter(conn)
|
2012-04-07 11:44:59 -07:00
|
|
|
go func() {
|
2014-02-08 17:10:04 -08:00
|
|
|
defer close(ch)
|
2012-04-07 11:44:59 -07:00
|
|
|
for str := range ch {
|
2013-05-11 14:43:06 -07:00
|
|
|
if DEBUG_NET {
|
2014-02-08 17:43:59 -08:00
|
|
|
log.Printf("%s ← %s %s", conn.RemoteAddr(), conn.LocalAddr(), str)
|
2013-05-11 14:43:06 -07:00
|
|
|
}
|
2014-02-08 22:06:10 -08:00
|
|
|
if _, err := writer.WriteString(str); maybeLogWriteError(conn, err) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if _, err := writer.WriteString(CRLF); maybeLogWriteError(conn, err) {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if err := writer.Flush(); maybeLogWriteError(conn, err) {
|
2012-04-07 11:44:59 -07:00
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
return ch
|
|
|
|
}
|
2012-12-08 22:54:58 -08:00
|
|
|
|
|
|
|
func LookupHostname(addr net.Addr) string {
|
|
|
|
addrStr := addr.String()
|
|
|
|
ipaddr, _, err := net.SplitHostPort(addrStr)
|
|
|
|
if err != nil {
|
|
|
|
return addrStr
|
|
|
|
}
|
2014-02-09 15:14:53 -08:00
|
|
|
switch ipaddr {
|
|
|
|
case "127.0.0.1", "::1":
|
|
|
|
return "localhost"
|
|
|
|
}
|
2014-02-04 19:28:24 -08:00
|
|
|
names, err := net.LookupHost(ipaddr)
|
2012-12-08 22:54:58 -08:00
|
|
|
if err != nil {
|
|
|
|
return ipaddr
|
|
|
|
}
|
|
|
|
return names[0]
|
|
|
|
}
|