2016-03-23 14:53:09 -05:00
|
|
|
package fastly
|
|
|
|
|
|
|
|
import (
|
2016-04-20 13:43:54 -05:00
|
|
|
"fmt"
|
|
|
|
"sort"
|
2016-03-23 14:53:09 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// Service represents a single service for the Fastly account.
|
|
|
|
type Service struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
ID string `mapstructure:"id"`
|
|
|
|
Name string `mapstructure:"name"`
|
|
|
|
Comment string `mapstructure:"comment"`
|
|
|
|
CustomerID string `mapstructure:"customer_id"`
|
|
|
|
CreatedAt string `mapstructure:"created_at"`
|
|
|
|
UpdatedAt string `mapstructure:"updated_at"`
|
|
|
|
DeletedAt string `mapstructure:"deleted_at"`
|
|
|
|
ActiveVersion uint `mapstructure:"version"`
|
|
|
|
Versions []*Version `mapstructure:"versions"`
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
type ServiceDetail struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
ID string `mapstructure:"id"`
|
|
|
|
Name string `mapstructure:"name"`
|
|
|
|
Comment string `mapstructure:"comment"`
|
|
|
|
CustomerID string `mapstructure:"customer_id"`
|
|
|
|
ActiveVersion Version `mapstructure:"active_version"`
|
|
|
|
Version Version `mapstructure:"version"`
|
|
|
|
Versions []*Version `mapstructure:"versions"`
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// servicesByName is a sortable list of services.
|
|
|
|
type servicesByName []*Service
|
|
|
|
|
|
|
|
// Len, Swap, and Less implement the sortable interface.
|
|
|
|
func (s servicesByName) Len() int { return len(s) }
|
|
|
|
func (s servicesByName) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
|
|
|
|
func (s servicesByName) Less(i, j int) bool {
|
2016-04-20 13:43:54 -05:00
|
|
|
return s[i].Name < s[j].Name
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListServicesInput is used as input to the ListServices function.
|
|
|
|
type ListServicesInput struct{}
|
|
|
|
|
|
|
|
// ListServices returns the full list of services for the current account.
|
|
|
|
func (c *Client) ListServices(i *ListServicesInput) ([]*Service, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
resp, err := c.Get("/service", nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s []*Service
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
sort.Stable(servicesByName(s))
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// CreateServiceInput is used as input to the CreateService function.
|
|
|
|
type CreateServiceInput struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
Name string `form:"name,omitempty"`
|
|
|
|
Comment string `form:"comment,omitempty"`
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// CreateService creates a new service with the given information.
|
|
|
|
func (c *Client) CreateService(i *CreateServiceInput) (*Service, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
resp, err := c.PostForm("/service", i, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s *Service
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetServiceInput is used as input to the GetService function.
|
|
|
|
type GetServiceInput struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
ID string
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetService retrieves the service information for the service with the given
|
|
|
|
// id. If no service exists for the given id, the API returns a 400 response
|
|
|
|
// (not a 404).
|
|
|
|
func (c *Client) GetService(i *GetServiceInput) (*Service, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
if i.ID == "" {
|
|
|
|
return nil, ErrMissingID
|
|
|
|
}
|
|
|
|
|
|
|
|
path := fmt.Sprintf("/service/%s", i.ID)
|
|
|
|
resp, err := c.Get(path, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s *Service
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetService retrieves the details for the service with the given id. If no
|
|
|
|
// service exists for the given id, the API returns a 400 response (not a 404).
|
|
|
|
func (c *Client) GetServiceDetails(i *GetServiceInput) (*ServiceDetail, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
if i.ID == "" {
|
|
|
|
return nil, ErrMissingID
|
|
|
|
}
|
|
|
|
|
|
|
|
path := fmt.Sprintf("/service/%s/details", i.ID)
|
|
|
|
resp, err := c.Get(path, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s *ServiceDetail
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateServiceInput is used as input to the UpdateService function.
|
|
|
|
type UpdateServiceInput struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
ID string
|
2016-03-23 14:53:09 -05:00
|
|
|
|
2016-04-20 13:43:54 -05:00
|
|
|
Name string `form:"name,omitempty"`
|
|
|
|
Comment string `form:"comment,omitempty"`
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateService updates the service with the given input.
|
|
|
|
func (c *Client) UpdateService(i *UpdateServiceInput) (*Service, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
if i.ID == "" {
|
|
|
|
return nil, ErrMissingID
|
|
|
|
}
|
|
|
|
|
|
|
|
path := fmt.Sprintf("/service/%s", i.ID)
|
|
|
|
resp, err := c.PutForm(path, i, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s *Service
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteServiceInput is used as input to the DeleteService function.
|
|
|
|
type DeleteServiceInput struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
ID string
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteService updates the service with the given input.
|
|
|
|
func (c *Client) DeleteService(i *DeleteServiceInput) error {
|
2016-04-20 13:43:54 -05:00
|
|
|
if i.ID == "" {
|
|
|
|
return ErrMissingID
|
|
|
|
}
|
|
|
|
|
|
|
|
path := fmt.Sprintf("/service/%s", i.ID)
|
|
|
|
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
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// SearchServiceInput is used as input to the SearchService function.
|
|
|
|
type SearchServiceInput struct {
|
2016-04-20 13:43:54 -05:00
|
|
|
Name string
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// SearchService gets a specific service by name. If no service exists by that
|
|
|
|
// name, the API returns a 400 response (not a 404).
|
|
|
|
func (c *Client) SearchService(i *SearchServiceInput) (*Service, error) {
|
2016-04-20 13:43:54 -05:00
|
|
|
if i.Name == "" {
|
|
|
|
return nil, ErrMissingName
|
|
|
|
}
|
|
|
|
|
|
|
|
resp, err := c.Get("/service/search", &RequestOptions{
|
|
|
|
Params: map[string]string{
|
|
|
|
"name": i.Name,
|
|
|
|
},
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
var s *Service
|
|
|
|
if err := decodeJSON(&s, resp.Body); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return s, nil
|
2016-03-23 14:53:09 -05:00
|
|
|
}
|