<div dir="ltr"><div class="gmail_default" style=""><p style="margin:0px 0px 1em;padding:0px;border:0px;font-size:15px;clear:both;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;line-height:17.7272720336914px">Hello all,</p><p style="margin:0px 0px 1em;padding:0px;border:0px;font-size:15px;clear:both;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;line-height:17.7272720336914px">For Each SecurityGroup, how can i convert that into a List that in turn will have a dictionary of the cidr block, protocol type and the port...so from output below, the SecurityGroup called "default" had 2 rules...allowing TCP port from 80 and 5500 to the source IP and then SecurityGroup called "Pub_HDP_SG" had only one rule...so on and so forth....here is the output that i am trying to get out in the form of a list....</p><p style="margin:0px 0px 1em;padding:0px;border:0px;font-size:15px;clear:both;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;line-height:17.7272720336914px">what I am planning to do is, take the list(and nested dictionary) and pass that to a function that will in turn spitout a cloudformation template using troposphere (something like "<a href="http://imil.net/wp/2015/06/04/rock-your-cloudformation-with-troposphere-and-boto/" rel="nofollow" style="margin:0px;padding:0px;border:0px;text-decoration:none;color:rgb(12,101,165)">http://imil.net/wp/2015/06/04/rock-your-cloudformation-with-troposphere-and-boto/</a>")</p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">For Better Readablity (<a href="http://pastebin.com/rT6Aswwz">http://pastebin.com/rT6Aswwz</a>)</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><span style="font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;font-size:15px;line-height:17.7272720336914px">import boto.ec2</span><br></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><span style="font-size:15px;line-height:17.7272720336914px;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif">sgs = boto.ec2.connect_to_region('us-east-1').get_all_security_groups()</span><br></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><span style="font-size:15px;line-height:17.7272720336914px;font-family:'Helvetica Neue',Helvetica,Arial,sans-serif">for sg in sgs:</span><br></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    for rule in sg.rules:</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">        print sg, <a href="http://sg.id">sg.id</a>, "inbound:", rule, " source:", rule.grants</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:default sg-e1304484 inbound: IPPermissions:tcp(80-80)  source: [<a href="http://67.184.225.222/32">67.184.225.222/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:default sg-e1304484 inbound: IPPermissions:tcp(5500-5500)  source: [<a href="http://67.184.225.222/32">67.184.225.222/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:Pub_HDP_SG sg-e632d982 inbound: IPPermissions:tcp(80-80)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:sg3-MySecurityGroup-LB0QF9UQAOEF sg-4fe73728 inbound: IPPermissions:tcp(22-22)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:sg3-MySecurityGroup-LB0QF9UQAOEF sg-4fe73728 inbound: IPPermissions:tcp(80-80)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:RDP Rule - open everyone  sg-42d58d27 inbound: IPPermissions:-1(None-None)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:us-east-open-all sg-97ffa7f2 inbound: IPPermissions:tcp(22-22)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:us-east-open-all sg-97ffa7f2 inbound: IPPermissions:tcp(53-53)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:-1(None-None)  source: [sg-e632d982-995635159130]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:tcp(22-22)  source: [<a href="http://67.184.225.222/32">67.184.225.222/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:tcp(1024-65535)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:tcp(80-80)  source: [<a href="http://24.12.30.198/32">24.12.30.198/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:udp(138-138)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:udp(53-53)  source: [<a href="http://24.12.30.198/32">24.12.30.198/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:tcp(30015-30015)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:wordpress-app-SG sg-99c4befc inbound: IPPermissions:icmp(-1--1)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:default sg-c65a20a3 inbound: IPPermissions:-1(None-None)  source: [sg-c65a20a3-995635159130]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:default sg-c65a20a3 inbound: IPPermissions:-1(None-None)  source: [sg-99c4befc-995635159130]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:sg3-MySecurityGroup2-1HGPN4UF57XN6 sg-4ee73729 inbound: IPPermissions:tcp(22-22)  source: [<a href="http://192.168.1.12/32">192.168.1.12/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:AWS-AMI-SG sg-35568d51 inbound: IPPermissions:tcp(22-22)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:launch-wizard-2 sg-932255f6 inbound: IPPermissions:tcp(22-22)  source: [<a href="http://10.0.20.100/32">10.0.20.100/32</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">SecurityGroup:launch-wizard-2 sg-932255f6 inbound: IPPermissions:tcp(443-443)  source: [<a href="http://0.0.0.0/0">0.0.0.0/0</a>]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">>>> </span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">Here is the output i am looking for....</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">rule1 = [{</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'cidr': '<a href="http://67.184.225.222/32">67.184.225.222/32</a>',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'proto': 'tcp',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'port': 80</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">},{</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'cidr': '<a href="http://67.184.225.222/32">67.184.225.222/32</a>',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'proto': 'tcp',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'port': 5500</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">}]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">rule2 = [{</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'cidr': '[<a href="http://0.0.0.0/0">0.0.0.0/0</a>',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'proto': 'tcp',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'port': 80</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">}]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">rule3 = [{</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'cidr': '<a href="http://0.0.0.0/0">0.0.0.0/0</a>',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'proto': 'tcp',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'port': 22</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">},{</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'cidr': '<a href="http://0.0.0.0/0">0.0.0.0/0</a>',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'proto': 'tcp',</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">    'port': 80</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px">}]</span></font></p><p style="margin:0px 0px 1em;padding:0px;border:0px;clear:both"><font face="Helvetica Neue, Helvetica, Arial, sans-serif"><span style="font-size:15px;line-height:17.7272720336914px"><br></span></font></p></div></div>