box-o-sand/logstash/crispy/main.go

55 lines
983 B
Go
Raw Normal View History

package main
import (
"encoding/json"
"fmt"
"log"
"net"
"net/http"
)
func main() {
server := newCrispyServer()
http.Handle("/", server)
2014-09-20 14:39:22 +00:00
log.Printf("Serving on :9799 with %+v\n", server)
log.Fatal(http.ListenAndServe(":9799", nil))
}
type crispyServer struct {
logstasher *log.Logger
}
func newCrispyServer() *crispyServer {
return &crispyServer{
logstasher: newLogstashLogger(),
}
}
func (me *crispyServer) ServeHTTP(w http.ResponseWriter, r *http.Request) {
2014-09-20 14:39:22 +00:00
if r.URL.Path == "/DIE" && r.Method == "POST" {
me.logstasher.Fatal("OH GOSH")
}
j, err := json.Marshal(r)
if err == nil {
me.logstasher.Println(string(j))
}
}
func newLogstashLogger() *log.Logger {
return log.New(&logstashWriter{}, "", 0)
}
type logstashWriter struct{}
func (me *logstashWriter) Write(b []byte) (int, error) {
conn, err := net.Dial("tcp", ":55784")
if err == nil {
defer conn.Close()
fmt.Fprintf(conn, string(b))
} else {
fmt.Printf(string(b))
}
return 0, nil
}