Documentation ¶
Index ¶
- Constants
- type Client
- func (c *Client) AllocateFloatingIPV2(floatingNetworkId string) (*FloatingIPV2, error)
- func (c *Client) CreateSecurityGroupRuleV2(ruleInfo RuleInfoV2) (*SecurityGroupRuleV2, error)
- func (c *Client) CreateSecurityGroupV2(name, description string) (*SecurityGroupV2, error)
- func (c *Client) DeleteFloatingIPV2(ipId string) error
- func (c *Client) DeleteSecurityGroupRuleV2(ruleId string) error
- func (c *Client) DeleteSecurityGroupV2(groupId string) error
- func (c *Client) GetFloatingIPV2(ipId string) (*FloatingIPV2, error)
- func (c *Client) GetNetworkV2(netID string) (*NetworkV2, error)
- func (c *Client) GetSubnetV2(subnetID string) (*SubnetV2, error)
- func (c *Client) ListFloatingIPsV2() ([]FloatingIPV2, error)
- func (c *Client) ListNetworksV2(filter ...*Filter) ([]NetworkV2, error)
- func (c *Client) ListSecurityGroupsV2() ([]SecurityGroupV2, error)
- func (c *Client) ListSubnetsV2() ([]SubnetV2, error)
- func (c *Client) SecurityGroupByNameV2(name string) ([]SecurityGroupV2, error)
- func (c *Client) UpdateSecurityGroupV2(groupId, name, description string) (*SecurityGroupV2, error)
- type Filter
- type FloatingIPV2
- type NetworkV2
- type RuleInfoV2
- type SecurityGroupRuleV2
- type SecurityGroupV2
- type SubnetV2
Constants ¶
const ( ApiFloatingIPsV2 = "floatingips" ApiNetworksV2 = "networks" ApiSubnetsV2 = "subnets" ApiSecurityGroupsV2 = "security-groups" ApiSecurityGroupRulesV2 = "security-group-rules" )
const ( FilterRouterExternal = "router:external" // The router:external FilterNetwork = "name" // The network name. )
Filter keys for Networks. As of the Newton release of OpenStack, Network filter by subnet was not implemented
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client provides a means to access the OpenStack Network Service.
func (*Client) AllocateFloatingIPV2 ¶
func (c *Client) AllocateFloatingIPV2(floatingNetworkId string) (*FloatingIPV2, error)
AllocateFloatingIPV2 allocates a new floating IP address in the given external network.
func (*Client) CreateSecurityGroupRuleV2 ¶
func (c *Client) CreateSecurityGroupRuleV2(ruleInfo RuleInfoV2) (*SecurityGroupRuleV2, error)
CreateSecurityGroupRuleV2 creates a security group rule. It can either be an ingress rule or group rule (see the description of SecurityGroupRuleV2).
func (*Client) CreateSecurityGroupV2 ¶
func (c *Client) CreateSecurityGroupV2(name, description string) (*SecurityGroupV2, error)
CreateSecurityGroupV2 creates a new security group.
func (*Client) DeleteFloatingIPV2 ¶
DeleteFloatingIPV2 deallocates the floating IP address associated with the specified id.
func (*Client) DeleteSecurityGroupRuleV2 ¶
DeleteSecurityGroupRuleV2 deletes the specified security group rule.
func (*Client) DeleteSecurityGroupV2 ¶
DeleteSecurityGroupV2 deletes the specified security group.
func (*Client) GetFloatingIPV2 ¶
func (c *Client) GetFloatingIPV2(ipId string) (*FloatingIPV2, error)
GetFloatingIPV2 lists details of the floating IP address associated with specified id.
func (*Client) GetNetworkV2 ¶
GetNetworkV2 gives details on a specific network
func (*Client) GetSubnetV2 ¶
GetSubnetV2 gives details on a specific subnet
func (*Client) ListFloatingIPsV2 ¶
func (c *Client) ListFloatingIPsV2() ([]FloatingIPV2, error)
ListFloatingIPsV2 lists floating IP addresses associated with the tenant or account.
func (*Client) ListNetworksV2 ¶
ListNetworksV2 gives details on available networks, zero or one Filters accepted, any more will be ignored.
TODO(hml): when this package revs to a new version, make this the same as other methods with Filters. We don't want to break compatibility at this time or rev the package at this time.
func (*Client) ListSecurityGroupsV2 ¶
func (c *Client) ListSecurityGroupsV2() ([]SecurityGroupV2, error)
ListSecurityGroupsV2 lists IDs, names, and other details for all security groups.
func (*Client) ListSubnetsV2 ¶
ListSubnetsV2 gives details on available subnets
func (*Client) SecurityGroupByNameV2 ¶
func (c *Client) SecurityGroupByNameV2(name string) ([]SecurityGroupV2, error)
SecurityGroupByNameV2 returns the named security group. OpenStack now supports filtering with API calls. More than one Security Group may be returned, as names are not unique e.g. name=default
func (*Client) UpdateSecurityGroupV2 ¶
func (c *Client) UpdateSecurityGroupV2(groupId, name, description string) (*SecurityGroupV2, error)
UpdateSecurityGroupV2 updates the name and description of the given group.
type Filter ¶
type Filter struct {
// contains filtered or unexported fields
}
---------------------------------------------------------------------------- Filter builds filtering parameters to be used in an OpenStack query which supports filtering. For example:
filter := NewFilter() filter.Set(neutron.FilterRouterExternal, "true") resp, err := neutron.ListNetworks(filter)
TODO(hml): copied from the nova package. However it should really be pulled out and shared between goose pkgs, but we don't want to break compatibility or rev the package at this time.
type FloatingIPV2 ¶
type FloatingIPV2 struct { // FixedIP holds the private IP address of the machine (when assigned) FixedIP string `json:"fixed_ip_address"` Id string `json:"id"` IP string `json:"floating_ip_address"` FloatingNetworkId string `json:"floating_network_id"` }
FloatingIPV2 contains details about a floating ip
type NetworkV2 ¶
type NetworkV2 struct { Id string `json:"id"` // UUID of the resource Name string // User-provided name for the network range SubnetIds []string `json:"subnets"` // an array of subnet UUIDs External bool `json:"router:external"` // is this network connected to an external router AvailabilityZones []string `json:"availability_zones"` TenantId string `json:"tenant_id"` }
NetworkV2 contains details about a labeled network
type RuleInfoV2 ¶
type RuleInfoV2 struct { // Ingress or egress, which is the direction in which the metering // rule is applied. Required. Direction string `json:"direction"` // IPProtocol is optional, and if specified must be "tcp", "udp" or // "icmp" (in the case of icmp, both PortRangeMax and PortRangeMin should // be blank). IPProtocol string `json:"protocol,omitempty"` // The maximum port number in the range that is matched by the // security group rule. The port_range_min attribute constrains // the port_range_max attribute. If the protocol is ICMP, this // value must be an ICMP type. PortRangeMax int `json:"port_range_max,omitempty"` // The minimum port number in the range that is matched by the // security group rule. If the protocol is TCP or UDP, this value // must be less than or equal to the port_range_max attribute value. // If the protocol is ICMP, this value must be an ICMP type. PortRangeMin int `json:"port_range_min,omitempty"` EthernetType string `json:"ethertype,omitempty"` // Cidr for ICMP RemoteIPPrefix string `json:"remote_ip_prefix"` // ParentGroupId is always required and specifies the group to which // the rule is added. ParentGroupId string `json:"security_group_id"` RemoteGroupId string `json:"remote_group_id,omitempty"` }
RuleInfoV2 allows the callers of CreateSecurityGroupRuleV2() to create 2 types of security group rules: ingress rules and egress rules. Security Groups are applied on neutron ports.
Each tenant/project has a default security group with a rule which allows intercommunication among hosts associated with the default security group. As a result, all egress traffic and intercommunication in the default group are allowed and all ingress from outside of the default group is dropped by default (in the default security group).
If no ingress rule is defined, all inbound traffic is dropped. If no egress rule is defined, all outbound traffic is dropped.
For more information: http://docs.openstack.org/developer/neutron/devref/security_group_api.html https://wiki.openstack.org/wiki/Neutron/SecurityGroups Neutron source: https://github.com/openstack/neutron.git
type SecurityGroupRuleV2 ¶
type SecurityGroupRuleV2 struct { PortRangeMax *int `json:"port_range_max"` // Can be nil PortRangeMin *int `json:"port_range_min"` // Can be nil IPProtocol *string `json:"protocol"` // Can be nil, must be defined if PortRange is used ParentGroupId string `json:"security_group_id"` RemoteIPPrefix string `json:"remote_ip_prefix"` RemoteGroupID string `json:"remote_group_id"` EthernetType string `json:"ethertype"` Direction string `json:"direction"` // Required Id string `json:",omitempty"` TenantId string `json:"tenant_id,omitempty"` }
SecurityGroupRuleV2 describes a rule of a security group. There are 2 basic rule types: ingress and egress rules (see RuleInfo struct).
type SecurityGroupV2 ¶
type SecurityGroupV2 struct { Rules []SecurityGroupRuleV2 `json:"security_group_rules"` TenantId string `json:"tenant_id"` Id string `json:"id"` Name string `json:"name"` Description string `json:"description"` }
SecurityGroupV2 describes a single security group in OpenStack.
type SubnetV2 ¶
type SubnetV2 struct { Id string `json:"id"` // UUID of the resource NetworkId string `json:"network_id"` // UUID of the related network Name string `json:"name"` // User-provided name for the subnet Cidr string `json:"cidr"` // IP range covered by the subnet AllocationPools []interface{} `json:"allocation_pools"` TenantId string `json:"tenant_id"` }
SubnetV2 contains details about a labeled subnet