mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-10-31 02:28:09 +00:00 
			
		
		
		
	 8dd6180e31
			
		
	
	8dd6180e31
	
	
	
		
			
			* Pin HTTP Host header for all client requests * Drop port map scheme * Add SRV Lookup environment var * Lookup SRV records only when env var is specified * Add docs Co-Authored-By: Michel Vocks <michelvocks@gmail.com>
		
			
				
	
	
		
			149 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package api
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"encoding/json"
 | |
| 	"io"
 | |
| 	"io/ioutil"
 | |
| 	"net/http"
 | |
| 	"net/url"
 | |
| 
 | |
| 	"github.com/hashicorp/vault/sdk/helper/consts"
 | |
| 
 | |
| 	retryablehttp "github.com/hashicorp/go-retryablehttp"
 | |
| )
 | |
| 
 | |
| // Request is a raw request configuration structure used to initiate
 | |
| // API requests to the Vault server.
 | |
| type Request struct {
 | |
| 	Method        string
 | |
| 	URL           *url.URL
 | |
| 	Host          string
 | |
| 	Params        url.Values
 | |
| 	Headers       http.Header
 | |
| 	ClientToken   string
 | |
| 	MFAHeaderVals []string
 | |
| 	WrapTTL       string
 | |
| 	Obj           interface{}
 | |
| 
 | |
| 	// When possible, use BodyBytes as it is more efficient due to how the
 | |
| 	// retry logic works
 | |
| 	BodyBytes []byte
 | |
| 
 | |
| 	// Fallback
 | |
| 	Body     io.Reader
 | |
| 	BodySize int64
 | |
| 
 | |
| 	// Whether to request overriding soft-mandatory Sentinel policies (RGPs and
 | |
| 	// EGPs). If set, the override flag will take effect for all policies
 | |
| 	// evaluated during the request.
 | |
| 	PolicyOverride bool
 | |
| }
 | |
| 
 | |
| // SetJSONBody is used to set a request body that is a JSON-encoded value.
 | |
| func (r *Request) SetJSONBody(val interface{}) error {
 | |
| 	buf, err := json.Marshal(val)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	r.Obj = val
 | |
| 	r.BodyBytes = buf
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // ResetJSONBody is used to reset the body for a redirect
 | |
| func (r *Request) ResetJSONBody() error {
 | |
| 	if r.BodyBytes == nil {
 | |
| 		return nil
 | |
| 	}
 | |
| 	return r.SetJSONBody(r.Obj)
 | |
| }
 | |
| 
 | |
| // DEPRECATED: ToHTTP turns this request into a valid *http.Request for use
 | |
| // with the net/http package.
 | |
| func (r *Request) ToHTTP() (*http.Request, error) {
 | |
| 	req, err := r.toRetryableHTTP()
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	switch {
 | |
| 	case r.BodyBytes == nil && r.Body == nil:
 | |
| 		// No body
 | |
| 
 | |
| 	case r.BodyBytes != nil:
 | |
| 		req.Request.Body = ioutil.NopCloser(bytes.NewReader(r.BodyBytes))
 | |
| 
 | |
| 	default:
 | |
| 		if c, ok := r.Body.(io.ReadCloser); ok {
 | |
| 			req.Request.Body = c
 | |
| 		} else {
 | |
| 			req.Request.Body = ioutil.NopCloser(r.Body)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return req.Request, nil
 | |
| }
 | |
| 
 | |
| func (r *Request) toRetryableHTTP() (*retryablehttp.Request, error) {
 | |
| 	// Encode the query parameters
 | |
| 	r.URL.RawQuery = r.Params.Encode()
 | |
| 
 | |
| 	// Create the HTTP request, defaulting to retryable
 | |
| 	var req *retryablehttp.Request
 | |
| 
 | |
| 	var err error
 | |
| 	var body interface{}
 | |
| 
 | |
| 	switch {
 | |
| 	case r.BodyBytes == nil && r.Body == nil:
 | |
| 		// No body
 | |
| 
 | |
| 	case r.BodyBytes != nil:
 | |
| 		// Use bytes, it's more efficient
 | |
| 		body = r.BodyBytes
 | |
| 
 | |
| 	default:
 | |
| 		body = r.Body
 | |
| 	}
 | |
| 
 | |
| 	req, err = retryablehttp.NewRequest(r.Method, r.URL.RequestURI(), body)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	req.URL.User = r.URL.User
 | |
| 	req.URL.Scheme = r.URL.Scheme
 | |
| 	req.URL.Host = r.URL.Host
 | |
| 	req.Host = r.Host
 | |
| 
 | |
| 	if r.Headers != nil {
 | |
| 		for header, vals := range r.Headers {
 | |
| 			for _, val := range vals {
 | |
| 				req.Header.Add(header, val)
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if len(r.ClientToken) != 0 {
 | |
| 		req.Header.Set(consts.AuthHeaderName, r.ClientToken)
 | |
| 	}
 | |
| 
 | |
| 	if len(r.WrapTTL) != 0 {
 | |
| 		req.Header.Set("X-Vault-Wrap-TTL", r.WrapTTL)
 | |
| 	}
 | |
| 
 | |
| 	if len(r.MFAHeaderVals) != 0 {
 | |
| 		for _, mfaHeaderVal := range r.MFAHeaderVals {
 | |
| 			req.Header.Add("X-Vault-MFA", mfaHeaderVal)
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	if r.PolicyOverride {
 | |
| 		req.Header.Set("X-Vault-Policy-Override", "true")
 | |
| 	}
 | |
| 
 | |
| 	return req, nil
 | |
| }
 |