Merge "CRUD for VPN endpoint group API"
This commit is contained in:
100
neutronclient/neutron/v2_0/vpn/endpoint_group.py
Normal file
100
neutronclient/neutron/v2_0/vpn/endpoint_group.py
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
# (c) Copyright 2015 Cisco Systems, Inc.
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
from neutronclient.i18n import _
|
||||||
|
from neutronclient.neutron import v2_0 as neutronv20
|
||||||
|
|
||||||
|
|
||||||
|
def add_known_endpoint_group_arguments(parser, is_create=True):
|
||||||
|
parser.add_argument(
|
||||||
|
'--name',
|
||||||
|
help=_('Set a name for the endpoint group.'))
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
help=_('Set a description for the endpoint group.'))
|
||||||
|
if is_create:
|
||||||
|
parser.add_argument(
|
||||||
|
'--type',
|
||||||
|
required=is_create,
|
||||||
|
help=_('Type of endpoints in group (e.g. subnet, cidr, vlan).'))
|
||||||
|
parser.add_argument(
|
||||||
|
'--value',
|
||||||
|
action='append', dest='endpoints',
|
||||||
|
required=is_create,
|
||||||
|
help=_('Endpoint(s) for the group. Must all be of the same type.'))
|
||||||
|
|
||||||
|
|
||||||
|
class ListEndpointGroup(neutronv20.ListCommand):
|
||||||
|
"""List VPN endpoint groups that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
list_columns = ['id', 'name', 'type', 'endpoints']
|
||||||
|
_formatters = {}
|
||||||
|
pagination_support = True
|
||||||
|
sorting_support = True
|
||||||
|
|
||||||
|
|
||||||
|
class ShowEndpointGroup(neutronv20.ShowCommand):
|
||||||
|
"""Show a specific VPN endpoint group."""
|
||||||
|
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
|
||||||
|
|
||||||
|
class CreateEndpointGroup(neutronv20.CreateCommand):
|
||||||
|
"""Create a VPN endpoint group."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
|
||||||
|
def add_known_arguments(self, parser):
|
||||||
|
add_known_endpoint_group_arguments(parser)
|
||||||
|
|
||||||
|
def subnet_name2id(self, endpoint):
|
||||||
|
return neutronv20.find_resourceid_by_name_or_id(self.get_client(),
|
||||||
|
'subnet', endpoint)
|
||||||
|
|
||||||
|
def args2body(self, parsed_args):
|
||||||
|
if parsed_args.type == 'subnet':
|
||||||
|
endpoints = [self.subnet_name2id(ep)
|
||||||
|
for ep in parsed_args.endpoints]
|
||||||
|
else:
|
||||||
|
endpoints = parsed_args.endpoints
|
||||||
|
|
||||||
|
body = {'endpoints': endpoints}
|
||||||
|
|
||||||
|
neutronv20.update_dict(parsed_args, body,
|
||||||
|
['name', 'description',
|
||||||
|
'tenant_id', 'type'])
|
||||||
|
return {self.resource: body}
|
||||||
|
|
||||||
|
|
||||||
|
class UpdateEndpointGroup(neutronv20.UpdateCommand):
|
||||||
|
"""Update a given VPN endpoint group."""
|
||||||
|
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
|
||||||
|
def add_known_arguments(self, parser):
|
||||||
|
add_known_endpoint_group_arguments(parser, is_create=False)
|
||||||
|
|
||||||
|
def args2body(self, parsed_args):
|
||||||
|
body = {}
|
||||||
|
neutronv20.update_dict(parsed_args, body,
|
||||||
|
['name', 'description'])
|
||||||
|
return {self.resource: body}
|
||||||
|
|
||||||
|
|
||||||
|
class DeleteEndpointGroup(neutronv20.DeleteCommand):
|
||||||
|
"""Delete a given VPN endpoint group."""
|
||||||
|
|
||||||
|
resource = 'endpoint_group'
|
@@ -81,6 +81,7 @@ from neutronclient.neutron.v2_0 import securitygroup
|
|||||||
from neutronclient.neutron.v2_0 import servicetype
|
from neutronclient.neutron.v2_0 import servicetype
|
||||||
from neutronclient.neutron.v2_0 import subnet
|
from neutronclient.neutron.v2_0 import subnet
|
||||||
from neutronclient.neutron.v2_0 import subnetpool
|
from neutronclient.neutron.v2_0 import subnetpool
|
||||||
|
from neutronclient.neutron.v2_0.vpn import endpoint_group
|
||||||
from neutronclient.neutron.v2_0.vpn import ikepolicy
|
from neutronclient.neutron.v2_0.vpn import ikepolicy
|
||||||
from neutronclient.neutron.v2_0.vpn import ipsec_site_connection
|
from neutronclient.neutron.v2_0.vpn import ipsec_site_connection
|
||||||
from neutronclient.neutron.v2_0.vpn import ipsecpolicy
|
from neutronclient.neutron.v2_0.vpn import ipsecpolicy
|
||||||
@@ -332,6 +333,11 @@ COMMAND_V2 = {
|
|||||||
'ipsec-site-connection-delete': (
|
'ipsec-site-connection-delete': (
|
||||||
ipsec_site_connection.DeleteIPsecSiteConnection
|
ipsec_site_connection.DeleteIPsecSiteConnection
|
||||||
),
|
),
|
||||||
|
'vpn-endpoint-group-list': endpoint_group.ListEndpointGroup,
|
||||||
|
'vpn-endpoint-group-show': endpoint_group.ShowEndpointGroup,
|
||||||
|
'vpn-endpoint-group-create': endpoint_group.CreateEndpointGroup,
|
||||||
|
'vpn-endpoint-group-update': endpoint_group.UpdateEndpointGroup,
|
||||||
|
'vpn-endpoint-group-delete': endpoint_group.DeleteEndpointGroup,
|
||||||
'vpn-service-list': vpnservice.ListVPNService,
|
'vpn-service-list': vpnservice.ListVPNService,
|
||||||
'vpn-service-show': vpnservice.ShowVPNService,
|
'vpn-service-show': vpnservice.ShowVPNService,
|
||||||
'vpn-service-create': vpnservice.CreateVPNService,
|
'vpn-service-create': vpnservice.CreateVPNService,
|
||||||
|
148
neutronclient/tests/unit/vpn/test_cli20_endpoint_group.py
Normal file
148
neutronclient/tests/unit/vpn/test_cli20_endpoint_group.py
Normal file
@@ -0,0 +1,148 @@
|
|||||||
|
# (c) Copyright 2015 Cisco Systems, Inc.
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from neutronclient.neutron.v2_0.vpn import endpoint_group
|
||||||
|
from neutronclient.tests.unit import test_cli20
|
||||||
|
|
||||||
|
|
||||||
|
class CLITestV20VpnEndpointGroupJSON(test_cli20.CLITestV20Base):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
super(CLITestV20VpnEndpointGroupJSON, self).setUp()
|
||||||
|
self.register_non_admin_status_resource('endpoint_group')
|
||||||
|
|
||||||
|
def test_create_endpoint_group_with_cidrs(self):
|
||||||
|
"""vpn-endpoint-group-create with CIDR endpoints."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.CreateEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
tenant_id = 'mytenant-id'
|
||||||
|
my_id = 'my-id'
|
||||||
|
name = 'my-endpoint-group'
|
||||||
|
description = 'my endpoint group'
|
||||||
|
endpoint_type = 'cidr'
|
||||||
|
endpoints = ['10.0.0.0/24', '20.0.0.0/24']
|
||||||
|
|
||||||
|
args = ['--name', name,
|
||||||
|
'--description', description,
|
||||||
|
'--tenant-id', tenant_id,
|
||||||
|
'--type', endpoint_type,
|
||||||
|
'--value', '10.0.0.0/24',
|
||||||
|
'--value', '20.0.0.0/24']
|
||||||
|
|
||||||
|
position_names = ['name', 'description', 'tenant_id',
|
||||||
|
'type', 'endpoints']
|
||||||
|
|
||||||
|
position_values = [name, description, tenant_id,
|
||||||
|
endpoint_type, endpoints]
|
||||||
|
|
||||||
|
self._test_create_resource(resource, cmd, name, my_id, args,
|
||||||
|
position_names, position_values)
|
||||||
|
|
||||||
|
def test_create_endpoint_group_with_subnets(self):
|
||||||
|
"""vpn-endpoint-group-create with subnet endpoints."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.CreateEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
tenant_id = 'mytenant-id'
|
||||||
|
my_id = 'my-id'
|
||||||
|
endpoint_type = 'subnet'
|
||||||
|
subnet = 'subnet-id'
|
||||||
|
endpoints = [subnet]
|
||||||
|
|
||||||
|
args = ['--type', endpoint_type,
|
||||||
|
'--value', subnet,
|
||||||
|
'--tenant-id', tenant_id]
|
||||||
|
|
||||||
|
position_names = ['type', 'endpoints', 'tenant_id']
|
||||||
|
|
||||||
|
position_values = [endpoint_type, endpoints, tenant_id]
|
||||||
|
|
||||||
|
self._test_create_resource(resource, cmd, None, my_id, args,
|
||||||
|
position_names, position_values)
|
||||||
|
|
||||||
|
def test_list_endpoint_group(self):
|
||||||
|
"""vpn-endpoint-group-list."""
|
||||||
|
resources = "endpoint_groups"
|
||||||
|
cmd = endpoint_group.ListEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
self._test_list_resources(resources, cmd, True)
|
||||||
|
|
||||||
|
def test_list_endpoint_group_pagination(self):
|
||||||
|
"""vpn-endpoint-group-list."""
|
||||||
|
resources = "endpoint_groups"
|
||||||
|
cmd = endpoint_group.ListEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
self._test_list_resources_with_pagination(resources, cmd)
|
||||||
|
|
||||||
|
def test_list_endpoint_group_sort(self):
|
||||||
|
"""vpn-endpoint-group-list --sort-key name --sort-key id
|
||||||
|
--sort-key asc --sort-key desc
|
||||||
|
"""
|
||||||
|
resources = "endpoint_groups"
|
||||||
|
cmd = endpoint_group.ListEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
self._test_list_resources(resources, cmd,
|
||||||
|
sort_key=["name", "id"],
|
||||||
|
sort_dir=["asc", "desc"])
|
||||||
|
|
||||||
|
def test_list_endpoint_group_limit(self):
|
||||||
|
"""vpn-endpoint-group-list -P."""
|
||||||
|
resources = "endpoint_groups"
|
||||||
|
cmd = endpoint_group.ListEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
self._test_list_resources(resources, cmd, page_size=1000)
|
||||||
|
|
||||||
|
def test_show_endpoint_group_id(self):
|
||||||
|
"""vpn-endpoint-group-show test_id."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.ShowEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
args = ['--fields', 'id', self.test_id]
|
||||||
|
self._test_show_resource(resource, cmd, self.test_id, args, ['id'])
|
||||||
|
|
||||||
|
def test_show_endpoint_group_id_name(self):
|
||||||
|
"""vpn-endpoint-group-show."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.ShowEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
args = ['--fields', 'id', '--fields', 'name', self.test_id]
|
||||||
|
self._test_show_resource(resource, cmd, self.test_id,
|
||||||
|
args, ['id', 'name'])
|
||||||
|
|
||||||
|
def test_update_endpoint_group(self):
|
||||||
|
"""vpn-endpoint-group-update myid --name newname
|
||||||
|
--description newdesc.
|
||||||
|
"""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.UpdateEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
self._test_update_resource(resource, cmd, 'myid',
|
||||||
|
['myid', '--name', 'newname',
|
||||||
|
'--description', 'newdesc'],
|
||||||
|
{'name': 'newname',
|
||||||
|
'description': 'newdesc'})
|
||||||
|
|
||||||
|
def test_delete_endpoint_group(self):
|
||||||
|
"""vpn-endpoint-group-delete my-id."""
|
||||||
|
resource = 'endpoint_group'
|
||||||
|
cmd = endpoint_group.DeleteEndpointGroup(test_cli20.MyApp(sys.stdout),
|
||||||
|
None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
args = [my_id]
|
||||||
|
self._test_delete_resource(resource, cmd, my_id, args)
|
@@ -355,6 +355,8 @@ class Client(ClientBase):
|
|||||||
security_group_path = "/security-groups/%s"
|
security_group_path = "/security-groups/%s"
|
||||||
security_group_rules_path = "/security-group-rules"
|
security_group_rules_path = "/security-group-rules"
|
||||||
security_group_rule_path = "/security-group-rules/%s"
|
security_group_rule_path = "/security-group-rules/%s"
|
||||||
|
endpoint_groups_path = "/vpn/endpoint-groups"
|
||||||
|
endpoint_group_path = "/vpn/endpoint-groups/%s"
|
||||||
vpnservices_path = "/vpn/vpnservices"
|
vpnservices_path = "/vpn/vpnservices"
|
||||||
vpnservice_path = "/vpn/vpnservices/%s"
|
vpnservice_path = "/vpn/vpnservices/%s"
|
||||||
ipsecpolicies_path = "/vpn/ipsecpolicies"
|
ipsecpolicies_path = "/vpn/ipsecpolicies"
|
||||||
@@ -447,6 +449,7 @@ class Client(ClientBase):
|
|||||||
'ikepolicies': 'ikepolicy',
|
'ikepolicies': 'ikepolicy',
|
||||||
'ipsec_site_connections': 'ipsec_site_connection',
|
'ipsec_site_connections': 'ipsec_site_connection',
|
||||||
'vpnservices': 'vpnservice',
|
'vpnservices': 'vpnservice',
|
||||||
|
'endpoint_groups': 'endpoint_group',
|
||||||
'vips': 'vip',
|
'vips': 'vip',
|
||||||
'pools': 'pool',
|
'pools': 'pool',
|
||||||
'members': 'member',
|
'members': 'member',
|
||||||
@@ -802,6 +805,33 @@ class Client(ClientBase):
|
|||||||
return self.get(self.security_group_rule_path % (security_group_rule),
|
return self.get(self.security_group_rule_path % (security_group_rule),
|
||||||
params=_params)
|
params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_endpoint_groups(self, retrieve_all=True, **_params):
|
||||||
|
"""Fetches a list of all VPN endpoint groups for a tenant."""
|
||||||
|
return self.list('endpoint_groups', self.endpoint_groups_path,
|
||||||
|
retrieve_all, **_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_endpoint_group(self, endpointgroup, **_params):
|
||||||
|
"""Fetches information for a specific VPN endpoint group."""
|
||||||
|
return self.get(self.endpoint_group_path % endpointgroup,
|
||||||
|
params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def create_endpoint_group(self, body=None):
|
||||||
|
"""Creates a new VPN endpoint group."""
|
||||||
|
return self.post(self.endpoint_groups_path, body=body)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def update_endpoint_group(self, endpoint_group, body=None):
|
||||||
|
"""Updates a VPN endpoint group."""
|
||||||
|
return self.put(self.endpoint_group_path % endpoint_group, body=body)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def delete_endpoint_group(self, endpoint_group):
|
||||||
|
"""Deletes the specified VPN endpoint group."""
|
||||||
|
return self.delete(self.endpoint_group_path % endpoint_group)
|
||||||
|
|
||||||
@APIParamsCall
|
@APIParamsCall
|
||||||
def list_vpnservices(self, retrieve_all=True, **_params):
|
def list_vpnservices(self, retrieve_all=True, **_params):
|
||||||
"""Fetches a list of all configured VPN services for a tenant."""
|
"""Fetches a list of all configured VPN services for a tenant."""
|
||||||
|
Reference in New Issue
Block a user