2018-08-22 18:47:00 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"fmt"
|
2018-08-23 02:08:53 +02:00
|
|
|
"net"
|
2018-08-22 18:47:00 +02:00
|
|
|
"net/http"
|
2018-08-22 23:51:59 +02:00
|
|
|
"os"
|
2018-11-10 16:32:12 +01:00
|
|
|
"os/signal"
|
2018-08-22 18:47:00 +02:00
|
|
|
|
2018-08-23 01:21:53 +02:00
|
|
|
"git.lattuga.net/boyska/circolog"
|
2018-08-22 18:47:00 +02:00
|
|
|
syslog "gopkg.in/mcuadros/go-syslog.v2"
|
|
|
|
)
|
|
|
|
|
2018-11-10 16:32:12 +01:00
|
|
|
func cleanSocket(socket string) {
|
|
|
|
if err := os.Remove(socket); err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, socket, ":", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-22 18:47:00 +02:00
|
|
|
func main() {
|
2018-08-22 23:51:59 +02:00
|
|
|
var err error
|
2018-08-22 18:47:00 +02:00
|
|
|
syslogSocketPath := flag.String("syslogd-socket", "", "The socket to listen to syslog addresses")
|
|
|
|
// dumpSocketPath := flag.String("dump-socket", "/run/buffer.sock", "The socket that user will connect to in order to receive logs")
|
|
|
|
bufsize := flag.Int("buffer-size", 1000, "Number of messages to keep")
|
2018-08-22 22:59:32 +02:00
|
|
|
syslogAddr := flag.String("syslog-addr", "127.0.0.1:9514", "Address:port where to listen for syslog messages")
|
|
|
|
queryAddr := flag.String("query-addr", "127.0.0.1:9080", "Address:port where to bind the query service")
|
2018-08-23 02:08:53 +02:00
|
|
|
querySocket := flag.String("query-socket", "", "Path to a unix domain socket for the HTTP server; recommended for security reasons!")
|
2018-08-22 18:47:00 +02:00
|
|
|
flag.Parse()
|
|
|
|
|
2018-11-10 16:32:12 +01:00
|
|
|
interrupt := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(interrupt, os.Interrupt)
|
|
|
|
|
2018-08-23 01:21:53 +02:00
|
|
|
hub := circolog.NewHub(*bufsize)
|
2018-08-23 00:56:27 +02:00
|
|
|
handler := syslog.NewChannelHandler(hub.LogMessages)
|
2018-08-22 18:47:00 +02:00
|
|
|
|
|
|
|
server := syslog.NewServer()
|
|
|
|
server.SetFormat(syslog.RFC5424)
|
|
|
|
server.SetHandler(handler)
|
|
|
|
if *syslogSocketPath != "" {
|
2018-08-22 23:51:59 +02:00
|
|
|
if err = server.ListenUnixgram(*syslogSocketPath); err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, "argh", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2018-11-10 16:32:12 +01:00
|
|
|
defer cleanSocket(*syslogSocketPath)
|
2018-08-22 21:05:37 +02:00
|
|
|
fmt.Printf("Binding socket `%s` [syslog]\n", *syslogSocketPath)
|
2018-08-22 20:56:43 +02:00
|
|
|
} else {
|
2018-08-22 22:59:32 +02:00
|
|
|
fmt.Printf("Binding address `%s` [syslog]\n", *syslogAddr)
|
2018-08-22 23:51:59 +02:00
|
|
|
if err = server.ListenUDP(*syslogAddr); err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, "argh", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2018-08-22 18:47:00 +02:00
|
|
|
}
|
2018-08-22 23:51:59 +02:00
|
|
|
if err = server.Boot(); err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, "argh", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
go hub.Run()
|
2018-08-22 18:47:00 +02:00
|
|
|
|
2018-08-23 12:25:07 +02:00
|
|
|
setupHTTP(hub)
|
2018-08-23 02:08:53 +02:00
|
|
|
if *querySocket != "" {
|
|
|
|
fmt.Printf("Binding address `%s` [http]\n", *querySocket)
|
|
|
|
unixListener, err := net.Listen("unix", *querySocket)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Fprintln(os.Stderr, "Error binding HTTP unix domain socket", err)
|
|
|
|
}
|
2018-11-10 16:32:12 +01:00
|
|
|
go http.Serve(unixListener, nil)
|
2018-08-23 02:08:53 +02:00
|
|
|
} else {
|
|
|
|
fmt.Printf("Binding address `%s` [http]\n", *queryAddr)
|
2018-11-10 16:32:12 +01:00
|
|
|
go http.ListenAndServe(*queryAddr, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-interrupt:
|
|
|
|
server.Kill()
|
|
|
|
//server.Wait()
|
|
|
|
if *syslogSocketPath != "" {
|
|
|
|
|
|
|
|
}
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
}
|
2018-08-23 02:08:53 +02:00
|
|
|
}
|
2018-08-22 18:47:00 +02:00
|
|
|
}
|