1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
#!/usr/bin/env python
from argparse import ArgumentParser
import logging
from boto.ec2 import regions
from jujupy import SimpleEnvironment
from substrate import AWSAccount
def parse_args(argv=None):
parser = ArgumentParser('Clean up leftover resources.')
parser.add_argument('env', help='The juju environment to use.')
parser.add_argument('--verbose', '-v', action='count', default=0)
parser.add_argument('-a', '--all-regions', action='store_true',
help='Take action on all regions.')
return parser.parse_args(argv)
def get_regions(args, env):
if args.all_regions:
return [region.name for region in filter(
lambda x: '-gov-' not in x.name, regions())]
return [env.config['region']]
def clean(args):
env = SimpleEnvironment.from_config(args.env)
selected_regions = get_regions(args, env)
for region in selected_regions:
with AWSAccount.manager_from_config(
env.config, region=region) as substrate:
logging.info('Cleaning resources in {}.'.format(substrate.region))
all_groups = dict(substrate.iter_security_groups())
instance_groups = dict(substrate.iter_instance_security_groups())
non_instance_groups = dict((k, v) for k, v in all_groups.items()
if k not in instance_groups)
unclean = substrate.delete_detached_interfaces(
non_instance_groups.keys())
logging.info('Unable to delete {} groups'.format(len(unclean)))
for group_id in unclean:
logging.debug('Cannot delete {}'.format(all_groups[group_id]))
for group_id in unclean:
non_instance_groups.pop(group_id, None)
substrate.destroy_security_groups(non_instance_groups.values())
def main():
args = parse_args()
log_level = max(logging.WARN - args.verbose * 10, logging.DEBUG)
logging.basicConfig(level=log_level)
logging.getLogger('boto').setLevel(logging.CRITICAL)
clean(args)
if __name__ == '__main__':
main()
|