diff options
| author | Mikhail Osipov <mike.osipov@gmail.com> | 2020-03-25 15:50:02 +0300 |
|---|---|---|
| committer | Mikhail Osipov <mike.osipov@gmail.com> | 2020-03-25 16:23:38 +0300 |
| commit | 5c846ba3a0e5e323b61339572e7a4f917c1d79d4 (patch) | |
| tree | 42c6dd8efa35c0c199fda897ab9cc88cb57cd78b /pkg/server | |
| parent | 797fe0c5db5868774c81cb2ee9d6a3811caf2c60 (diff) | |
add look http hook
Diffstat (limited to 'pkg/server')
| -rw-r--r-- | pkg/server/hook/look-http.go | 58 | ||||
| -rw-r--r-- | pkg/server/tunnel.go | 6 |
2 files changed, 61 insertions, 3 deletions
diff --git a/pkg/server/hook/look-http.go b/pkg/server/hook/look-http.go new file mode 100644 index 0000000..d467563 --- /dev/null +++ b/pkg/server/hook/look-http.go @@ -0,0 +1,58 @@ +package hook + +import ( + "bufio" + "strings" + "tunnel/pkg/server/env" + "tunnel/pkg/server/opts" + "tunnel/pkg/server/queue" +) + +type lookHttpHook struct{} + +type lookHttp struct { + env env.Env +} + +func (look *lookHttp) Send(rq, wq queue.Q) error { + q := queue.New() + s := bufio.NewScanner(q.Reader()) + + go func() { + for b := range rq { + q <- b + wq <- b + } + + close(q) + }() + + if s.Scan() { + if w := strings.Split(s.Text(), " "); len(w) > 1 { + switch m := strings.ToUpper(w[0]); m { + case "CONNECT", "GET", "POST": + look.env.Set("look.info", m+" "+w[1]) + } + } + } + + q.Dry() + + return nil +} + +func (look *lookHttp) Recv(rq, wq queue.Q) error { + return queue.Copy(rq, wq) +} + +func (lookHttpHook) Open(env env.Env) (interface{}, error) { + return &lookHttp{env: env}, nil +} + +func newLookHttpHook(opts opts.Opts, env env.Env) (hook, error) { + return lookHttpHook{}, nil +} + +func init() { + register("look-http", newLookHttpHook) +} diff --git a/pkg/server/tunnel.go b/pkg/server/tunnel.go index 1bb21b4..79734b9 100644 --- a/pkg/server/tunnel.go +++ b/pkg/server/tunnel.go @@ -203,8 +203,8 @@ func (s *stream) info() string { d = s.until.Sub(s.since).Milliseconds() } - return fmt.Sprintf("%.3fs %d/%d -> %d/%d", - float64(d)/1000.0, + return fmt.Sprintf("%.3fs [%s] %d/%d -> %d/%d", + float64(d)/1000.0, s.env.Get("look.info"), s.m.in.tx, s.m.in.rx, s.m.out.rx, @@ -501,7 +501,7 @@ func showRecent(r *request) { foreachTunnel(r.c.s.tunnels, func(t *tunnel) { t.mu.Lock() streams = append(streams, t.recent...) - defer t.mu.Unlock() + t.mu.Unlock() }) sort.SliceStable(streams, func(i, j int) bool { |
