241 lines
6.6 KiB
Go
241 lines
6.6 KiB
Go
package fastly
|
|
|
|
import (
|
|
"fmt"
|
|
"sort"
|
|
)
|
|
|
|
// HealthCheck represents a health check response from the Fastly API.
|
|
type HealthCheck struct {
|
|
ServiceID string `mapstructure:"service_id"`
|
|
Version string `mapstructure:"version"`
|
|
|
|
Name string `mapstructure:"name"`
|
|
Method string `mapstructure:"method"`
|
|
Host string `mapstructure:"host"`
|
|
Path string `mapstructure:"path"`
|
|
HTTPVersion string `mapstructure:"http_version"`
|
|
Timeout uint `mapstructure:"timeout"`
|
|
CheckInterval uint `mapstructure:"check_interval"`
|
|
ExpectedResponse uint `mapstructure:"expected_response"`
|
|
Window uint `mapstructure:"window"`
|
|
Threshold uint `mapstructure:"threshold"`
|
|
Initial uint `mapstructure:"initial"`
|
|
}
|
|
|
|
// healthChecksByName is a sortable list of health checks.
|
|
type healthChecksByName []*HealthCheck
|
|
|
|
// Len, Swap, and Less implement the sortable interface.
|
|
func (s healthChecksByName) Len() int { return len(s) }
|
|
func (s healthChecksByName) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
|
|
func (s healthChecksByName) Less(i, j int) bool {
|
|
return s[i].Name < s[j].Name
|
|
}
|
|
|
|
// ListHealthChecksInput is used as input to the ListHealthChecks function.
|
|
type ListHealthChecksInput struct {
|
|
// Service is the ID of the service (required).
|
|
Service string
|
|
|
|
// Version is the specific configuration version (required).
|
|
Version string
|
|
}
|
|
|
|
// ListHealthChecks returns the list of health checks for the configuration
|
|
// version.
|
|
func (c *Client) ListHealthChecks(i *ListHealthChecksInput) ([]*HealthCheck, error) {
|
|
if i.Service == "" {
|
|
return nil, ErrMissingService
|
|
}
|
|
|
|
if i.Version == "" {
|
|
return nil, ErrMissingVersion
|
|
}
|
|
|
|
path := fmt.Sprintf("/service/%s/version/%s/healthcheck", i.Service, i.Version)
|
|
resp, err := c.Get(path, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var hcs []*HealthCheck
|
|
if err := decodeJSON(&hcs, resp.Body); err != nil {
|
|
return nil, err
|
|
}
|
|
sort.Stable(healthChecksByName(hcs))
|
|
return hcs, nil
|
|
}
|
|
|
|
// CreateHealthCheckInput is used as input to the CreateHealthCheck function.
|
|
type CreateHealthCheckInput struct {
|
|
// Service is the ID of the service. Version is the specific configuration
|
|
// version. Both fields are required.
|
|
Service string
|
|
Version string
|
|
|
|
Name string `form:"name,omitempty"`
|
|
Method string `form:"method,omitempty"`
|
|
Host string `form:"host,omitempty"`
|
|
Path string `form:"path,omitempty"`
|
|
HTTPVersion string `form:"http_version,omitempty"`
|
|
Timeout uint `form:"timeout,omitempty"`
|
|
CheckInterval uint `form:"check_interval,omitempty"`
|
|
ExpectedResponse uint `form:"expected_response,omitempty"`
|
|
Window uint `form:"window,omitempty"`
|
|
Threshold uint `form:"threshold,omitempty"`
|
|
Initial uint `form:"initial,omitempty"`
|
|
}
|
|
|
|
// CreateHealthCheck creates a new Fastly health check.
|
|
func (c *Client) CreateHealthCheck(i *CreateHealthCheckInput) (*HealthCheck, error) {
|
|
if i.Service == "" {
|
|
return nil, ErrMissingService
|
|
}
|
|
|
|
if i.Version == "" {
|
|
return nil, ErrMissingVersion
|
|
}
|
|
|
|
path := fmt.Sprintf("/service/%s/version/%s/healthcheck", i.Service, i.Version)
|
|
resp, err := c.PostForm(path, i, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var h *HealthCheck
|
|
if err := decodeJSON(&h, resp.Body); err != nil {
|
|
return nil, err
|
|
}
|
|
return h, nil
|
|
}
|
|
|
|
// GetHealthCheckInput is used as input to the GetHealthCheck function.
|
|
type GetHealthCheckInput struct {
|
|
// Service is the ID of the service. Version is the specific configuration
|
|
// version. Both fields are required.
|
|
Service string
|
|
Version string
|
|
|
|
// Name is the name of the health check to fetch.
|
|
Name string
|
|
}
|
|
|
|
// GetHealthCheck gets the health check configuration with the given parameters.
|
|
func (c *Client) GetHealthCheck(i *GetHealthCheckInput) (*HealthCheck, error) {
|
|
if i.Service == "" {
|
|
return nil, ErrMissingService
|
|
}
|
|
|
|
if i.Version == "" {
|
|
return nil, ErrMissingVersion
|
|
}
|
|
|
|
if i.Name == "" {
|
|
return nil, ErrMissingName
|
|
}
|
|
|
|
path := fmt.Sprintf("/service/%s/version/%s/healthcheck/%s", i.Service, i.Version, i.Name)
|
|
resp, err := c.Get(path, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var h *HealthCheck
|
|
if err := decodeJSON(&h, resp.Body); err != nil {
|
|
return nil, err
|
|
}
|
|
return h, nil
|
|
}
|
|
|
|
// UpdateHealthCheckInput is used as input to the UpdateHealthCheck function.
|
|
type UpdateHealthCheckInput struct {
|
|
// Service is the ID of the service. Version is the specific configuration
|
|
// version. Both fields are required.
|
|
Service string
|
|
Version string
|
|
|
|
// Name is the name of the health check to update.
|
|
Name string
|
|
|
|
NewName string `form:"name,omitempty"`
|
|
Method string `form:"method,omitempty"`
|
|
Host string `form:"host,omitempty"`
|
|
Path string `form:"path,omitempty"`
|
|
HTTPVersion string `form:"http_version,omitempty"`
|
|
Timeout uint `form:"timeout,omitempty"`
|
|
CheckInterval uint `form:"check_interval,omitempty"`
|
|
ExpectedResponse uint `form:"expected_response,omitempty"`
|
|
Window uint `form:"window,omitempty"`
|
|
Threshold uint `form:"threshold,omitempty"`
|
|
Initial uint `form:"initial,omitempty"`
|
|
}
|
|
|
|
// UpdateHealthCheck updates a specific health check.
|
|
func (c *Client) UpdateHealthCheck(i *UpdateHealthCheckInput) (*HealthCheck, error) {
|
|
if i.Service == "" {
|
|
return nil, ErrMissingService
|
|
}
|
|
|
|
if i.Version == "" {
|
|
return nil, ErrMissingVersion
|
|
}
|
|
|
|
if i.Name == "" {
|
|
return nil, ErrMissingName
|
|
}
|
|
|
|
path := fmt.Sprintf("/service/%s/version/%s/healthcheck/%s", i.Service, i.Version, i.Name)
|
|
resp, err := c.PutForm(path, i, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
var h *HealthCheck
|
|
if err := decodeJSON(&h, resp.Body); err != nil {
|
|
return nil, err
|
|
}
|
|
return h, nil
|
|
}
|
|
|
|
// DeleteHealthCheckInput is the input parameter to DeleteHealthCheck.
|
|
type DeleteHealthCheckInput struct {
|
|
// Service is the ID of the service. Version is the specific configuration
|
|
// version. Both fields are required.
|
|
Service string
|
|
Version string
|
|
|
|
// Name is the name of the health check to delete (required).
|
|
Name string
|
|
}
|
|
|
|
// DeleteHealthCheck deletes the given health check.
|
|
func (c *Client) DeleteHealthCheck(i *DeleteHealthCheckInput) error {
|
|
if i.Service == "" {
|
|
return ErrMissingService
|
|
}
|
|
|
|
if i.Version == "" {
|
|
return ErrMissingVersion
|
|
}
|
|
|
|
if i.Name == "" {
|
|
return ErrMissingName
|
|
}
|
|
|
|
path := fmt.Sprintf("/service/%s/version/%s/healthcheck/%s", i.Service, i.Version, i.Name)
|
|
resp, err := c.Delete(path, nil)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
var r *statusResp
|
|
if err := decodeJSON(&r, resp.Body); err != nil {
|
|
return err
|
|
}
|
|
if !r.Ok() {
|
|
return fmt.Errorf("Not Ok")
|
|
}
|
|
return nil
|
|
}
|