Подтвердить что ты не робот

Простой golang IRC-бот сохраняет тайм-аут

Я возился с golang, и мой первый код - простой IRC-бот со следующим кодом:

package main

import ("net"
        "log"
        "bufio"
        "fmt"
        "net/textproto"
      )
type Bot struct{
        server string
        port string
        nick string
        user string
        channel string
        pass string
        pread, pwrite chan string
        conn net.Conn
}

func NewBot() *Bot {
        return &Bot{server: "irc.freenode.net",
                    port: "6667",
                    nick: "subsaharan",
                    channel: "#rapidsms", 
                    pass: "",
                    conn: nil,
                    user: "blaze"}
}
func (bot *Bot) Connect() (conn net.Conn, err error){
  conn, err = net.Dial("tcp",bot.server + ":" + bot.port)
  if err != nil{
    log.Fatal("unable to connect to IRC server ", err)
  }
  bot.conn = conn
  log.Printf("Connected to IRC server %s (%s)\n", bot.server, bot.conn.RemoteAddr())
  return bot.conn, nil
}



func main(){
  ircbot := NewBot()
  conn, _ := ircbot.Connect()
  conn.Write([]byte("NICK " + ircbot.nick))
  conn.Write([]byte("JOIN " + ircbot.channel))
  defer conn.Close()

  reader := bufio.NewReader(conn)
  tp := textproto.NewReader( reader )
  for {
        line, err := tp.ReadLine()
        if err != nil {
            break // break loop on errors    
        }
        fmt.Printf("%s\n", line)
    }

}

Когда я запускаю этот код, я получаю следующий вывод на терминале:

2012/11/12 13:31:20 Connected to IRC server irc.freenode.net (193.219.128.49:6667)
:sendak.freenode.net NOTICE * :*** Looking up your hostname...
:sendak.freenode.net NOTICE * :*** Checking Ident
:sendak.freenode.net NOTICE * :*** Couldn't look up your hostname
:sendak.freenode.net NOTICE * :*** No Ident response
ERROR :Closing Link: 127.0.0.1 (Connection timed out)

Любая причина, по которой соединение не синхронизируется?

4b9b3361

Ответ 1

Все команды, отправленные на IRC-сервер, имеют максимум 255 512 байт и должны быть завершены возвратом каретки и переводом строки \r\n.

conn.Write([]byte("NICK " + ircbot.nick + "\r\n"))
conn.Write([]byte("JOIN " + ircbot.channel + "\r\n"))

Кроме того, freenode ожидает, что команда USER будет первой, что она увидит от вас.

conn.Write([]byte("USER "+ircbot.nick+" 8 * :" + ircbot.nick + "\r\n"))
conn.Write([]byte("NICK " + ircbot.nick + "\r\n"))
conn.Write([]byte("JOIN " + ircbot.channel + "\r\n"))

В качестве дополнительной заметки вы можете сделать свою жизнь немного легче, используя fmt.Fprintf для форматирования и отправки данных:

fmt.Fprintf(conn, "USER %s 8 * :%s\r\n", ircbot.nick, ircbot.nick)
fmt.Fprintf(conn, "NICK %s\r\n", ircbot.nick)
fmt.Fprintf(conn, "JOIN %s\r\n", ircbot.channel)

Первым параметром fmt.Fprintf должен быть любой тип, который удовлетворяет интерфейсу io.Writer. Реализации net.Conn все это делают. Таким образом, вы можете передать их в любую функцию, которая ожидает реализацию io.Writer (или io.Reader).

Ответ 2

Кроме того, иногда IRC-серверы отправляют сообщение "PING: cookie" (если, например, ваше соединение простаивает слишком долго). Ожидается, что вы ответите "PONG: cookie".