summaryrefslogtreecommitdiff
path: root/openstackclient/compute/v2
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2017-04-03 20:51:20 +0000
committerGerrit Code Review <review@openstack.org>2017-04-03 20:51:20 +0000
commitd0f368ba0e0793b8dfc800ea0ef7c60b3e94d5df (patch)
treec90fa918e62705a5388e4b003a8756ff02ffe5ad /openstackclient/compute/v2
parente2cd971a03ed8b8bf518b995d32c49a85cae441d (diff)
parent21510ac1a94eeb8de218a0edfe81db5ef0437249 (diff)
downloadpython-openstackclient-d0f368ba0e0793b8dfc800ea0ef7c60b3e94d5df.tar.gz
Merge "Enable to add/remove port to/from a server"
Diffstat (limited to 'openstackclient/compute/v2')
-rw-r--r--openstackclient/compute/v2/server.py66
1 files changed, 66 insertions, 0 deletions
diff --git a/openstackclient/compute/v2/server.py b/openstackclient/compute/v2/server.py
index 3ae75167..13c4c2d8 100644
--- a/openstackclient/compute/v2/server.py
+++ b/openstackclient/compute/v2/server.py
@@ -253,6 +253,39 @@ class AddFloatingIP(command.Command):
parsed_args.fixed_ip_address)
+class AddPort(command.Command):
+ _description = _("Add port to server")
+
+ def get_parser(self, prog_name):
+ parser = super(AddPort, self).get_parser(prog_name)
+ parser.add_argument(
+ "server",
+ metavar="<server>",
+ help=_("Server to add the port to (name or ID)"),
+ )
+ parser.add_argument(
+ "port",
+ metavar="<port>",
+ help=_("Port to add to the server (name or ID)"),
+ )
+ return parser
+
+ def take_action(self, parsed_args):
+ compute_client = self.app.client_manager.compute
+
+ server = utils.find_resource(
+ compute_client.servers, parsed_args.server)
+
+ if self.app.client_manager.is_network_endpoint_enabled():
+ network_client = self.app.client_manager.network
+ port_id = network_client.find_port(
+ parsed_args.port, ignore_missing=False).id
+ else:
+ port_id = parsed_args.port
+
+ server.interface_attach(port_id=port_id, net_id=None, fixed_ip=None)
+
+
class AddServerSecurityGroup(command.Command):
_description = _("Add security group to server")
@@ -1342,6 +1375,39 @@ class RemoveFloatingIP(command.Command):
server.remove_floating_ip(parsed_args.ip_address)
+class RemovePort(command.Command):
+ _description = _("Remove port from server")
+
+ def get_parser(self, prog_name):
+ parser = super(RemovePort, self).get_parser(prog_name)
+ parser.add_argument(
+ "server",
+ metavar="<server>",
+ help=_("Server to remove the port from (name or ID)"),
+ )
+ parser.add_argument(
+ "port",
+ metavar="<port>",
+ help=_("Port to remove from the server (name or ID)"),
+ )
+ return parser
+
+ def take_action(self, parsed_args):
+ compute_client = self.app.client_manager.compute
+
+ server = utils.find_resource(
+ compute_client.servers, parsed_args.server)
+
+ if self.app.client_manager.is_network_endpoint_enabled():
+ network_client = self.app.client_manager.network
+ port_id = network_client.find_port(
+ parsed_args.port, ignore_missing=False).id
+ else:
+ port_id = parsed_args.port
+
+ server.interface_detach(port_id)
+
+
class RemoveServerSecurityGroup(command.Command):
_description = _("Remove security group from server")