Removed all extension functionality from core package
diff --git a/acceptance/openstack/networking/v2/network_test.go b/acceptance/openstack/networking/v2/network_test.go
index 7228015..4e37fc0 100644
--- a/acceptance/openstack/networking/v2/network_test.go
+++ b/acceptance/openstack/networking/v2/network_test.go
@@ -48,11 +48,7 @@
th.AssertEquals(t, n.Status, "ACTIVE")
th.AssertDeepEquals(t, n.Subnets, []string{})
th.AssertEquals(t, n.Name, "sample_network")
- th.AssertEquals(t, n.ProviderPhysicalNetwork, "")
- th.AssertEquals(t, n.ProviderNetworkType, "local")
- th.AssertEquals(t, n.ProviderSegmentationID, 0)
th.AssertEquals(t, n.AdminStateUp, true)
- th.AssertEquals(t, n.RouterExternal, false)
th.AssertEquals(t, n.Shared, false)
th.AssertEquals(t, n.ID, networkID)
diff --git a/openstack/networking/v2/networks/requests.go b/openstack/networking/v2/networks/requests.go
index f4fbe97..f87ea87 100644
--- a/openstack/networking/v2/networks/requests.go
+++ b/openstack/networking/v2/networks/requests.go
@@ -113,7 +113,7 @@
// The tenant ID that is contained in the URI is the tenant that creates the
// network. An admin user, however, has the option of specifying another tenant
// ID in the CreateOpts struct.
-func Create(c *gophercloud.ServiceClient, opts CreateOpts) (*NetworkCreateResult, error) {
+func Create(c *gophercloud.ServiceClient, opts CreateOpts) (*Network, error) {
// Define structures
type network struct {
AdminStateUp bool `json:"admin_state_up,omitempty"`
@@ -125,7 +125,7 @@
Network network `json:"network"`
}
type response struct {
- Network *NetworkCreateResult `json:"network"`
+ Network *Network `json:"network"`
}
// Populate request body
diff --git a/openstack/networking/v2/networks/requests_test.go b/openstack/networking/v2/networks/requests_test.go
index b637b50..1b309a0 100644
--- a/openstack/networking/v2/networks/requests_test.go
+++ b/openstack/networking/v2/networks/requests_test.go
@@ -41,14 +41,10 @@
"54d6f61d-db07-451c-9ab3-b9609b6b6f0b"
],
"name": "private-network",
- "provider:physical_network": null,
"admin_state_up": true,
"tenant_id": "4fd44f30292945e481c7b8a0c8908869",
- "provider:network_type": "local",
- "router:external": true,
"shared": true,
- "id": "d32019d3-bc6e-4319-9c1d-6722fc136a22",
- "provider:segmentation_id": null
+ "id": "d32019d3-bc6e-4319-9c1d-6722fc136a22"
},
{
"status": "ACTIVE",
@@ -56,14 +52,10 @@
"08eae331-0402-425a-923c-34f7cfe39c1b"
],
"name": "private",
- "provider:physical_network": null,
"admin_state_up": true,
"tenant_id": "26a7980765d0414dbc1fc1f88cdb7e6e",
- "provider:network_type": "local",
- "router:external": true,
"shared": true,
- "id": "db193ab3-96e3-4cb3-8fc5-05f4296d0324",
- "provider:segmentation_id": null
+ "id": "db193ab3-96e3-4cb3-8fc5-05f4296d0324"
}
]
}
@@ -83,30 +75,22 @@
expected := []Network{
Network{
- Status: "ACTIVE",
- Subnets: []string{"54d6f61d-db07-451c-9ab3-b9609b6b6f0b"},
- Name: "private-network",
- ProviderPhysicalNetwork: "",
- AdminStateUp: true,
- TenantID: "4fd44f30292945e481c7b8a0c8908869",
- ProviderNetworkType: "local",
- RouterExternal: true,
- Shared: true,
- ID: "d32019d3-bc6e-4319-9c1d-6722fc136a22",
- ProviderSegmentationID: 0,
+ Status: "ACTIVE",
+ Subnets: []string{"54d6f61d-db07-451c-9ab3-b9609b6b6f0b"},
+ Name: "private-network",
+ AdminStateUp: true,
+ TenantID: "4fd44f30292945e481c7b8a0c8908869",
+ Shared: true,
+ ID: "d32019d3-bc6e-4319-9c1d-6722fc136a22",
},
Network{
- Status: "ACTIVE",
- Subnets: []string{"08eae331-0402-425a-923c-34f7cfe39c1b"},
- Name: "private",
- ProviderPhysicalNetwork: "",
- AdminStateUp: true,
- TenantID: "26a7980765d0414dbc1fc1f88cdb7e6e",
- ProviderNetworkType: "local",
- RouterExternal: true,
- Shared: true,
- ID: "db193ab3-96e3-4cb3-8fc5-05f4296d0324",
- ProviderSegmentationID: 0,
+ Status: "ACTIVE",
+ Subnets: []string{"08eae331-0402-425a-923c-34f7cfe39c1b"},
+ Name: "private",
+ AdminStateUp: true,
+ TenantID: "26a7980765d0414dbc1fc1f88cdb7e6e",
+ Shared: true,
+ ID: "db193ab3-96e3-4cb3-8fc5-05f4296d0324",
},
}
@@ -139,14 +123,10 @@
"54d6f61d-db07-451c-9ab3-b9609b6b6f0b"
],
"name": "private-network",
- "provider:physical_network": null,
"admin_state_up": true,
"tenant_id": "4fd44f30292945e481c7b8a0c8908869",
- "provider:network_type": "local",
- "router:external": true,
"shared": true,
- "id": "d32019d3-bc6e-4319-9c1d-6722fc136a22",
- "provider:segmentation_id": null
+ "id": "d32019d3-bc6e-4319-9c1d-6722fc136a22"
}
}
`)
@@ -158,12 +138,8 @@
th.AssertEquals(t, n.Status, "ACTIVE")
th.AssertDeepEquals(t, n.Subnets, []string{"54d6f61d-db07-451c-9ab3-b9609b6b6f0b"})
th.AssertEquals(t, n.Name, "private-network")
- th.AssertEquals(t, n.ProviderPhysicalNetwork, "")
- th.AssertEquals(t, n.ProviderNetworkType, "local")
- th.AssertEquals(t, n.ProviderSegmentationID, 0)
th.AssertEquals(t, n.AdminStateUp, true)
th.AssertEquals(t, n.TenantID, "4fd44f30292945e481c7b8a0c8908869")
- th.AssertEquals(t, n.RouterExternal, true)
th.AssertEquals(t, n.Shared, true)
th.AssertEquals(t, n.ID, "d32019d3-bc6e-4319-9c1d-6722fc136a22")
}
@@ -197,20 +173,7 @@
"name": "net1",
"admin_state_up": true,
"tenant_id": "9bacb3c5d39d41a79512987f338cf177",
- "segments": [
- {
- "provider:segmentation_id": 2,
- "provider:physical_network": "8bab8453-1bc9-45af-8c70-f83aa9b50453",
- "provider:network_type": "vlan"
- },
- {
- "provider:segmentation_id": null,
- "provider:physical_network": "8bab8453-1bc9-45af-8c70-f83aa9b50453",
- "provider:network_type": "stt"
- }
- ],
"shared": false,
- "port_security_enabled": true,
"id": "4e8e5957-649f-477b-9e5b-f1f75b21c03c"
}
}
@@ -226,12 +189,7 @@
th.AssertEquals(t, n.Name, "net1")
th.AssertEquals(t, n.AdminStateUp, true)
th.AssertEquals(t, n.TenantID, "9bacb3c5d39d41a79512987f338cf177")
- th.AssertDeepEquals(t, n.Segments, []NetworkProvider{
- {ProviderSegmentationID: 2, ProviderPhysicalNetwork: "8bab8453-1bc9-45af-8c70-f83aa9b50453", ProviderNetworkType: "vlan"},
- {ProviderSegmentationID: 0, ProviderPhysicalNetwork: "8bab8453-1bc9-45af-8c70-f83aa9b50453", ProviderNetworkType: "stt"},
- })
th.AssertEquals(t, n.Shared, false)
- th.AssertEquals(t, n.PortSecurityEnabled, true)
th.AssertEquals(t, n.ID, "4e8e5957-649f-477b-9e5b-f1f75b21c03c")
}
@@ -292,14 +250,10 @@
"status": "ACTIVE",
"subnets": [],
"name": "new_network_name",
- "provider:physical_network": null,
"admin_state_up": false,
"tenant_id": "4fd44f30292945e481c7b8a0c8908869",
- "provider:network_type": "local",
- "router:external": false,
"shared": true,
- "id": "4e8e5957-649f-477b-9e5b-f1f75b21c03c",
- "provider:segmentation_id": null
+ "id": "4e8e5957-649f-477b-9e5b-f1f75b21c03c"
}
}
`)
diff --git a/openstack/networking/v2/networks/results.go b/openstack/networking/v2/networks/results.go
index 7f9e51a..03cfb31 100644
--- a/openstack/networking/v2/networks/results.go
+++ b/openstack/networking/v2/networks/results.go
@@ -5,13 +5,6 @@
"github.com/rackspace/gophercloud/pagination"
)
-// NetworkProvider represents provider extension data
-type NetworkProvider struct {
- ProviderSegmentationID int `json:"provider:segmentation_id"`
- ProviderPhysicalNetwork string `json:"provider:physical_network"`
- ProviderNetworkType string `json:"provider:network_type"`
-}
-
// Network represents, well, a network.
type Network struct {
// UUID for the network
@@ -29,18 +22,6 @@
TenantID string `mapstructure:"tenant_id" json:"tenant_id"`
// Specifies whether the network resource can be accessed by any tenant or not.
Shared bool `mapstructure:"shared" json:"shared"`
-
- ProviderSegmentationID int `mapstructure:"provider:segmentation_id" json:"provider:segmentation_id"`
- ProviderPhysicalNetwork string `mapstructure:"provider:physical_network" json:"provider:physical_network"`
- ProviderNetworkType string `mapstructure:"provider:network_type" json:"provider:network_type"`
- RouterExternal bool `mapstructure:"router:external" json:"router:external"`
-}
-
-// NetworkCreateResult represents what is returned by a create operation.
-type NetworkCreateResult struct {
- Network
- Segments []NetworkProvider `json:"segments"`
- PortSecurityEnabled bool `json:"port_security_enabled"`
}
// NetworkPage is the page returned by a pager when traversing over a
diff --git a/openstack/networking/v2/ports/requests_test.go b/openstack/networking/v2/ports/requests_test.go
index 83b0153..6f27e09 100644
--- a/openstack/networking/v2/ports/requests_test.go
+++ b/openstack/networking/v2/ports/requests_test.go
@@ -37,20 +37,11 @@
"status": "ACTIVE",
"binding:host_id": "devstack",
"name": "",
- "allowed_address_pairs": [],
"admin_state_up": true,
"network_id": "70c1db1f-b701-45bd-96e0-a313ee3430b3",
"tenant_id": "",
- "extra_dhcp_opts": [],
- "binding:vif_details": {
- "port_filter": true,
- "ovs_hybrid_plug": true
- },
- "binding:vif_type": "ovs",
"device_owner": "network:router_gateway",
"mac_address": "fa:16:3e:58:42:ed",
- "binding:profile": {},
- "binding:vnic_type": "normal",
"fixed_ips": [
{
"subnet_id": "008ba151-0b8c-4a67-98b5-0d2b87666062",
@@ -78,29 +69,22 @@
expected := []Port{
Port{
- Status: "ACTIVE",
- Name: "",
- AllowedAddressPairs: []interface{}(nil),
- AdminStateUp: true,
- NetworkID: "70c1db1f-b701-45bd-96e0-a313ee3430b3",
- TenantID: "",
- ExtraDHCPOpts: []interface{}{},
- DeviceOwner: "network:router_gateway",
- MACAddress: "fa:16:3e:58:42:ed",
+ Status: "ACTIVE",
+ Name: "",
+ AdminStateUp: true,
+ NetworkID: "70c1db1f-b701-45bd-96e0-a313ee3430b3",
+ TenantID: "",
+ DeviceOwner: "network:router_gateway",
+ MACAddress: "fa:16:3e:58:42:ed",
FixedIPs: []IP{
IP{
SubnetID: "008ba151-0b8c-4a67-98b5-0d2b87666062",
IPAddress: "172.24.4.2",
},
},
- ID: "d80b1a3b-4fc1-49f3-952e-1e2ab7081d8b",
- SecurityGroups: []string{},
- DeviceID: "9ae135f4-b6e0-4dad-9e91-3c223e385824",
- BindingHostID: "devstack",
- BindingVIFDetails: map[string]interface{}{"port_filter": true, "ovs_hybrid_plug": true},
- BindingVIFType: "ovs",
- BindingProfile: map[string]interface{}{},
- BindingVNICType: "normal",
+ ID: "d80b1a3b-4fc1-49f3-952e-1e2ab7081d8b",
+ SecurityGroups: []string{},
+ DeviceID: "9ae135f4-b6e0-4dad-9e91-3c223e385824",
},
}
@@ -129,22 +113,12 @@
{
"port": {
"status": "ACTIVE",
- "binding:host_id": "devstack",
"name": "",
- "allowed_address_pairs": [],
"admin_state_up": true,
"network_id": "a87cc70a-3e15-4acf-8205-9b711a3531b7",
"tenant_id": "7e02058126cc4950b75f9970368ba177",
- "extra_dhcp_opts": [],
- "binding:vif_details": {
- "port_filter": true,
- "ovs_hybrid_plug": true
- },
- "binding:vif_type": "ovs",
"device_owner": "network:router_interface",
"mac_address": "fa:16:3e:23:fd:d7",
- "binding:profile": {},
- "binding:vnic_type": "normal",
"fixed_ips": [
{
"subnet_id": "a0304c3a-4f08-4c43-88af-d796509c97d2",
@@ -163,18 +137,12 @@
th.AssertNoErr(t, err)
th.AssertEquals(t, n.Status, "ACTIVE")
- th.AssertEquals(t, n.BindingHostID, "devstack")
th.AssertEquals(t, n.Name, "")
- th.AssertDeepEquals(t, n.AllowedAddressPairs, []interface{}(nil))
th.AssertEquals(t, n.AdminStateUp, true)
th.AssertEquals(t, n.NetworkID, "a87cc70a-3e15-4acf-8205-9b711a3531b7")
th.AssertEquals(t, n.TenantID, "7e02058126cc4950b75f9970368ba177")
- th.AssertDeepEquals(t, n.ExtraDHCPOpts, []interface{}{})
- th.AssertDeepEquals(t, n.BindingVIFDetails, map[string]interface{}{"port_filter": true, "ovs_hybrid_plug": true})
th.AssertEquals(t, n.DeviceOwner, "network:router_interface")
th.AssertEquals(t, n.MACAddress, "fa:16:3e:23:fd:d7")
- th.AssertDeepEquals(t, n.BindingProfile, map[string]interface{}{})
- th.AssertEquals(t, n.BindingVNICType, "normal")
th.AssertDeepEquals(t, n.FixedIPs, []IP{
IP{SubnetID: "a0304c3a-4f08-4c43-88af-d796509c97d2", IPAddress: "10.0.0.1"},
})
@@ -210,18 +178,13 @@
{
"port": {
"status": "DOWN",
- "binding:host_id": "",
"name": "private-port",
"allowed_address_pairs": [],
"admin_state_up": true,
"network_id": "a87cc70a-3e15-4acf-8205-9b711a3531b7",
"tenant_id": "d6700c0c9ffa4f1cb322cd4a1f3906fa",
- "binding:vif_details": {},
- "binding:vnic_type": "normal",
- "binding:vif_type": "unbound",
"device_owner": "",
"mac_address": "fa:16:3e:c9:cb:f0",
- "binding:profile": {},
"fixed_ips": [
{
"subnet_id": "a0304c3a-4f08-4c43-88af-d796509c97d2",
@@ -244,24 +207,17 @@
th.AssertNoErr(t, err)
th.AssertEquals(t, n.Status, "DOWN")
- th.AssertEquals(t, n.BindingHostID, "")
th.AssertEquals(t, n.Name, "private-port")
- th.AssertDeepEquals(t, n.AllowedAddressPairs, []interface{}(nil))
th.AssertEquals(t, n.AdminStateUp, true)
th.AssertEquals(t, n.NetworkID, "a87cc70a-3e15-4acf-8205-9b711a3531b7")
th.AssertEquals(t, n.TenantID, "d6700c0c9ffa4f1cb322cd4a1f3906fa")
- th.AssertDeepEquals(t, n.BindingVIFDetails, map[string]interface{}{})
th.AssertEquals(t, n.DeviceOwner, "")
th.AssertEquals(t, n.MACAddress, "fa:16:3e:c9:cb:f0")
- th.AssertDeepEquals(t, n.BindingProfile, map[string]interface{}{})
- th.AssertEquals(t, n.BindingVNICType, "normal")
- th.AssertEquals(t, n.BindingVIFType, "unbound")
th.AssertDeepEquals(t, n.FixedIPs, []IP{
IP{SubnetID: "a0304c3a-4f08-4c43-88af-d796509c97d2", IPAddress: "10.0.0.2"},
})
th.AssertEquals(t, n.ID, "65c0ee9f-d634-4522-8954-51021b570b0d")
th.AssertDeepEquals(t, n.SecurityGroups, []string{"f0ac4394-7e4a-4409-9701-ba8be283dbc3"})
- th.AssertEquals(t, n.DeviceID, "")
}
func TestUpdate(t *testing.T) {
@@ -297,18 +253,12 @@
{
"port": {
"status": "DOWN",
- "binding:host_id": "",
"name": "new_port_name",
- "allowed_address_pairs": [],
"admin_state_up": true,
"network_id": "a87cc70a-3e15-4acf-8205-9b711a3531b7",
"tenant_id": "d6700c0c9ffa4f1cb322cd4a1f3906fa",
- "binding:vif_details": {},
- "binding:vnic_type": "normal",
- "binding:vif_type": "unbound",
"device_owner": "",
"mac_address": "fa:16:3e:c9:cb:f0",
- "binding:profile": {},
"fixed_ips": [
{
"subnet_id": "a0304c3a-4f08-4c43-88af-d796509c97d2",
diff --git a/openstack/networking/v2/ports/results.go b/openstack/networking/v2/ports/results.go
index cddb58d..c190ad2 100644
--- a/openstack/networking/v2/ports/results.go
+++ b/openstack/networking/v2/ports/results.go
@@ -38,14 +38,6 @@
SecurityGroups []string `mapstructure:"security_groups" json:"security_groups"`
// Identifies the device (e.g., virtual server) using this port.
DeviceID string `mapstructure:"device_id" json:"device_id"`
-
- AllowedAddressPairs []interface{} `mapstructure:"allowed" json:"allowed"`
- ExtraDHCPOpts interface{} `mapstructure:"extra_dhcp_opts" json:"extra_dhcp_opts"`
- BindingHostID string `mapstructure:"binding:host_id" json:"binding:host_id"`
- BindingVIFDetails interface{} `mapstructure:"binding:vif_details" json:"binding:vif_details"`
- BindingVIFType string `mapstructure:"binding:vif_type" json:"binding:vif_type"`
- BindingProfile interface{} `mapstructure:"binding:profile" json:"binding:profile"`
- BindingVNICType string `mapstructure:"binding:vnic_type" json:"binding:vnic_type"`
}
// PortPage is the page returned by a pager when traversing over a collection
diff --git a/openstack/networking/v2/subnets/requests_test.go b/openstack/networking/v2/subnets/requests_test.go
index 63e9cc2..b2b4d38 100644
--- a/openstack/networking/v2/subnets/requests_test.go
+++ b/openstack/networking/v2/subnets/requests_test.go
@@ -99,7 +99,7 @@
End: "10.0.0.254",
},
},
- HostRoutes: []interface{}{},
+ HostRoutes: []HostRoute{},
IPVersion: 4,
GatewayIP: "10.0.0.1",
CIDR: "10.0.0.0/24",
@@ -117,7 +117,7 @@
End: "192.255.255.254",
},
},
- HostRoutes: []interface{}{},
+ HostRoutes: []HostRoute{},
IPVersion: 4,
GatewayIP: "192.0.0.1",
CIDR: "192.0.0.0/8",
@@ -184,7 +184,7 @@
End: "192.255.255.254",
},
})
- th.AssertDeepEquals(t, s.HostRoutes, []interface{}{})
+ th.AssertDeepEquals(t, s.HostRoutes, []HostRoute{})
th.AssertEquals(t, s.IPVersion, 4)
th.AssertEquals(t, s.GatewayIP, "192.0.0.1")
th.AssertEquals(t, s.CIDR, "192.0.0.0/8")
@@ -252,7 +252,7 @@
End: "192.168.199.254",
},
})
- th.AssertDeepEquals(t, s.HostRoutes, []interface{}{})
+ th.AssertDeepEquals(t, s.HostRoutes, []HostRoute{})
th.AssertEquals(t, s.IPVersion, 4)
th.AssertEquals(t, s.GatewayIP, "192.168.199.1")
th.AssertEquals(t, s.CIDR, "192.168.199.0/24")
diff --git a/openstack/networking/v2/subnets/results.go b/openstack/networking/v2/subnets/results.go
index f89bb3b..ead2172 100644
--- a/openstack/networking/v2/subnets/results.go
+++ b/openstack/networking/v2/subnets/results.go
@@ -5,12 +5,20 @@
"github.com/rackspace/gophercloud/pagination"
)
-// AllocationPool is a sub-struct that represents an allocation pool
+// AllocationPool represents a sub-range of cidr available for dynamic
+// allocation to ports, e.g. {Start: "10.0.0.2", End: "10.0.0.254"}
type AllocationPool struct {
Start string `json:"start"`
End string `json:"end"`
}
+// HostRoute represents a route that should be used by devices with IPs from
+// a subnet (not including local subnet route).
+type HostRoute struct {
+ DestinationCIDR string `json:"destination"`
+ NextHop string `json:"nexthop"`
+}
+
// Subnet represents a subnet. See package documentation for a top-level
// description of what this is.
type Subnet struct {
@@ -31,7 +39,7 @@
// Sub-ranges of CIDR available for dynamic allocation to ports. See AllocationPool.
AllocationPools []AllocationPool `mapstructure:"allocation_pools" json:"allocation_pools"`
// Routes that should be used by devices with IPs from this subnet (not including local subnet route).
- HostRoutes []interface{} `mapstructure:"host_routes" json:"host_routes"`
+ HostRoutes []HostRoute `mapstructure:"host_routes" json:"host_routes"`
// Specifies whether DHCP is enabled for this subnet or not.
EnableDHCP bool `mapstructure:"enable_dhcp" json:"enable_dhcp"`
// Owner of network. Only admin users can specify a tenant_id other than its own.