Trying out a version that uses golog
as well as touching up the Makefiles to set SHELL
This commit is contained in:
52
logstash/sirgoldenvoncrispywhite/main.go
Normal file
52
logstash/sirgoldenvoncrispywhite/main.go
Normal file
@@ -0,0 +1,52 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"log"
|
||||
"net/http"
|
||||
|
||||
"github.com/modcloth-labs/golog"
|
||||
)
|
||||
|
||||
func main() {
|
||||
server, err := newCrispyServer()
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
http.Handle("/", server)
|
||||
log.Printf("Serving on :9764 with %+v\n", server)
|
||||
log.Fatal(http.ListenAndServe(":9764", nil))
|
||||
}
|
||||
|
||||
type crispyServer struct {
|
||||
logstasher *golog.Logger
|
||||
}
|
||||
|
||||
func newCrispyServer() (*crispyServer, error) {
|
||||
logstasher, err := newLogstashLogger()
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &crispyServer{logstasher: logstasher}, nil
|
||||
}
|
||||
|
||||
func (me *crispyServer) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||
j, err := json.Marshal(r)
|
||||
if err == nil {
|
||||
if me.logstasher != nil {
|
||||
me.logstasher.Infof("%s", string(j))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func newLogstashLogger() (*golog.Logger, error) {
|
||||
logger := golog.NewLogger("")
|
||||
tcpProcessor, err := golog.NewTcpProcessorAt(":55784", golog.LOG_DEBUG)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
logger.AddProcessor("tcp", tcpProcessor)
|
||||
return logger, nil
|
||||
}
|
Reference in New Issue
Block a user