SDK Refactor: Prepare security group rule commands

Prepare the OSC "security group rule" commands for the SDK refactor.
See [1] for details.

[1] https://etherpad.openstack.org/p/osc-network-command-sdk-support

Change-Id: I5553e40fe90f3a26d3f462a69f1a424032479d49
Partially-Implements: blueprint network-command-sdk-support
This commit is contained in:
Abhishek Raut 2016-11-19 17:45:01 -08:00
parent d6e058fa1f
commit c76e631a2c

View File

@ -29,6 +29,7 @@ import six
from openstackclient.i18n import _ from openstackclient.i18n import _
from openstackclient.identity import common as identity_common from openstackclient.identity import common as identity_common
from openstackclient.network import common from openstackclient.network import common
from openstackclient.network import sdk_utils
from openstackclient.network import utils as network_utils from openstackclient.network import utils as network_utils
@ -67,11 +68,10 @@ def _format_network_port_range(rule):
def _get_columns(item): def _get_columns(item):
columns = list(item.keys()) column_map = {
if 'tenant_id' in columns: 'tenant_id': 'project_id',
columns.remove('tenant_id') }
columns.append('project_id') return sdk_utils.get_osc_show_columns_for_sdk_resource(item, column_map)
return tuple(sorted(columns))
def _convert_to_lowercase(string): def _convert_to_lowercase(string):
@ -89,6 +89,8 @@ def _is_icmp_protocol(protocol):
return False return False
# TODO(abhiraut): Use the SDK resource mapped attribute names once the
# OSC minimum requirements include SDK 1.0.
class CreateSecurityGroupRule(common.NetworkAndComputeShowOne): class CreateSecurityGroupRule(common.NetworkAndComputeShowOne):
_description = _("Create a new security group rule") _description = _("Create a new security group rule")
@ -341,9 +343,9 @@ class CreateSecurityGroupRule(common.NetworkAndComputeShowOne):
# Create and show the security group rule. # Create and show the security group rule.
obj = client.create_security_group_rule(**attrs) obj = client.create_security_group_rule(**attrs)
columns = _get_columns(obj) display_columns, columns = _get_columns(obj)
data = utils.get_item_properties(obj, columns) data = utils.get_item_properties(obj, columns)
return (columns, data) return (display_columns, data)
def take_action_compute(self, client, parsed_args): def take_action_compute(self, client, parsed_args):
group = utils.find_resource( group = utils.find_resource(
@ -597,9 +599,9 @@ class ShowSecurityGroupRule(common.NetworkAndComputeShowOne):
def take_action_network(self, client, parsed_args): def take_action_network(self, client, parsed_args):
obj = client.find_security_group_rule(parsed_args.rule, obj = client.find_security_group_rule(parsed_args.rule,
ignore_missing=False) ignore_missing=False)
columns = _get_columns(obj) display_columns, columns = _get_columns(obj)
data = utils.get_item_properties(obj, columns) data = utils.get_item_properties(obj, columns)
return (columns, data) return (display_columns, data)
def take_action_compute(self, client, parsed_args): def take_action_compute(self, client, parsed_args):
# NOTE(rtheis): Unfortunately, compute does not have an API # NOTE(rtheis): Unfortunately, compute does not have an API