summaryrefslogtreecommitdiff
path: root/openstackclient/network
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2016-03-28 15:57:31 +0000
committerGerrit Code Review <review@openstack.org>2016-03-28 15:57:31 +0000
commit5f55e99d464b2ca0a9f1cf879164b2cc2bb23fc5 (patch)
treed39eede33be1f0d05f85a70d9421b12ad74f4ca9 /openstackclient/network
parentd5596862b1bbd9fa0bcd1aeb8befad7fab4e3d2a (diff)
parent2109bce85a40da3e3cbebed1cac661611564ccb2 (diff)
downloadpython-openstackclient-5f55e99d464b2ca0a9f1cf879164b2cc2bb23fc5.tar.gz
Merge "Support security group name for --src-group"
Diffstat (limited to 'openstackclient/network')
-rw-r--r--openstackclient/network/v2/security_group_rule.py12
1 files changed, 10 insertions, 2 deletions
diff --git a/openstackclient/network/v2/security_group_rule.py b/openstackclient/network/v2/security_group_rule.py
index e0244654..f60995ab 100644
--- a/openstackclient/network/v2/security_group_rule.py
+++ b/openstackclient/network/v2/security_group_rule.py
@@ -69,7 +69,7 @@ class CreateSecurityGroupRule(common.NetworkAndComputeShowOne):
source_group.add_argument(
"--src-group",
metavar="<group>",
- help="Source security group (ID only)",
+ help="Source security group (name or ID)",
)
parser.add_argument(
"--dst-port",
@@ -103,7 +103,10 @@ class CreateSecurityGroupRule(common.NetworkAndComputeShowOne):
attrs['port_range_max'] = parsed_args.dst_port[1]
attrs['protocol'] = parsed_args.proto
if parsed_args.src_group is not None:
- attrs['remote_group_id'] = parsed_args.src_group
+ attrs['remote_group_id'] = client.find_security_group(
+ parsed_args.src_group,
+ ignore_missing=False
+ ).id
else:
attrs['remote_ip_prefix'] = parsed_args.src_ip
attrs['security_group_id'] = security_group_id
@@ -123,6 +126,11 @@ class CreateSecurityGroupRule(common.NetworkAndComputeShowOne):
from_port, to_port = -1, -1
else:
from_port, to_port = parsed_args.dst_port
+ if parsed_args.src_group is not None:
+ parsed_args.src_group = utils.find_resource(
+ client.security_groups,
+ parsed_args.src_group,
+ ).id
obj = client.security_group_rules.create(
group.id,
parsed_args.proto,