Example #1
0
def upsert_org_unit(ctx, stackname, region_folder, logoutput=None):
    session, config = configtasks.getConfig(region=region_folder,
                                            stack=stackname)
    org_client = organizationstasks.organizationstasks()
    org_client.upsert_org_unit(session=session,
                               config=config,
                               logoutput=logoutput)
Example #2
0
 def validateStack(self, stack, region, logoutput=None):
     session, config = configtasks.getConfig(region, stack)
     cftemplate = template.voltron(stack, **config)
     template.writecompiled(data=cftemplate, name=stack, region=region)
     cf = cloudformation.stack(session)
     validationstatus = cf.validateTemplate(cftemplate)
     return validationstatus
Example #3
0
def createVPCPeering(ctx, stackname, region, noop=False, logoutput=None):
    session, config = configtasks.getConfig(region, stackname)
    ec2client = ec2tasks.ec2tasks()
    ec2client.createVPCPeering(session=session,
                               config=config,
                               noop=noop,
                               logoutput=logoutput)
Example #4
0
 def getStackStatus(self, stack, region, githash=None, environment=None, logoutput=None):
     session, config = configtasks.getConfig(region, stack, githash, environment)
     cf = cloudformation.stack(session)
     cfstackname = self.generateStackName(config["stackname"], githash, environment)
     status = cf.getStackStatus(stackname=cfstackname)
     print "STATUS"
     print json.dumps(status, sort_keys=True, indent=4, separators=(',', ': '))
Example #5
0
    def deleteCreateStack(self, stack, region, githash=None, environment=None, logoutput=None):
        '''Deletes a stack then creates it again'''
        self.optOut(stack)
        session, config = configtasks.getConfig(region, stack, githash, environment)
        cftemplate = template.voltron(stack, **config)
        template.writecompiled(cftemplate, stack, region)
        cf = cloudformation.stack(session)

        try:
            cf.validateTemplate(cftemplate)
        except:
            print "Template validation failed!"
            print json.dumps(cftemplate, sort_keys=True, indent=4, separators=(',', ': '))
            sys.exit(1)

        try:
            cf.deleteStack(config["stackname"])
            cf.statusPoller(stackname=config["stackname"])
        except ClientError as err:
            print err
            sys.exit(1)

        try:
            cf.createStack(cftemplate, config["stackname"])
            cf.statusPoller(stackname=config["stackname"])
        except ClientError as err:
            log.warn(err)
            sys.exit(1)
Example #6
0
 def createChangeSet(self, stack, region, githash, environment):
     session, config = configtasks.getConfig(region, stack, githash, environment)
     cftemplate = template.voltron(stack, **config)
     template.writecompiled(data=cftemplate, name=stack, region=region)
     cf = cloudformation.stack(session)
     cfstackname = self.generateStackName(stack, githash, environment)
     changes = cf.createChangeSet(cftemplate, cfstackname)
     return changes
Example #7
0
def upsertGGDeployment(ctx,
                       stack,
                       region,
                       githash=None,
                       environment=None,
                       customConfig=None):
    session, config = configtasks.getConfig(region, stack, githash,
                                            environment, customConfig)
    return create_group_with_config(session, config)
Example #8
0
def createDatabaseSnapshot(ctx, stack, region, githash=None, environment=None):
    session, config = configtasks.getConfig(region, stack, githash,
                                            environment)
    cftasks = cloudformationtasks.cloudformationtasks()
    rds = database.rds(session)
    cfstackname = cftasks.generateStackName(config["stackname"], githash,
                                            environment)
    resources = cftasks.getStackResources(stackname=cfstackname)
    rds.SnapshotfromResources(stackresources=resources)
Example #9
0
 def generateTemplateS3(ctx, stack, region, githash=None, environment=None, logoutput=None, outFile=None, customConfig=None):
     '''Generates a template that needs to be uploaded to S3. Must run on
     the build agents as it will decrypt the secrets using KMS. Otherwise usage
     is the same as generateTemplate'''
     session, config = configtasks.getConfig(region, stack, githash, environment, customConfig)
     cftemplate = template.voltron(stack, **config)
     if len(json.dumps(cftemplate)) >= 51200:
         print output.whalesay(text='Your generated Cloudformation Template is over the max allowable size.\nYou will need to reduce the size, split the template or upload into S3.')
     if len(json.dumps(cftemplate)) >= 460800:
         print output.piesay(text='Your generated Cloudformation Template is over the max allowable size.')
         sys.exit(1)
     name = outFile if outFile else stack
     template.writecompiled(cftemplate, name, region)
