112 lines
2.0 KiB
Go
112 lines
2.0 KiB
Go
// vi:ts=4:sts=4:sw=4:noet:tw=72
|
|
//
|
|
// flokatirc coffee module
|
|
//
|
|
// Copyright (c) 2016 Daniel Aberger <da@ixab.de>
|
|
|
|
package modules
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"sync"
|
|
"time"
|
|
|
|
"code.dnix.de/an/xlog"
|
|
|
|
"github.com/sorcix/irc"
|
|
"github.com/sorcix/irc/ctcp"
|
|
)
|
|
|
|
type Receivers struct {
|
|
names map[string]bool
|
|
running bool
|
|
mux sync.Mutex
|
|
}
|
|
|
|
var (
|
|
r Receivers
|
|
)
|
|
|
|
func init() {
|
|
MsgHandlers["coffee"] = coffeeHandleMessage
|
|
r.names = make(map[string]bool)
|
|
xlog.Info("Coffee module initialized")
|
|
}
|
|
|
|
func coffeeHandleMessage(m *irc.Message) {
|
|
tok := strings.Split(strings.Trim(m.Trailing, " "), " ")
|
|
if len(tok) < 1 {
|
|
return
|
|
}
|
|
switch strings.ToLower(tok[0]) {
|
|
case "!kaffee":
|
|
switch len(tok) {
|
|
case 1:
|
|
go r.addReceivers(nil)
|
|
default:
|
|
go r.addReceivers(tok[1:])
|
|
}
|
|
default:
|
|
}
|
|
}
|
|
|
|
func (r *Receivers) addReceivers(newNames []string) {
|
|
r.mux.Lock()
|
|
if r.running {
|
|
if newNames != nil {
|
|
r.addNames(newNames)
|
|
}
|
|
} else {
|
|
if newNames != nil {
|
|
r.addNames(newNames)
|
|
}
|
|
go r.makeCoffee()
|
|
}
|
|
r.mux.Unlock()
|
|
}
|
|
|
|
func (r *Receivers) makeCoffee() {
|
|
r.mux.Lock()
|
|
r.running = true
|
|
r.mux.Unlock()
|
|
printAction("setzt Kaffee auf.")
|
|
time.Sleep(time.Second * 30)
|
|
printAction("stellt eine frische Kanne Kaffee in den Raum.")
|
|
r.mux.Lock()
|
|
if len(r.names) != 0 {
|
|
var users string
|
|
var count int = 0
|
|
for i, _ := range r.names {
|
|
count++
|
|
users += i
|
|
if count < len(r.names)-1 {
|
|
users += ", "
|
|
} else if count == len(r.names)-1 {
|
|
users += " und "
|
|
}
|
|
}
|
|
printAction("gibt " + users + " einen frischen, richtig schwarzen, richtig leckeren Kaffee.")
|
|
}
|
|
r.mux.Unlock()
|
|
time.Sleep(10 * time.Second)
|
|
SayCh <- "*\nProst! (c)"
|
|
|
|
r.mux.Lock()
|
|
r.names = make(map[string]bool)
|
|
r.running = false
|
|
r.mux.Unlock()
|
|
}
|
|
|
|
func (r *Receivers) addNames(newNames []string) {
|
|
for _, v := range newNames {
|
|
r.names[strings.ToLower(v)] = true
|
|
}
|
|
}
|
|
|
|
func printAction(s string) {
|
|
msg := ctcp.Encode(ctcp.ACTION, fmt.Sprintf(s))
|
|
SayCh <- fmt.Sprintf("%s\n%s", "*", msg)
|
|
}
|
|
|