From bc00ed5c8ec8ea08fd8e3b215e0a0bf121902eb7 Mon Sep 17 00:00:00 2001 From: Mathias Scherer Date: Tue, 14 Aug 2018 15:40:05 +0200 Subject: [PATCH 1/3] adds the private instance ip as a new parameter for the template keeps the parameter {IP} for backwards compatibility --- README.md | 3 ++- icinga2-aws.py | 3 +++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index d626c49..4580206 100644 --- a/README.md +++ b/README.md @@ -36,7 +36,8 @@ Just use the same command ## Templates For templates are following parameters available: {HOST} = instance id -{IP} = instance public ip +{IP} or {PublicIP} = instance public ip +{PrivateIP} = instance private ip If you need more just create a feature request ## Contributing diff --git a/icinga2-aws.py b/icinga2-aws.py index 4439e37..237bf7e 100644 --- a/icinga2-aws.py +++ b/icinga2-aws.py @@ -9,6 +9,9 @@ def writeTemplate(template, targetFile, targetFolder): with open(icinga2ConfigDir + 'conf.d/hosts/' + targetFolder + '/' + targetFile + '.conf', 'w') as out: template = template template = template.replace('{HOST}', instance.id) + template = template.replace('{PublicIP}', instance.public_ip_address) + template = template.replace('{PrivateIP}', instance.private_ip_address) + # Backwards compatibility template = template.replace('{IP}', instance.public_ip_address) out.write(template) out.flush() From cf252e57e8c2a244caaf5629402cbb2aa3af10a3 Mon Sep 17 00:00:00 2001 From: Mathias Scherer Date: Tue, 14 Aug 2018 16:35:34 +0200 Subject: [PATCH 2/3] bug fixes --- icinga2-aws.py | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/icinga2-aws.py b/icinga2-aws.py index 237bf7e..d885b07 100644 --- a/icinga2-aws.py +++ b/icinga2-aws.py @@ -9,10 +9,12 @@ def writeTemplate(template, targetFile, targetFolder): with open(icinga2ConfigDir + 'conf.d/hosts/' + targetFolder + '/' + targetFile + '.conf', 'w') as out: template = template template = template.replace('{HOST}', instance.id) - template = template.replace('{PublicIP}', instance.public_ip_address) template = template.replace('{PrivateIP}', instance.private_ip_address) - # Backwards compatibility - template = template.replace('{IP}', instance.public_ip_address) + + if instance.public_ip_address: + template = template.replace('{PublicIP}', instance.public_ip_address) + # Backwards compatibility + template = template.replace('{IP}', instance.public_ip_address) out.write(template) out.flush() @@ -40,7 +42,7 @@ def cleanupHosts(instances): shutil.rmtree(x[0]) for directory in os.listdir(config['Default']['php4nagiosPerfDataFolder']): if(directory.find(instance.id) > -1): - if os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + directory): + if os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + directory) and os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + instance.id): shutil.rmtree(config['Default']['php4nagiosPerfDataFolder'] + instance.id) From 6f494838a2a460f7b18d74143e36a45d8d51ccf9 Mon Sep 17 00:00:00 2001 From: Mathias Scherer Date: Tue, 14 Aug 2018 17:36:22 +0200 Subject: [PATCH 3/3] adds noClean function adds clean command --- README.md | 39 ++++++++++++++----- icinga2-aws.py | 101 ++++++++++++++++++++++++++++++++++--------------- 2 files changed, 99 insertions(+), 41 deletions(-) diff --git a/README.md b/README.md index 4580206..d9f5f35 100644 --- a/README.md +++ b/README.md @@ -13,16 +13,27 @@ Run install.sh script - command to reload Icinga2 configs ## Usage - AWS for Icinga 2 - - optional arguments: - -h, --help show this help message and exit - -t TAGS [TAGS ...], --tags TAGS [TAGS ...] - Tag Filter: Key value pair - -th TEMPLATEHOST, --template-host TEMPLATEHOST - Which Template should be used for the host - -tc TEMPLATECHECK, --template-check TEMPLATECHECK - Which Template should be used for the checks +usage: icinga2-aws.py [-h] -t TAGS [TAGS ...] -th TEMPLATEHOST -tc + TEMPLATECHECK [-nc] + {clean} ... + +AWS for Icinga 2 + +optional arguments: + -h, --help show this help message and exit + -t TAGS [TAGS ...], --tags TAGS [TAGS ...] + Tag Filter: Key value pair + -th TEMPLATEHOST, --template-host TEMPLATEHOST + Which Template should be used for the host + -tc TEMPLATECHECK, --template-check TEMPLATECHECK + Which Template should be used for the checks + -nc, --no-clean Don't clean host folders + +subcommands: + valid subcommands + + {clean} additional help + clean clean help ## Tag Parameter The Tags are in following format: @@ -40,6 +51,14 @@ For templates are following parameters available: {PrivateIP} = instance private ip If you need more just create a feature request + +## noClean clean +sample usage of the --no-clean and clean feature +1. Create config for application:application1 with --no-clean +2. Create another config for application:application2 with --no-clean +**if on step 2 a clean function would be called, all instances from step 1 would be deleted** +3. call the clean command with another tag like icinga:true + ## Contributing 1. Fork it! 2. Create your feature branch: `git checkout -b my-new-feature` diff --git a/icinga2-aws.py b/icinga2-aws.py index d885b07..66c8f7e 100644 --- a/icinga2-aws.py +++ b/icinga2-aws.py @@ -4,22 +4,25 @@ import shutil import subprocess import configparser +import sys -def writeTemplate(template, targetFile, targetFolder): +def writeTemplate(template, targetFile, targetFolder, instance): with open(icinga2ConfigDir + 'conf.d/hosts/' + targetFolder + '/' + targetFile + '.conf', 'w') as out: template = template template = template.replace('{HOST}', instance.id) template = template.replace('{PrivateIP}', instance.private_ip_address) if instance.public_ip_address: - template = template.replace('{PublicIP}', instance.public_ip_address) - # Backwards compatibility + template = template.replace( + '{PublicIP}', instance.public_ip_address) + # Backwards compatibility template = template.replace('{IP}', instance.public_ip_address) out.write(template) out.flush() out.close() + def walklevel(some_dir, level=1): some_dir = some_dir.rstrip(os.path.sep) assert os.path.isdir(some_dir) @@ -30,21 +33,64 @@ def walklevel(some_dir, level=1): if num_sep + level <= num_sep_this: del dirs[:] + def cleanupHosts(instances): for x in walklevel(icinga2ConfigDir + "conf.d/hosts/"): instanceActive = False if (x[0].find('i-') > -1): + folder_instance_id = x[0].split("/")[-1] for instance in instances: - if x[0].split("/")[-1] == instance.id: + if folder_instance_id == instance.id: instanceActive = True - + if instanceActive == False: shutil.rmtree(x[0]) for directory in os.listdir(config['Default']['php4nagiosPerfDataFolder']): - if(directory.find(instance.id) > -1): - if os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + directory) and os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + instance.id): - shutil.rmtree(config['Default']['php4nagiosPerfDataFolder'] + instance.id) + if(directory.find(folder_instance_id) > -1): + if os.path.exists(config['Default']['php4nagiosPerfDataFolder'] + directory): + shutil.rmtree( + config['Default']['php4nagiosPerfDataFolder'] + folder_instance_id) + +def get_instances(tags): + filters = [] + filters.append({"Name": 'instance-state-name', "Values": ['running']}) + for tag in tags: + tag = tag.split(':') + filters.append({"Name": "tag:" + tag[0], "Values": [tag[1]]}) + + ec2 = boto3.resource('ec2') + instances = ec2.instances.filter( + Filters=filters) + return instances + +def create_configs(instances, templateHost, templateCheck, noClean): + for instance in instances: + if not os.path.exists(icinga2ConfigDir + "conf.d/hosts/" + instance.id): + os.makedirs(icinga2ConfigDir + "conf.d/hosts/" + instance.id) + writeTemplate(templateHost, instance.id, instance.id, instance) + writeTemplate(templateCheck, 'checks', instance.id, instance) + + if noClean == False or noClean == None: + cleanupHosts(instances) + +def __add_main_parser(parser): + parser.add_argument('-t', '--tags', nargs='+', required=True, + help='Tag Filter: Key value pair') + parser.add_argument('-th', '--template-host', dest='templateHost', type=open, + required=True, help='Which Template should be used for the host') + parser.add_argument('-tc', '--template-check', dest='templateCheck', type=open, + required=True, help='Which Template should be used for the checks') + parser.add_argument('-nc', '--no-clean', dest='noClean', + default=False, action='store_true', required=False, help='Don\'t clean host folders') + +def __add_clean_parser(parser): + subparsers = parser.add_subparsers( + title='subcommands', description='valid subcommands', help='additional help', dest="command") + + parser_clean = subparsers.add_parser('clean', help='clean help') + parser_clean.add_argument('-t', '--tags', nargs='+', + required=True, help='Tag Filter: Key value pair') config = configparser.ConfigParser() config.read('config.ini') @@ -52,33 +98,26 @@ def cleanupHosts(instances): icinga2ConfigDir = config['Default']['icinga2ConfigDir'] parser = argparse.ArgumentParser(description='AWS for Icinga 2') -parser.add_argument('-t', '--tags', nargs='+', required=True, help='Tag Filter: Key value pair') -parser.add_argument('-th', '--template-host', dest='templateHost', type=open, required=True, help='Which Template should be used for the host') -parser.add_argument('-tc', '--template-check', dest='templateCheck', type=open, required=True, help='Which Template should be used for the checks') +# little hack to show the correct help and the really required params +if len(sys.argv) > 1 and sys.argv[1] in ['-h', '--help']: + __add_main_parser(parser) + __add_clean_parser(parser) +elif len(sys.argv) > 1 and sys.argv[1] == 'clean': + __add_clean_parser(parser) +else: + __add_main_parser(parser) + args = parser.parse_args() -filters = [] -filters.append({"Name": 'instance-state-name', "Values": ['running']}) -for tag in args.tags: - tag = tag.split(':') - filters.append({"Name": "tag:"+tag[0], "Values": [tag[1]]}) +instances = get_instances(args.tags) +if hasattr(args, 'command') and args.command == 'clean': + cleanupHosts(instances) +else: + templateHost = args.templateHost.read() + templateCheck = args.templateCheck.read() + create_configs(instances, templateHost, templateCheck, args.noClean) -ec2 = boto3.resource('ec2') -templateHost = args.templateHost.read() -templateCheck = args.templateCheck.read() - -instances = ec2.instances.filter( - Filters=filters) - -for instance in instances: - if not os.path.exists(icinga2ConfigDir + "conf.d/hosts/" + instance.id): - os.makedirs(icinga2ConfigDir + "conf.d/hosts/" + instance.id) - writeTemplate(templateHost, instance.id, instance.id) - writeTemplate(templateCheck, 'checks', instance.id) - -cleanupHosts(instances) subprocess.call(config['Default']['icinga2ReloadCommand'], shell=True) -