Example #10
0
    def upsertIamStackSet(self, stack, region, githash=None, environment=None, logoutput=None):
        self.optOut(stack)
        session, config = configtasks.getConfig(region, stack, githash, environment)
        cftemplate = template.voltron(stack, **config)
        cfstackname = self.generateStackName(config["stackname"], githash, environment)
        template.writecompiled(data=cftemplate, name=stack, region=region, logoutput=logoutput)
        cf = cloudformation.stack(session)
        try:
            cf.validateTemplate(cftemplate=cftemplate)
        except ClientError as err:
            log.warn(err)
            # print "Template validation failed!"
            # pprint.pprint(json.dumps(cftemplate))
            sys.exit(1)
        status = cf.describeStackSet(stackname=cfstackname)
        if status:
            try:
                response = cf.updateStackSet(cftemplate=cftemplate, stackname=cfstackname, iamcapable=['CAPABILITY_IAM', 'CAPABILITY_NAMED_IAM'])
                if logoutput:
                    print json.dumps(response, sort_keys=True, indent=4, separators=(',', ': '))
                state, status = cf.statusPoller(stackname=cfstackname)

                if logoutput:
                    print json.dumps(cf.getStackResources(stackname=cfstackname), default=str, sort_keys=True, indent=4, separators=(',', ': '))

                if state != 0:
                    sys.exit(1)
            except ClientError as err:
                log.warn(err)
                if 'No updates are to be performed' in str(err):
                    sys.exit(0)
                sys.exit(1)
        else:
            try:
                response = cf.createStackSet(cftemplate=cftemplate, stackname=cfstackname, iamcapable=['CAPABILITY_IAM', 'CAPABILITY_NAMED_IAM'])
                if logoutput:
                    print json.dumps(response, sort_keys=True, indent=4, separators=(',', ': '))
                state, status = cf.statusPoller(stackname=cfstackname)

                if logoutput:
                    print json.dumps(cf.getStackResources(stackname=cfstackname), default=str, sort_keys=True, indent=4, separators=(',', ': '))

                if state != 0:
                    sys.exit(1)
            except ClientError as err:
                log.warn(err)
                if 'already exists' in str(err):
                    sys.exit(0)
                sys.exit(1)
Example #11
0
    def deleteStackSet(self, stack, region, githash=None, environment=None, logoutput=None):
        '''Deletes a stack given a name and region USAGE deleteStack STACK REGION'''
        self.optOut(stack)
        session, config = configtasks.getConfig(region, stack, githash, environment)
        cfstackname = self.generateStackName(config["stackname"], githash, environment)
        cf = cloudformation.stack(session)
        try:
            cf.deleteStackSet(stackname=cfstackname)
            state, status = cf.statusPoller(stackname=cfstackname)

            if state != 0:
                sys.exit(1)
        except ClientError as err:
            print err
            sys.exit(1)
Example #12
0
def upsertLambdaAlias(ctx,
                      stack,
                      region,
                      githash=None,
                      environment=None,
                      customConfig=None):
    """Idempotent"""
    session, config = configtasks.getConfig(region, stack, githash,
                                            environment, customConfig)

    for lambda_name in config['resources']['lambda']:
        func_config = config['resources']['lambda'][lambda_name]
        lambdatasks.upsert_alias(
            session,
            function_name=func_config['functionName'],
            alias_name=func_config['alias'],
            alias_desc=func_config['aliasDescription'],
        )
Example #13
0
    def upsertS3Stack(self, stack, s3location, region, githash=None, environment=None, logoutput=None, customConfig=None):
        self.optOut(stack)
        session, config = configtasks.getConfig(region, stack, githash, environment, customConfig)
        cftemplate = template.voltron(stack, **config)
        cfstackname = self.generateStackName(config["stackname"], githash, environment)
        template.writecompiled(data=cftemplate, name=stack, region=region, logoutput=logoutput)
        cf = cloudformation.stack(session)
        status = cf.describeStack(stackname=cfstackname)
        if status:
            try:
                response = cf.updateStack(cftemplate=s3location, stackname=cfstackname)
                if logoutput:
                    print json.dumps(response, sort_keys=True, indent=4, separators=(',', ': '))
                state, status = cf.statusPoller(stackname=cfstackname)

                if logoutput:
                    print json.dumps(cf.getStackResources(stackname=cfstackname), default=str, sort_keys=True, indent=4, separators=(',', ': '))

                if state != 0:
                    sys.exit(1)
            except ClientError as err:
                log.warn(err)
                if 'No updates are to be performed' in str(err):
                    sys.exit(0)
                sys.exit(1)
        else:
            try:
                response = cf.createStack(cftemplate=s3location, stackname=cfstackname)
                if logoutput:
                    print json.dumps(response, sort_keys=True, indent=4, separators=(',', ': '))
                state, status = cf.statusPoller(stackname=cfstackname)

                if logoutput:
                    print json.dumps(cf.getStackResources(stackname=cfstackname), default=str, sort_keys=True, indent=4, separators=(',', ': '))

                if state != 0:
                    sys.exit(1)
            except ClientError as err:
                log.warn(err)
                if 'already exists' in str(err):
                    sys.exit(0)
                sys.exit(1)
Example #14
0
def createBeanstalkApplicationVersion(ctx, stack, region, logoutput=None):
    session, config = configtasks.getConfig(region, stack)
    bsclient = beanstalktasks.beanstalktasks()
    bsclient.createApplicationVersion(session=session,
                                      config=config,
                                      logoutput=logoutput)