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
|
package awsutil
import (
"bytes"
"net/http"
"net/http/httputil"
"regexp"
"github.com/rebuy-de/aws-nuke/pkg/util"
log "github.com/sirupsen/logrus"
)
var (
RESecretHeader = regexp.MustCompile(`(?m:^([^:]*(Auth|Security)[^:]*):.*$)`)
)
func HideSecureHeaders(dump []byte) []byte {
return RESecretHeader.ReplaceAll(dump, []byte("$1: <hidden>"))
}
func DumpRequest(r *http.Request) string {
dump, err := httputil.DumpRequest(r, true)
if err != nil {
log.WithField("Error", err).
Warnf("failed to dump HTTP request")
return ""
}
dump = bytes.TrimSpace(dump)
dump = HideSecureHeaders(dump)
dump = util.IndentBytes(dump, []byte(" > "))
return string(dump)
}
func DumpResponse(r *http.Response) string {
dump, err := httputil.DumpResponse(r, true)
if err != nil {
log.WithField("Error", err).
Warnf("failed to dump HTTP response")
return ""
}
dump = bytes.TrimSpace(dump)
dump = util.IndentBytes(dump, []byte(" < "))
return string(dump)
}
|