You've already forked tarr
							
							
		
			
				
	
	
		
			80 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
package health
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"crypto/tls"
 | 
						|
	"errors"
 | 
						|
	"fmt"
 | 
						|
	"net/http"
 | 
						|
	"net/url"
 | 
						|
)
 | 
						|
 | 
						|
var ErrNoAPIToken error = errors.New("no API token defined")
 | 
						|
var ErrNoURL error = errors.New("no API token defined")
 | 
						|
 | 
						|
type ReadinessProbe struct {
 | 
						|
	additionalQueryValues url.Values
 | 
						|
	insecure              bool
 | 
						|
	url                   string
 | 
						|
}
 | 
						|
 | 
						|
func (rp *ReadinessProbe) QueryAdd(key, value string) *ReadinessProbe {
 | 
						|
	if rp.additionalQueryValues.Has(key) {
 | 
						|
		rp.additionalQueryValues.Add(key, value)
 | 
						|
	} else {
 | 
						|
		rp.additionalQueryValues.Set(key, value)
 | 
						|
	}
 | 
						|
	return rp
 | 
						|
}
 | 
						|
 | 
						|
func (rp *ReadinessProbe) Insecure(insecure bool) *ReadinessProbe {
 | 
						|
	rp.insecure = insecure
 | 
						|
	return rp
 | 
						|
}
 | 
						|
 | 
						|
func (rp *ReadinessProbe) Run(ctx context.Context) error {
 | 
						|
	if len(rp.url) <= 0 {
 | 
						|
		return ErrNoURL
 | 
						|
	}
 | 
						|
 | 
						|
	httpClient := &http.Client{
 | 
						|
		Transport: &http.Transport{
 | 
						|
			TLSClientConfig: &tls.Config{
 | 
						|
				// #nosec G402
 | 
						|
				InsecureSkipVerify: rp.insecure,
 | 
						|
			},
 | 
						|
		},
 | 
						|
	}
 | 
						|
 | 
						|
	req, err := http.NewRequest(http.MethodGet, rp.url, nil)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	reValues := req.URL.Query()
 | 
						|
	for key, values := range rp.additionalQueryValues {
 | 
						|
		for _, value := range values {
 | 
						|
			reValues.Add(key, value)
 | 
						|
		}
 | 
						|
	}
 | 
						|
	req.URL.RawQuery = reValues.Encode()
 | 
						|
 | 
						|
	resp, err := httpClient.Do(req)
 | 
						|
	if err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	if resp.StatusCode != http.StatusOK {
 | 
						|
		return fmt.Errorf("received unexpected HTTP status code %v", resp.StatusCode)
 | 
						|
	}
 | 
						|
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
func NewReadinessProbe(url string) *ReadinessProbe {
 | 
						|
	return &ReadinessProbe{
 | 
						|
		additionalQueryValues: make(map[string][]string),
 | 
						|
		url:                   url,
 | 
						|
	}
 | 
						|
}
 |