Fix bugs and refactor response collector out into its own file TODO write tests for everything
This commit is contained in:
parent
8345b868b7
commit
c341321145
48
cache.go
48
cache.go
|
@ -4,50 +4,6 @@ import (
|
||||||
"net/http"
|
"net/http"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Response struct {
|
|
||||||
Code int
|
|
||||||
Headers map[string][]string
|
|
||||||
Body []byte
|
|
||||||
}
|
|
||||||
|
|
||||||
func (r Response) WriteResponse(rw http.ResponseWriter) {
|
|
||||||
for k, vs := range r.Headers {
|
|
||||||
for _, v := range vs {
|
|
||||||
rw.Header().Add(k, v)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
rw.WriteHeader(r.Code)
|
|
||||||
rw.Write(r.Body)
|
|
||||||
}
|
|
||||||
|
|
||||||
// implements ResponseWriter to collect HTTP responses
|
|
||||||
type ResponseCollector struct {
|
|
||||||
Response
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewResponseCollector() *ResponseCollector {
|
|
||||||
return &ResponseCollector{
|
|
||||||
Response{Code: 200, Headers: make(map[string][]string)},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (rc *ResponseCollector) Header() http.Header {
|
|
||||||
return rc.Headers
|
|
||||||
}
|
|
||||||
|
|
||||||
func (rc *ResponseCollector) Write(bs []byte) (int, error) {
|
|
||||||
rc.Body = append(rc.Body, bs...)
|
|
||||||
return len(bs), nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (rc *ResponseCollector) WriteHeader(code int) {
|
|
||||||
rc.Code = code
|
|
||||||
}
|
|
||||||
|
|
||||||
func (rc *ResponseCollector) CollectResponse() Response {
|
|
||||||
return rc.Response
|
|
||||||
}
|
|
||||||
|
|
||||||
type cacheEntry struct {
|
type cacheEntry struct {
|
||||||
r Response
|
r Response
|
||||||
}
|
}
|
||||||
|
@ -66,10 +22,10 @@ func Cache(h http.Handler) http.Handler {
|
||||||
if exists {
|
if exists {
|
||||||
entry.r.WriteResponse(rw)
|
entry.r.WriteResponse(rw)
|
||||||
} else {
|
} else {
|
||||||
rc := NewResponseCollector()
|
rc := ResponseCollector{}
|
||||||
// copy request in case they modify it
|
// copy request in case they modify it
|
||||||
req := *r
|
req := *r
|
||||||
h.ServeHTTP(rc, &req)
|
h.ServeHTTP(&rc, &req)
|
||||||
resp := rc.CollectResponse()
|
resp := rc.CollectResponse()
|
||||||
if resp.Code == 200 {
|
if resp.Code == 200 {
|
||||||
c[r.URL.String()] = cacheEntry{resp}
|
c[r.URL.String()] = cacheEntry{resp}
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Response struct {
|
||||||
|
Code int
|
||||||
|
Headers map[string][]string
|
||||||
|
Body []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r Response) WriteResponse(rw http.ResponseWriter) {
|
||||||
|
for k, vs := range r.Headers {
|
||||||
|
for _, v := range vs {
|
||||||
|
rw.Header().Add(k, v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rw.WriteHeader(r.Code)
|
||||||
|
rw.Write(r.Body)
|
||||||
|
}
|
||||||
|
|
||||||
|
// implements ResponseWriter to collect HTTP responses
|
||||||
|
type ResponseCollector struct {
|
||||||
|
Response
|
||||||
|
}
|
||||||
|
|
||||||
|
func (rc *ResponseCollector) Header() http.Header {
|
||||||
|
if rc.Headers == nil {
|
||||||
|
rc.Headers = make(map[string][]string)
|
||||||
|
}
|
||||||
|
return rc.Headers
|
||||||
|
}
|
||||||
|
|
||||||
|
func (rc *ResponseCollector) Write(bs []byte) (int, error) {
|
||||||
|
if rc.Code == 0 {
|
||||||
|
rc.Code = 200
|
||||||
|
}
|
||||||
|
rc.Body = append(rc.Body, bs...)
|
||||||
|
return len(bs), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (rc *ResponseCollector) WriteHeader(code int) {
|
||||||
|
rc.Code = code
|
||||||
|
}
|
||||||
|
|
||||||
|
func (rc *ResponseCollector) CollectResponse() Response {
|
||||||
|
return rc.Response
|
||||||
|
}
|
|
@ -12,9 +12,9 @@ import (
|
||||||
|
|
||||||
func Resize(maxWidth uint, h http.Handler) http.Handler {
|
func Resize(maxWidth uint, h http.Handler) http.Handler {
|
||||||
return http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) {
|
return http.HandlerFunc(func(rw http.ResponseWriter, r *http.Request) {
|
||||||
rc := NewResponseCollector()
|
rc := ResponseCollector{}
|
||||||
req := *r
|
req := *r
|
||||||
h.ServeHTTP(rc, &req)
|
h.ServeHTTP(&rc, &req)
|
||||||
imageResp := rc.CollectResponse()
|
imageResp := rc.CollectResponse()
|
||||||
|
|
||||||
if imageResp.Code != 200 {
|
if imageResp.Code != 200 {
|
||||||
|
|
Loading…
Reference in New Issue