package irc import ( "strings" "fmt" "time" "strconv" ) func (irc *IRCConnection) AddCallback(eventcode string, callback func(*IRCEvent)) { eventcode = strings.ToUpper(eventcode) if _, ok := irc.events[eventcode]; ok { irc.events[eventcode] = append(irc.events[eventcode], callback) } else { irc.events[eventcode] = make([]func(*IRCEvent), 1) irc.events[eventcode][0] = callback } } func (irc *IRCConnection) ReplaceCallback(eventcode string, i int, callback func(*IRCEvent)) { eventcode = strings.ToUpper(eventcode) if event, ok := irc.events[eventcode]; ok { if i < len(event) { event[i] = callback return } fmt.Printf("Event found, but no callback found at index %d. Use AddCallback\n", i) return } fmt.Printf("Event not found. Use AddCallBack\n") } func (irc *IRCConnection) RunCallbacks(event *IRCEvent) { if event.Code == "PRIVMSG" && len(event.Message) > 0 && event.Message[0] == '\x01' { event.Code = "CTCP" //Unknown CTCP if i := strings.LastIndex(event.Message, "\x01"); i > -1 { event.Message = event.Message[1:i] } if event.Message == "VERSION" { event.Code = "CTCP_VERSION" } else if event.Message == "TIME" { event.Code = "CTCP_TIME" } else if event.Message[0:4] == "PING" { event.Code = "CTCP_PING" } else if event.Message == "USERINFO" { event.Code = "CTCP_USERINFO" } else if event.Message == "CLIENTINFO" { event.Code = "CTCP_CLIENTINFO" } } if callbacks, ok := irc.events[event.Code]; ok { if irc.VerboseCallbackHandler { fmt.Printf("%v (%v) >> %#v\n", event.Code, len(callbacks), event) } for _, callback := range callbacks { go callback(event) } } else if irc.VerboseCallbackHandler { fmt.Printf("%v (0) >> %#v\n", event.Code, event) } } func (irc *IRCConnection) setupCallbacks() { irc.events = make(map[string][]func(*IRCEvent)) //Handle ping events irc.AddCallback("PING", func(e *IRCEvent) { irc.SendRaw("PONG :" + e.Message) }) //Version handler irc.AddCallback("CTCP_VERSION", func(e *IRCEvent) { irc.SendRaw(fmt.Sprintf("NOTICE %s :\x01VERSION %s\x01", e.Nick, VERSION)) }) irc.AddCallback("CTCP_USERINFO", func(e *IRCEvent) { irc.SendRaw(fmt.Sprintf("NOTICE %s :\x01USERINFO %s\x01", e.Nick, irc.user)) }) irc.AddCallback("CTCP_CLIENTINFO", func(e *IRCEvent) { irc.SendRaw(fmt.Sprintf("NOTICE %s :\x01CLIENTINFO PING VERSION TIME USERINFO CLIENTINFO\x01", e.Nick)) }) irc.AddCallback("CTCP_TIME", func(e *IRCEvent) { ltime := time.LocalTime() irc.SendRaw(fmt.Sprintf("NOTICE %s :\x01TIME %s\x01", e.Nick, ltime.String())) }) irc.AddCallback("CTCP_PING", func(e *IRCEvent) { irc.SendRaw(fmt.Sprintf("NOTICE %s :\x01%s\x01", e.Nick, e.Message)) }) irc.AddCallback("437", func(e *IRCEvent) { irc.nickcurrent = irc.nickcurrent + "_" irc.SendRaw(fmt.Sprintf("NICK %s", irc.nickcurrent)) }) irc.AddCallback("433", func(e *IRCEvent) { if len(irc.nickcurrent) > 8 { irc.nickcurrent = "_" + irc.nickcurrent } else { irc.nickcurrent = irc.nickcurrent + "_" } irc.SendRaw(fmt.Sprintf("NICK %s", irc.nickcurrent)) }) irc.AddCallback("PONG", func(e *IRCEvent) { ns, _ := strconv.Atoi64(e.Message) fmt.Printf("Lag: %fs\n", float32((time.Nanoseconds()-ns))/1000/1000/1000) }) irc.AddCallback("NICK", func(e *IRCEvent) { if e.Nick == irc.nick { irc.nickcurrent = e.Arguments[0] } }) irc.AddCallback("001", func(e *IRCEvent) { irc.nickcurrent = e.Arguments[0] }) }