-
Notifications
You must be signed in to change notification settings - Fork 71
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use felixge/httpsnoop approach to preserve additional interfaces (#26)
* Add overhead benchmark * Use snoopwrap * Use opencensus method for status code tracking It's more efficient than using httpsnoop. * Do not build status code tracker for go1.7 * Add remove support for http.Pusher in go1.7 * Adjust travis version range Add up to go 1.11. * Correct build tags
- Loading branch information
1 parent
0965915
commit 77df8e8
Showing
5 changed files
with
409 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,6 +4,8 @@ go: | |
- 1.7.x | ||
- 1.8.x | ||
- 1.9.x | ||
- 1.10.x | ||
- 1.11.x | ||
- tip | ||
|
||
script: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
// +build go1.7,!go1.8 | ||
|
||
package nethttp | ||
|
||
import ( | ||
"io" | ||
"net/http" | ||
) | ||
|
||
type statusCodeTracker struct { | ||
http.ResponseWriter | ||
status int | ||
} | ||
|
||
func (w *statusCodeTracker) WriteHeader(status int) { | ||
w.status = status | ||
w.ResponseWriter.WriteHeader(status) | ||
} | ||
|
||
// wrappedResponseWriter returns a wrapped version of the original | ||
// ResponseWriter and only implements the same combination of additional | ||
// interfaces as the original. This implementation is based on | ||
// https://github.com/felixge/httpsnoop. | ||
func (w *statusCodeTracker) wrappedResponseWriter() http.ResponseWriter { | ||
var ( | ||
hj, i0 = w.ResponseWriter.(http.Hijacker) | ||
cn, i1 = w.ResponseWriter.(http.CloseNotifier) | ||
fl, i3 = w.ResponseWriter.(http.Flusher) | ||
rf, i4 = w.ResponseWriter.(io.ReaderFrom) | ||
) | ||
i2 := false | ||
|
||
switch { | ||
case !i0 && !i1 && !i2 && !i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
}{w} | ||
case !i0 && !i1 && !i2 && !i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
io.ReaderFrom | ||
}{w, rf} | ||
case !i0 && !i1 && !i2 && i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Flusher | ||
}{w, fl} | ||
case !i0 && !i1 && !i2 && i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Flusher | ||
io.ReaderFrom | ||
}{w, fl, rf} | ||
case !i0 && i1 && !i2 && !i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.CloseNotifier | ||
}{w, cn} | ||
case !i0 && i1 && !i2 && !i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.CloseNotifier | ||
io.ReaderFrom | ||
}{w, cn, rf} | ||
case !i0 && i1 && !i2 && i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.CloseNotifier | ||
http.Flusher | ||
}{w, cn, fl} | ||
case !i0 && i1 && !i2 && i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.CloseNotifier | ||
http.Flusher | ||
io.ReaderFrom | ||
}{w, cn, fl, rf} | ||
case i0 && !i1 && !i2 && !i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
}{w, hj} | ||
case i0 && !i1 && !i2 && !i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
io.ReaderFrom | ||
}{w, hj, rf} | ||
case i0 && !i1 && !i2 && i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.Flusher | ||
}{w, hj, fl} | ||
case i0 && !i1 && !i2 && i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.Flusher | ||
io.ReaderFrom | ||
}{w, hj, fl, rf} | ||
case i0 && i1 && !i2 && !i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.CloseNotifier | ||
}{w, hj, cn} | ||
case i0 && i1 && !i2 && !i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.CloseNotifier | ||
io.ReaderFrom | ||
}{w, hj, cn, rf} | ||
case i0 && i1 && !i2 && i3 && !i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.CloseNotifier | ||
http.Flusher | ||
}{w, hj, cn, fl} | ||
case i0 && i1 && !i2 && i3 && i4: | ||
return struct { | ||
http.ResponseWriter | ||
http.Hijacker | ||
http.CloseNotifier | ||
http.Flusher | ||
io.ReaderFrom | ||
}{w, hj, cn, fl, rf} | ||
default: | ||
return struct { | ||
http.ResponseWriter | ||
}{w} | ||
} | ||
} |
Oops, something went wrong.