blob: 42ccfae0ef1cc7715a190596eb81037cfab6ed1a [file] [log] [blame]
package lbs
import (
"github.com/mitchellh/mapstructure"
"github.com/rackspace/gophercloud"
"github.com/rackspace/gophercloud/pagination"
"github.com/rackspace/gophercloud/rackspace/lb/v1/nodes"
)
type Protocol string
// The constants below represent all the compatible load balancer protocols.
const (
// DNSTCP is a protocol that works with IPv6 and allows your DNS server to
// receive traffic using TCP port 53.
DNSTCP = "DNS_TCP"
// DNSUDP is a protocol that works with IPv6 and allows your DNS server to
// receive traffic using UDP port 53.
DNSUDP = "DNS_UDP"
// TCP is one of the core protocols of the Internet Protocol Suite. It
// provides a reliable, ordered delivery of a stream of bytes from one
// program on a computer to another program on another computer. Applications
// that require an ordered and reliable delivery of packets use this protocol.
TCP = "TCP"
// TCPCLIENTFIRST is a protocol similar to TCP, but is more efficient when a
// client is expected to write the data first.
TCPCLIENTFIRST = "TCP_CLIENT_FIRST"
// UDP provides a datagram service that emphasizes speed over reliability. It
// works well with applications that provide security through other measures.
UDP = "UDP"
// UDPSTREAM is a protocol designed to stream media over networks and is
// built on top of UDP.
UDPSTREAM = "UDP_STREAM"
)
// Algorithm defines how traffic should be directed between back-end nodes.
type Algorithm string
const (
// LC directs traffic to the node with the lowest number of connections.
LC = "LEAST_CONNECTIONS"
// RAND directs traffic to nodes at random.
RAND = "RANDOM"
// RR directs traffic to each of the nodes in turn.
RR = "ROUND_ROBIN"
// WLC directs traffic to a node based on the number of concurrent
// connections and its weight.
WLC = "WEIGHTED_LEAST_CONNECTIONS"
// WRR directs traffic to a node according to the RR algorithm, but with
// different proportions of traffic being directed to the back-end nodes.
// Weights must be defined as part of the node configuration.
WRR = "WEIGHTED_ROUND_ROBIN"
)
type Status string
const (
// ACTIVE indicates that the LB is configured properly and ready to serve
// traffic to incoming requests via the configured virtual IPs.
ACTIVE = "ACTIVE"
// BUILD indicates that the LB is being provisioned for the first time and
// configuration is being applied to bring the service online. The service
// cannot yet serve incoming requests.
BUILD = "BUILD"
// PENDINGUPDATE indicates that the LB is online but configuration changes
// are being applied to update the service based on a previous request.
PENDINGUPDATE = "PENDING_UPDATE"
// PENDINGDELETE indicates that the LB is online but configuration changes
// are being applied to begin deletion of the service based on a previous
// request.
PENDINGDELETE = "PENDING_DELETE"
// SUSPENDED indicates that the LB has been taken offline and disabled.
SUSPENDED = "SUSPENDED"
// ERROR indicates that the system encountered an error when attempting to
// configure the load balancer.
ERROR = "ERROR"
// DELETED indicates that the LB has been deleted.
DELETED = "DELETED"
)
type Datetime struct {
Time string
}
type VIP struct {
Address string `json:"address,omitempty"`
ID int `json:"id,omitempty"`
Type string `json:"type,omitempty"`
Version string `json:"ipVersion,omitempty" mapstructure:"ipVersion"`
}
type LoadBalancer struct {
// Human-readable name for the load balancer.
Name string
// The unique ID for the load balancer.
ID int
// Represents the service protocol being load balanced.
Protocol Protocol
// Defines how traffic should be directed between back-end nodes. The default
// algorithm is RANDOM.
Algorithm Algorithm
// The current status of the load balancer.
Status Status
// The number of load balancer nodes.
NodeCount int `mapstructure:"nodeCount"`
// Slice of virtual IPs associated with this load balancer.
VIPs []VIP `mapstructure:"virtualIps"`
// Datetime when the LB was created.
Created Datetime
// Datetime when the LB was created.
Updated Datetime
Port int
HalfClosed bool
Timeout int
Cluster Cluster
Nodes []nodes.Node
ConnectionLogging ConnectionLogging
SessionPersistence SessionPersistence
ConnectionThrottle ConnectionThrottle
SourceAddrs SourceAddrs `mapstructure:"sourceAddresses"`
}
type SourceAddrs struct {
IPv4Public string `json:"ipv4Public" mapstructure:"ipv4Public"`
IPv4Private string `json:"ipv4Servicenet" mapstructure:"ipv4Servicenet"`
IPv6Public string `json:"ipv6Public" mapstructure:"ipv6Public"`
IPv6Private string `json:"ipv6Servicenet" mapstructure:"ipv6Servicenet"`
}
type SessionPersistence struct {
Type string `json:"persistenceType" mapstructure:"persistenceType"`
}
type ConnectionThrottle struct {
MinConns int `json:"minConnections" mapstructure:"minConnections"`
MaxConns int `json:"maxConnections" mapstructure:"maxConnections"`
MaxConnRate int `json:"maxConnectionRate" mapstructure:"maxConnectionRate"`
RateInterval int `json:"rateInterval" mapstructure:"rateInterval"`
}
type ConnectionLogging struct {
Enabled bool
}
type Cluster struct {
Name string
}
// LBPage is the page returned by a pager when traversing over a collection of
// LBs.
type LBPage struct {
pagination.LinkedPageBase
}
// IsEmpty checks whether a NetworkPage struct is empty.
func (p LBPage) IsEmpty() (bool, error) {
is, err := ExtractLBs(p)
if err != nil {
return true, nil
}
return len(is) == 0, nil
}
// ExtractLBs accepts a Page struct, specifically a LBPage struct, and extracts
// the elements into a slice of LoadBalancer structs. In other words, a generic
// collection is mapped into a relevant slice.
func ExtractLBs(page pagination.Page) ([]LoadBalancer, error) {
var resp struct {
LBs []LoadBalancer `mapstructure:"loadBalancers" json:"loadBalancers"`
}
err := mapstructure.Decode(page.(LBPage).Body, &resp)
return resp.LBs, err
}
type commonResult struct {
gophercloud.Result
}
// Extract interprets any commonResult as a LB, if possible.
func (r commonResult) Extract() (*LoadBalancer, error) {
if r.Err != nil {
return nil, r.Err
}
var response struct {
LB LoadBalancer `mapstructure:"loadBalancer"`
}
err := mapstructure.Decode(r.Body, &response)
return &response.LB, err
}
type CreateResult struct {
commonResult
}
type DeleteResult struct {
gophercloud.ErrResult
}
type UpdateResult struct {
gophercloud.ErrResult
}
type GetResult struct {
commonResult
}