Skip to content

Commit

Permalink
Support bearer tokens for talking to GCP projects
Browse files Browse the repository at this point in the history
  • Loading branch information
mhutchinson committed May 9, 2024
1 parent 54c3891 commit cea60ce
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 1 deletion.
10 changes: 9 additions & 1 deletion hammer/clients.go
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,15 @@ func (w *LogWriter) Run(ctx context.Context) {
}
newLeaf := w.gen()

resp, err := w.hc.Post(w.u.String(), "application/octet-stream", bytes.NewReader(newLeaf))
req, err := http.NewRequest(http.MethodPost, w.u.String(), bytes.NewReader(newLeaf))
if err != nil {
w.errchan <- fmt.Errorf("failed to create request: %v", err)
continue
}
if len(*bearerToken) > 0 {
req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", *bearerToken))
}
resp, err := hc.Do(req.WithContext(ctx))
if err != nil {
w.errchan <- fmt.Errorf("failed to write leaf: %v", err)
continue
Expand Down
4 changes: 4 additions & 0 deletions hammer/hammer.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ import (

var (
logURL = flag.String("log_url", "", "Log storage root URL, e.g. https://log.server/and/path/")
bearerToken = flag.String("bearer_token", "", "The bearer token for auth. For GCP this is the result of `gcloud auth print-identity-token`")
logPubKeyFile = flag.String("log_public_key", "", "Location of log public key file. If unset, uses the contents of the SERVERLESS_LOG_PUBLIC_KEY environment variable")
origin = flag.String("origin", "", "Expected first line of checkpoints from log")

Expand Down Expand Up @@ -398,6 +399,9 @@ func readHTTP(ctx context.Context, u *url.URL) ([]byte, error) {
if err != nil {
return nil, err
}
if len(*bearerToken) > 0 {
req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", *bearerToken))
}
resp, err := hc.Do(req.WithContext(ctx))
if err != nil {
return nil, err
Expand Down

0 comments on commit cea60ce

Please sign in to comment.