Add authentication support to the http_response input plugin (#7491)
This commit is contained in:
		
							parent
							
								
									a78de9c5f0
								
							
						
					
					
						commit
						670277f785
					
				|  | @ -21,16 +21,21 @@ import ( | ||||||
| 
 | 
 | ||||||
| // HTTPResponse struct
 | // HTTPResponse struct
 | ||||||
| type HTTPResponse struct { | type HTTPResponse struct { | ||||||
| 	Address             string   // deprecated in 1.12
 | 	Address         string   // deprecated in 1.12
 | ||||||
| 	URLs                []string `toml:"urls"` | 	URLs            []string `toml:"urls"` | ||||||
| 	HTTPProxy           string   `toml:"http_proxy"` | 	HTTPProxy       string   `toml:"http_proxy"` | ||||||
| 	Body                string | 	Body            string | ||||||
| 	Method              string | 	Method          string | ||||||
| 	ResponseTimeout     internal.Duration | 	ResponseTimeout internal.Duration | ||||||
| 	Headers             map[string]string | 	Headers         map[string]string | ||||||
| 	FollowRedirects     bool | 	FollowRedirects bool | ||||||
|  | 	// Absolute path to file with Bearer token
 | ||||||
|  | 	BearerToken         string `toml:"bearer_token"` | ||||||
| 	ResponseStringMatch string | 	ResponseStringMatch string | ||||||
| 	Interface           string | 	Interface           string | ||||||
|  | 	// HTTP Basic Auth Credentials
 | ||||||
|  | 	Username string `toml:"username"` | ||||||
|  | 	Password string `toml:"password"` | ||||||
| 	tls.ClientConfig | 	tls.ClientConfig | ||||||
| 
 | 
 | ||||||
| 	Log telegraf.Logger | 	Log telegraf.Logger | ||||||
|  | @ -64,6 +69,14 @@ var sampleConfig = ` | ||||||
|   ## Whether to follow redirects from the server (defaults to false) |   ## Whether to follow redirects from the server (defaults to false) | ||||||
|   # follow_redirects = false |   # follow_redirects = false | ||||||
| 
 | 
 | ||||||
|  |   ## Optional file with Bearer token | ||||||
|  |   ## file content is added as an Authorization header | ||||||
|  |   # bearer_token = "/path/to/file" | ||||||
|  | 
 | ||||||
|  |   ## Optional HTTP Basic Auth Credentials | ||||||
|  |   # username = "username" | ||||||
|  |   # password = "pa$$word" | ||||||
|  | 
 | ||||||
|   ## Optional HTTP Request Body |   ## Optional HTTP Request Body | ||||||
|   # body = ''' |   # body = ''' | ||||||
|   # {'fake':'data'} |   # {'fake':'data'} | ||||||
|  | @ -227,6 +240,15 @@ func (h *HTTPResponse) httpGather(u string) (map[string]interface{}, map[string] | ||||||
| 		return nil, nil, err | 		return nil, nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if h.BearerToken != "" { | ||||||
|  | 		token, err := ioutil.ReadFile(h.BearerToken) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return nil, nil, err | ||||||
|  | 		} | ||||||
|  | 		bearer := "Bearer " + strings.Trim(string(token), "\n") | ||||||
|  | 		request.Header.Add("Authorization", bearer) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	for key, val := range h.Headers { | 	for key, val := range h.Headers { | ||||||
| 		request.Header.Add(key, val) | 		request.Header.Add(key, val) | ||||||
| 		if key == "Host" { | 		if key == "Host" { | ||||||
|  | @ -234,6 +256,10 @@ func (h *HTTPResponse) httpGather(u string) (map[string]interface{}, map[string] | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if h.Username != "" || h.Password != "" { | ||||||
|  | 		request.SetBasicAuth(h.Username, h.Password) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	// Start Timer
 | 	// Start Timer
 | ||||||
| 	start := time.Now() | 	start := time.Now() | ||||||
| 	resp, err := h.client.Do(request) | 	resp, err := h.client.Do(request) | ||||||
|  |  | ||||||
|  | @ -864,3 +864,45 @@ func TestRedirect(t *testing.T) { | ||||||
| 
 | 
 | ||||||
| 	testutil.RequireMetricsEqual(t, expected, actual, testutil.IgnoreTime()) | 	testutil.RequireMetricsEqual(t, expected, actual, testutil.IgnoreTime()) | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func TestBasicAuth(t *testing.T) { | ||||||
|  | 	ts := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { | ||||||
|  | 		aHeader := r.Header.Get("Authorization") | ||||||
|  | 		assert.Equal(t, "Basic bWU6bXlwYXNzd29yZA==", aHeader) | ||||||
|  | 		w.WriteHeader(http.StatusOK) | ||||||
|  | 	})) | ||||||
|  | 	defer ts.Close() | ||||||
|  | 
 | ||||||
|  | 	h := &HTTPResponse{ | ||||||
|  | 		Log:             testutil.Logger{}, | ||||||
|  | 		Address:         ts.URL + "/good", | ||||||
|  | 		Body:            "{ 'test': 'data'}", | ||||||
|  | 		Method:          "GET", | ||||||
|  | 		ResponseTimeout: internal.Duration{Duration: time.Second * 20}, | ||||||
|  | 		Username:        "me", | ||||||
|  | 		Password:        "mypassword", | ||||||
|  | 		Headers: map[string]string{ | ||||||
|  | 			"Content-Type": "application/json", | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	var acc testutil.Accumulator | ||||||
|  | 	err := h.Gather(&acc) | ||||||
|  | 	require.NoError(t, err) | ||||||
|  | 
 | ||||||
|  | 	expectedFields := map[string]interface{}{ | ||||||
|  | 		"http_response_code": http.StatusOK, | ||||||
|  | 		"result_type":        "success", | ||||||
|  | 		"result_code":        0, | ||||||
|  | 		"response_time":      nil, | ||||||
|  | 		"content_length":     nil, | ||||||
|  | 	} | ||||||
|  | 	expectedTags := map[string]interface{}{ | ||||||
|  | 		"server":      nil, | ||||||
|  | 		"method":      "GET", | ||||||
|  | 		"status_code": "200", | ||||||
|  | 		"result":      "success", | ||||||
|  | 	} | ||||||
|  | 	absentFields := []string{"response_string_match"} | ||||||
|  | 	checkOutput(t, &acc, expectedFields, expectedTags, absentFields, nil) | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue