Added multiple allowed ranges.

This commit is contained in:
Robert Marsa 2015-03-17 13:49:53 -07:00
parent ae253593e3
commit 74e94f2712

View file

@ -33,7 +33,7 @@ description:
options: options:
allowed: allowed:
description: description:
- the protocol:ports to allow ('tcp:80' or 'tcp:80,443' or 'tcp:80-800') - the protocol:ports to allow ('tcp:80' or 'tcp:80,443' or 'tcp:80-800;udp:1-25')
required: false required: false
default: null default: null
aliases: [] aliases: []
@ -136,9 +136,8 @@ except ImportError:
"msg='libcloud with GCE support required for this module.'") "msg='libcloud with GCE support required for this module.'")
sys.exit(1) sys.exit(1)
def format_allowed_section(allowed):
def format_allowed(allowed): """Format each section of the allowed list"""
"""Format the 'allowed' value so that it is GCE compatible."""
if allowed.count(":") == 0: if allowed.count(":") == 0:
protocol = allowed protocol = allowed
ports = [] ports = []
@ -153,8 +152,18 @@ def format_allowed(allowed):
return_val = {"IPProtocol": protocol} return_val = {"IPProtocol": protocol}
if ports: if ports:
return_val["ports"] = ports return_val["ports"] = ports
return [return_val] return return_val
def format_allowed(allowed):
"""Format the 'allowed' value so that it is GCE compatible."""
return_value = []
if allowed.count(";") == 0:
return [format_allowed_section(allowed)]
else:
sections = allowed.split(";")
for section in sections:
return_value.append(format_allowed_section(section))
return return_value
def main(): def main():
module = AnsibleModule( module = AnsibleModule(