aboutsummaryrefslogtreecommitdiff
path: root/vendor/github.com/Xe/ln/example/http.go
blob: 7fb98a39f0026d4b1640841c8ff57c9c9f4037c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// +build ignore

package main

import (
	"context"
	"flag"
	"net/http"
	"time"

	"github.com/Xe/ln"
	"github.com/Xe/ln/ex"
	"github.com/facebookgo/flagenv"
	"golang.org/x/net/trace"
)

var (
	port          = flag.String("port", "2145", "http port to listen on")
	tracingFamily = flag.String("trace-family", "ln example", "tracing family to use for x/net/trace")
)

func main() {
	flagenv.Parse()
	flag.Parse()

	ln.DefaultLogger.Filters = append(ln.DefaultLogger.Filters, ex.NewGoTraceLogger())

	http.HandleFunc("/", handleIndex)
	http.ListenAndServe(":"+*port, middlewareSpan(ex.HTTPLog(http.DefaultServeMux)))
}

func middlewareSpan(next http.Handler) http.Handler {
	return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
		sp := trace.New(*tracingFamily, "HTTP request")
		defer sp.Finish()
		ctx, cancel := context.WithTimeout(r.Context(), 30*time.Second)
		defer cancel()

		ctx = trace.NewContext(ctx, sp)

		next.ServeHTTP(w, r.WithContext(ctx))
	})
}

func handleIndex(w http.ResponseWriter, r *http.Request) {
	ctx := r.Context()

	ln.Log(ctx, ln.Action("index"), ln.F{"there_is": "no_danger"})

	http.Error(w, "There is no danger citizen", http.StatusOK)
}