Skip to content

Commit

Permalink
Use application/json as content type when returning credentials (#115)
Browse files Browse the repository at this point in the history
  • Loading branch information
dleen authored Mar 17, 2022
1 parent 4ee3630 commit 4d87188
Show file tree
Hide file tree
Showing 7 changed files with 23 additions and 10 deletions.
2 changes: 1 addition & 1 deletion .pre-commit-config.yaml
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
repos:
- repo: git://github.com/dnephin/pre-commit-golang
- repo: https://github.com/dnephin/pre-commit-golang
rev: master
hooks:
- id: go-fmt
Expand Down
2 changes: 2 additions & 0 deletions pkg/server/baseHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ reservation-id
security-groups
services/`

w.Header().Set("Content-Type", "text/plain")
fmt.Fprint(w, baseMetadata)
}

Expand All @@ -56,6 +57,7 @@ func BaseVersionHandler(w http.ResponseWriter, r *http.Request) {
meta-data
user-data`

w.Header().Set("Content-Type", "text/plain")
fmt.Fprintln(w, baseVersionPath)
}

Expand Down
1 change: 1 addition & 0 deletions pkg/server/credentialsHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ func RoleHandler(w http.ResponseWriter, r *http.Request) {
util.WriteError(w, "error", 500)
return
}
w.Header().Set("Content-Type", "text/plain")
if _, err := w.Write([]byte(fmt.Sprintf("%s\n", defaultRole.RoleName))); err != nil {
logging.Log.Errorf("failed to write response: %v", err)
}
Expand Down
1 change: 1 addition & 0 deletions pkg/server/ecsCredentialsHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,7 @@ func getCredentialHandler(region string) func(http.ResponseWriter, *http.Request
Token: fmt.Sprintf("%s", cachedCredentials.SessionToken),
}

w.Header().Set("Content-Type", "application/json")
err = json.NewEncoder(w).Encode(credentialResponse)
if err != nil {
logging.Log.Errorf("failed to write response: %v", err)
Expand Down
3 changes: 1 addition & 2 deletions pkg/server/middleware.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,7 @@ import (

// InstanceMetadataMiddleware is a convenience wrapper that chains TokenMiddleware, BrowserFilterMiddleware, and AWSHeaderMiddleware
func InstanceMetadataMiddleware(next http.HandlerFunc) http.HandlerFunc {
return TokenMiddleware(TaskMetadataMiddleware(next))
return BrowserFilterMiddleware(TokenMiddleware(AWSHeaderMiddleware(next)))
}

// TaskMetadataMiddleware is a convenience wrapper that chains BrowserFilterMiddleware and AWSHeaderMiddleware
Expand Down Expand Up @@ -75,7 +75,6 @@ func AWSHeaderMiddleware(next http.HandlerFunc) http.HandlerFunc {
w.Header().Set("ETag", strconv.FormatInt(rand.Int63n(10000000000), 10))
w.Header().Set("Last-Modified", time.Now().UTC().Format("2006-01-02T15:04:05Z")) // TODO: set this to cred refresh time
w.Header().Set("Server", "EC2ws")
w.Header().Set("Content-Type", "text/plain")

ua := r.Header.Get("User-Agent")
metadataVersion := 1
Expand Down
23 changes: 16 additions & 7 deletions pkg/server/middleware_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ func TestAWSHeaderMiddleware(t *testing.T) {
w.WriteHeader(http.StatusOK)
})
t.Logf("test case: %s", description)
bfmHandler := InstanceMetadataMiddleware(nextHandler)
bfmHandler := AWSHeaderMiddleware(nextHandler)
req := httptest.NewRequest("GET", "http://localhost", nil)
rec := httptest.NewRecorder()
bfmHandler.ServeHTTP(rec, req)
Expand All @@ -135,9 +135,6 @@ func TestAWSHeaderMiddleware(t *testing.T) {
if server := rec.Header().Get("Server"); server != "EC2ws" {
t.Errorf("%s failed: got Server header %s, expected %s", description, server, "EC2ws")
}
if contentType := rec.Header().Get("Content-Type"); contentType != "text/plain" {
t.Errorf("%s failed: got Content-Type header %s, expected %s", description, contentType, "text/plain")
}
}

// TestCredentialServiceMiddleware is a superset of TestBrowserFilterMiddleware and TestAWSHeaderMiddleware
Expand Down Expand Up @@ -167,9 +164,21 @@ func TestCredentialServiceMiddleware(t *testing.T) {
if server := rec.Header().Get("Server"); server != "EC2ws" {
t.Errorf("%s failed: got Server header %s, expected %s", tc.Description, server, "EC2ws")
}
if contentType := rec.Header().Get("Content-Type"); contentType != "text/plain" {
t.Errorf("%s failed: got Content-Type header %s, expected %s", tc.Description, contentType, "text/plain")
}
}
}
}

func TestTokenMiddleware(t *testing.T) {
description := "aws token middleware"
nextHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusOK)
})
t.Logf("test case: %s", description)
bfmHandler := TokenMiddleware(nextHandler)
req := httptest.NewRequest("GET", "http://localhost", nil)
rec := httptest.NewRecorder()
bfmHandler.ServeHTTP(rec, req)
if rec.Code != http.StatusOK {
t.Errorf("%s failed: got status %d, expected %d", description, rec.Code, http.StatusOK)
}
}
1 change: 1 addition & 0 deletions pkg/util/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ func CreateFile(filename string, directoryPerm, filePerm fs.FileMode) error {
// The error is written as plaintext so AWS SDKs will display it inline with an error message.
func WriteError(w http.ResponseWriter, message string, status int) {
logging.Log.Debugf("writing HTTP error response: %s", message)
w.Header().Set("Content-Type", "text/plain")
w.WriteHeader(status)
_, err := w.Write([]byte(message))
if err != nil {
Expand Down

0 comments on commit 4d87188

Please sign in to comment.