gorepost/gorepost.go

78 lines
2.0 KiB
Go
Raw Normal View History

package main
import (
"log"
"os"
"path"
2015-11-08 19:55:47 +00:00
"github.com/arachnist/gorepost/bot"
. "github.com/arachnist/gorepost/config"
"github.com/arachnist/gorepost/irc"
)
func main() {
var exit chan struct{}
context := make(map[string]string)
2015-11-09 23:13:30 +00:00
var networks []string
2015-11-08 21:00:33 +00:00
if len(os.Args) < 2 {
log.Fatalln("Usage:", os.Args[0], "<configuration directory>")
}
d, err := os.Stat(os.Args[1])
if err != nil {
log.Fatalln("Error reading configuration from", os.Args[1], "error:", err.Error())
}
if !d.IsDir() {
log.Fatalln("Not a directory:", os.Args[1])
}
C.BuildFileList = func(c map[string]string) []string {
var r []string
if c["Network"] != "" {
if c["Source"] != "" {
if c["Target"] != "" {
r = append(r, path.Join(os.Args[1], c["Network"], c["Source"], c["Target"]+".json"))
}
r = append(r, path.Join(os.Args[1], c["Network"], c["Source"]+".json"))
}
r = append(r, path.Join(os.Args[1], c["Network"]+".json"))
}
return append(r, path.Join(os.Args[1], "common.json"))
}
logfile, err := os.OpenFile(C.Lookup(context, "Logpath").(string), os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666)
if err != nil {
log.Fatalln("Error opening", C.Lookup(context, "Logpath").(string), "for writing, error:", err.Error())
}
log.SetOutput(logfile)
2015-11-09 23:13:30 +00:00
rawNetworks := C.Lookup(context, "Networks").([]interface{})
for _, n := range rawNetworks {
networks = append(networks, n.(string))
}
log.Println("Configured networks:", len(networks), networks)
connections := make([]irc.Connection, len(networks))
2015-11-09 23:13:30 +00:00
for i, _ := range connections {
var servers []string
context["Network"] = networks[i]
2015-11-09 23:13:30 +00:00
rawServers := C.Lookup(context, "Servers").([]interface{})
log.Println("Rawservers:", rawServers)
for _, n := range rawServers {
servers = append(servers, n.(string))
}
log.Println(context["Network"], "Configured servers", len(servers), servers)
connections[i].Setup(bot.Dispatcher, networks[i],
2015-11-09 23:13:30 +00:00
servers,
C.Lookup(context, "Nick").(string),
C.Lookup(context, "User").(string),
C.Lookup(context, "RealName").(string))
}
<-exit
}