packer-cn/vendor/github.com/oracle/oci-go-sdk/loadbalancer/load_balancer.go

110 lines
5.3 KiB
Go

// Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
// Code generated. DO NOT EDIT.
// Load Balancing Service API
//
// API for the Load Balancing Service
//
package loadbalancer
import (
"github.com/oracle/oci-go-sdk/common"
)
// LoadBalancer The properties that define a load balancer. For more information, see
// Managing a Load Balancer (https://docs.us-phoenix-1.oraclecloud.com/Content/Balance/Tasks/managingloadbalancer.htm).
// To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized,
// talk to an administrator. If you're an administrator who needs to write policies to give users access, see
// Getting Started with Policies (https://docs.us-phoenix-1.oraclecloud.com/Content/Identity/Concepts/policygetstarted.htm).
// For information about endpoints and signing API requests, see
// About the API (https://docs.us-phoenix-1.oraclecloud.com/Content/API/Concepts/usingapi.htm). For information about available SDKs and tools, see
// SDKS and Other Tools (https://docs.us-phoenix-1.oraclecloud.com/Content/API/Concepts/sdks.htm).
type LoadBalancer struct {
// The OCID (https://docs.us-phoenix-1.oraclecloud.com/Content/General/Concepts/identifiers.htm) of the compartment containing the load balancer.
CompartmentId *string `mandatory:"true" json:"compartmentId"`
// A user-friendly name. It does not have to be unique, and it is changeable.
// Example: `example_load_balancer`
DisplayName *string `mandatory:"true" json:"displayName"`
// The OCID (https://docs.us-phoenix-1.oraclecloud.com/Content/General/Concepts/identifiers.htm) of the load balancer.
Id *string `mandatory:"true" json:"id"`
// The current state of the load balancer.
LifecycleState LoadBalancerLifecycleStateEnum `mandatory:"true" json:"lifecycleState"`
// A template that determines the total pre-provisioned bandwidth (ingress plus egress).
// To get a list of available shapes, use the ListShapes
// operation.
// Example: `100Mbps`
ShapeName *string `mandatory:"true" json:"shapeName"`
// The date and time the load balancer was created, in the format defined by RFC3339.
// Example: `2016-08-25T21:10:29.600Z`
TimeCreated *common.SDKTime `mandatory:"true" json:"timeCreated"`
BackendSets map[string]BackendSet `mandatory:"false" json:"backendSets"`
Certificates map[string]Certificate `mandatory:"false" json:"certificates"`
Hostnames map[string]Hostname `mandatory:"false" json:"hostnames"`
// An array of IP addresses.
IpAddresses []IpAddress `mandatory:"false" json:"ipAddresses"`
// Whether the load balancer has a VCN-local (private) IP address.
// If "true", the service assigns a private IP address to the load balancer. The load balancer requires only one subnet
// to host both the primary and secondary load balancers. The private IP address is local to the subnet. The load balancer
// is accessible only from within the VCN that contains the associated subnet, or as further restricted by your security
// list rules. The load balancer can route traffic to any backend server that is reachable from the VCN.
// For a private load balancer, both the primary and secondary load balancer hosts are within the same Availability Domain.
// If "false", the service assigns a public IP address to the load balancer. A load balancer with a public IP address
// requires two subnets, each in a different Availability Domain. One subnet hosts the primary load balancer and the other
// hosts the secondary (standby) load balancer. A public load balancer is accessible from the internet, depending on your
// VCN's security list rules (https://docs.us-phoenix-1.oraclecloud.com/Content/Network/Concepts/securitylists.htm).
// Example: `true`
IsPrivate *bool `mandatory:"false" json:"isPrivate"`
Listeners map[string]Listener `mandatory:"false" json:"listeners"`
PathRouteSets map[string]PathRouteSet `mandatory:"false" json:"pathRouteSets"`
// An array of subnet OCIDs (https://docs.us-phoenix-1.oraclecloud.com/Content/General/Concepts/identifiers.htm).
SubnetIds []string `mandatory:"false" json:"subnetIds"`
}
func (m LoadBalancer) String() string {
return common.PointerString(m)
}
// LoadBalancerLifecycleStateEnum Enum with underlying type: string
type LoadBalancerLifecycleStateEnum string
// Set of constants representing the allowable values for LoadBalancerLifecycleState
const (
LoadBalancerLifecycleStateCreating LoadBalancerLifecycleStateEnum = "CREATING"
LoadBalancerLifecycleStateFailed LoadBalancerLifecycleStateEnum = "FAILED"
LoadBalancerLifecycleStateActive LoadBalancerLifecycleStateEnum = "ACTIVE"
LoadBalancerLifecycleStateDeleting LoadBalancerLifecycleStateEnum = "DELETING"
LoadBalancerLifecycleStateDeleted LoadBalancerLifecycleStateEnum = "DELETED"
)
var mappingLoadBalancerLifecycleState = map[string]LoadBalancerLifecycleStateEnum{
"CREATING": LoadBalancerLifecycleStateCreating,
"FAILED": LoadBalancerLifecycleStateFailed,
"ACTIVE": LoadBalancerLifecycleStateActive,
"DELETING": LoadBalancerLifecycleStateDeleting,
"DELETED": LoadBalancerLifecycleStateDeleted,
}
// GetLoadBalancerLifecycleStateEnumValues Enumerates the set of values for LoadBalancerLifecycleState
func GetLoadBalancerLifecycleStateEnumValues() []LoadBalancerLifecycleStateEnum {
values := make([]LoadBalancerLifecycleStateEnum, 0)
for _, v := range mappingLoadBalancerLifecycleState {
values = append(values, v)
}
return values
}