summaryrefslogtreecommitdiff
path: root/openstackclient/network
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-04-09 04:52:09 +0000
committerGerrit Code Review <review@openstack.org>2016-04-09 04:52:09 +0000
commit6c739466239d6a6565498e5a7bdc25706e91329b (patch)
treec549a701d4c103b056627329efb08dedb24b86fc /openstackclient/network
parentb70afef9d5bfc18ef73163cde48010f3e68dd113 (diff)
parent9e42daa577b0f15c349c2f4a79b3632ffec97720 (diff)
downloadpython-openstackclient-6c739466239d6a6565498e5a7bdc25706e91329b.tar.gz
Merge "Add Subnet add/remove support to router"
Diffstat (limited to 'openstackclient/network')
-rw-r--r--openstackclient/network/v2/router.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/openstackclient/network/v2/router.py b/openstackclient/network/v2/router.py
index cd0f0e4c..6a78be6c 100644
--- a/openstackclient/network/v2/router.py
+++ b/openstackclient/network/v2/router.py
@@ -111,6 +111,33 @@ class AddPortToRouter(command.Command):
parsed_args.router, ignore_missing=False), port_id=port.id)
+class AddSubnetToRouter(command.Command):
+ """Add a subnet to a router"""
+
+ def get_parser(self, prog_name):
+ parser = super(AddSubnetToRouter, self).get_parser(prog_name)
+ parser.add_argument(
+ 'router',
+ metavar='<router>',
+ help="Router to which subnet will be added (name or ID)",
+ )
+ parser.add_argument(
+ 'subnet',
+ metavar='<subnet>',
+ help="Subnet to be added (name or ID)",
+ )
+ return parser
+
+ def take_action(self, parsed_args):
+ client = self.app.client_manager.network
+ subnet = client.find_subnet(parsed_args.subnet,
+ ignore_missing=False)
+ client.router_add_interface(
+ client.find_router(parsed_args.router,
+ ignore_missing=False),
+ subnet_id=subnet.id)
+
+
class CreateRouter(command.ShowOne):
"""Create a new router"""
@@ -268,6 +295,33 @@ class RemovePortFromRouter(command.Command):
parsed_args.router, ignore_missing=False), port_id=port.id)
+class RemoveSubnetFromRouter(command.Command):
+ """Remove a subnet from a router"""
+
+ def get_parser(self, prog_name):
+ parser = super(RemoveSubnetFromRouter, self).get_parser(prog_name)
+ parser.add_argument(
+ 'router',
+ metavar='<router>',
+ help="Router from which the subnet will be removed (name or ID)",
+ )
+ parser.add_argument(
+ 'subnet',
+ metavar='<subnet>',
+ help="Subnet to be removed (name or ID)",
+ )
+ return parser
+
+ def take_action(self, parsed_args):
+ client = self.app.client_manager.network
+ subnet = client.find_subnet(parsed_args.subnet,
+ ignore_missing=False)
+ client.router_remove_interface(
+ client.find_router(parsed_args.router,
+ ignore_missing=False),
+ subnet_id=subnet.id)
+
+
class SetRouter(command.Command):
"""Set router properties"""