diff --git a/main.go b/main.go index 79a8d2a..5861845 100644 --- a/main.go +++ b/main.go @@ -14,16 +14,19 @@ import ( "net/http" "net/http/httputil" "net/url" + "unicode/utf8" ) var proxyTarget string var listen string +var printResponse bool func main() { log.SetFlags(0) flag.StringVar(&proxyTarget, "proxy", "https://app.fossa.com", "The host to which all requests should be proxied.") flag.StringVar(&listen, "listen", ":3000", "The local address on which to listen.") + flag.BoolVar(&printResponse, "response", false, "Prints the response from the remote endpoint if enabled and if the response is text.") flag.Parse() proxyUrl, err := url.Parse(proxyTarget) @@ -67,12 +70,40 @@ func main() { // Replace the body in the request with a new reader that just reads from the body // that was previously buffered at the start of this function, and perform the reverse proxy. r.Body = ioutil.NopCloser(bytes.NewBuffer(body)) - proxy.ServeHTTP(w, r) + + if printResponse { + rr := responseRecorder{w} + proxy.ServeHTTP(rr, r) + } else { + proxy.ServeHTTP(w, r) + } }) http.ListenAndServe(listen, nil) } +type responseRecorder struct { + w http.ResponseWriter +} + +func (rr responseRecorder) Header() http.Header { + return rr.w.Header() +} + +func (rr responseRecorder) Write(content []byte) (int, error) { + if !utf8.Valid(content) { + log.Printf("\n") + } else { + log.Printf("%s\n", content) + } + return rr.w.Write(content) +} + +func (rr responseRecorder) WriteHeader(status int) { + log.Printf("✨ Response:\n%v\n", status) + rr.w.WriteHeader(status) +} + func bailf(msg string, err error) { log.Fatalf("😵 error: "+msg, err) }