2015-10-15 19:04:24 +00:00
|
|
|
package main
|
2015-10-15 14:50:32 +00:00
|
|
|
|
|
|
|
import (
|
2015-10-19 23:54:07 +00:00
|
|
|
"log"
|
|
|
|
"os"
|
2015-11-10 20:00:40 +00:00
|
|
|
"path"
|
2015-10-15 14:50:32 +00:00
|
|
|
|
2015-11-08 19:55:47 +00:00
|
|
|
"github.com/arachnist/gorepost/bot"
|
2015-11-09 13:32:26 +00:00
|
|
|
. "github.com/arachnist/gorepost/config"
|
2015-10-19 23:56:34 +00:00
|
|
|
"github.com/arachnist/gorepost/irc"
|
2015-10-15 14:50:32 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2015-10-20 00:59:05 +00:00
|
|
|
var exit chan struct{}
|
2015-11-10 20:00:40 +00:00
|
|
|
context := make(map[string]string)
|
2015-11-08 21:00:33 +00:00
|
|
|
|
2015-11-09 00:05:06 +00:00
|
|
|
if len(os.Args) < 2 {
|
2015-11-09 13:32:26 +00:00
|
|
|
log.Fatalln("Usage:", os.Args[0], "<configuration directory>")
|
2015-11-09 00:05:06 +00:00
|
|
|
}
|
2015-11-09 13:32:26 +00:00
|
|
|
|
|
|
|
d, err := os.Stat(os.Args[1])
|
2015-10-19 23:54:07 +00:00
|
|
|
if err != nil {
|
2015-11-09 00:05:06 +00:00
|
|
|
log.Fatalln("Error reading configuration from", os.Args[1], "error:", err.Error())
|
2015-10-19 23:54:07 +00:00
|
|
|
}
|
2015-11-09 13:32:26 +00:00
|
|
|
if !d.IsDir() {
|
|
|
|
log.Fatalln("Not a directory:", os.Args[1])
|
|
|
|
}
|
2015-10-15 19:04:24 +00:00
|
|
|
|
2015-11-10 20:00:40 +00:00
|
|
|
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"))
|
|
|
|
}
|
2015-11-09 13:32:26 +00:00
|
|
|
|
2015-11-10 20:57:31 +00:00
|
|
|
logfile, err := os.OpenFile(C.Lookup(context, "Logpath").(string), os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644)
|
2015-10-19 23:54:07 +00:00
|
|
|
if err != nil {
|
2015-11-09 13:32:26 +00:00
|
|
|
log.Fatalln("Error opening", C.Lookup(context, "Logpath").(string), "for writing, error:", err.Error())
|
2015-10-19 23:54:07 +00:00
|
|
|
}
|
|
|
|
log.SetOutput(logfile)
|
2015-10-19 08:37:08 +00:00
|
|
|
|
2015-11-10 20:57:31 +00:00
|
|
|
networks := C.Lookup(context, "Networks").([]interface{})
|
2015-11-09 23:13:30 +00:00
|
|
|
|
|
|
|
log.Println("Configured networks:", len(networks), networks)
|
|
|
|
|
2015-11-09 13:32:26 +00:00
|
|
|
connections := make([]irc.Connection, len(networks))
|
2015-11-10 20:57:31 +00:00
|
|
|
for i := range connections {
|
|
|
|
log.Println("Setting up", networks[i].(string), "connection")
|
|
|
|
connections[i].Setup(bot.Dispatcher, networks[i].(string))
|
2015-10-20 00:59:05 +00:00
|
|
|
}
|
|
|
|
<-exit
|
2015-10-15 14:50:32 +00:00
|
|
|
}
|