UNPKG

aws-ddk-core

Version:

The AWS DataOps Development Kit is an open source development framework for customers that build data workflows and modern data architecture on AWS.

93 lines 16.7 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.CICDActions = void 0; const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const codecommit = require("aws-cdk-lib/aws-codecommit"); const pipelines = require("aws-cdk-lib/pipelines"); const utils_1 = require("./utils"); class CICDActions { static getCodeCommitSourceAction(scope, props) { return pipelines.CodePipelineSource.codeCommit(codecommit.Repository.fromRepositoryName(scope, props.repositoryName, props.repositoryName), props.branch, props.props); } static getSynthAction(props) { var installCommands; installCommands = [`npm install -g aws-cdk@${props.cdkVersion ? props.cdkVersion : "latest"}`]; // if (all([codeArtifactRepository, codeArtifactDomain, codeArtifactDomainOwner])) { // if (!rolePolicyStatements) { // rolePolicyStatements = _get_codeartifact_read_policy_statements(partition, region, account, codeArtifactDomain, codeArtifactRepository); // } // install_commands.psuh(`aws codeartifact login --tool pip --repository ${codeArtifactRepository} --domain ${codeArtifactDomain} --domain-owner ${codeArtifactDomainOwner}`); // } if (props.additionalInstallCommands != undefined && props.additionalInstallCommands.length > 0) { installCommands = installCommands.concat(props.additionalInstallCommands); // will need to be replaced with `npm install aws-ddk-core@${version}` when available } return new pipelines.CodeBuildStep("Synth", { input: props.codePipelineSource, installCommands: installCommands, commands: ["cdk synth"], rolePolicyStatements: props.rolePolicyStatements, }); } static getCfnNagAction(fileSetProducer, stageName = "CFNNag", failBuild) { return new pipelines.ShellStep(stageName, { input: fileSetProducer, installCommands: ["gem install cfn-nag"], env: { FAIL_BUILD: failBuild ? "true" : "false", }, commands: [ 'cfn_nag_scan --input-path ./ --template-pattern ".*.template.json" && scan_result="SUCCESS" || echo scan_result="FAILED"', 'if [[ "$FAIL_BUILD" = "true" && "$scan_result" = "FAILED" ]]; then printf "\n\nFailing pipeline as possible insecure configurations were detected\n\n" && exit 1; fi', ], }); } static getBanditAction(codePipelineSource, stageName = "Bandit") { return new pipelines.ShellStep(stageName, { input: codePipelineSource, installCommands: ["pip install bandit"], commands: ["bandit -r -ll -ii ."], }); } static getTestsAction(fileSetProducer, commands = ["./test.sh"], installCommands = ["pip install -r requirements-dev.txt", "pip install -r requirements.txt"], stageName = "Tests") { return new pipelines.ShellStep(stageName, { input: fileSetProducer, installCommands: installCommands, commands: commands, }); } static getCodeArtifactPublishAction(partition, region, account, codeartifactRepository, codeartifactDomain, codeartifactDomainOwner, codePipelineSource, rolePolicyStatements = utils_1.getCodeArtifactPublishPolicyStatements(partition, region, account, codeartifactDomain, codeartifactRepository)) { var rolePolicyStatements = rolePolicyStatements ?? utils_1.getCodeArtifactPublishPolicyStatements(partition, region, account, codeartifactDomain, codeartifactRepository); return new pipelines.CodeBuildStep("BuildAndUploadArtifact", { input: codePipelineSource, buildEnvironment: { environmentVariables: { DOMAIN: { value: codeartifactDomain, }, OWNER: { value: codeartifactDomainOwner, }, REPOSITORY: { value: codeartifactRepository, }, }, }, installCommands: [ "pip install wheel twine", "pip install -U -r requirements.txt", "python setup.py bdist_wheel", "export VERSION=$(python setup.py --version)", "export PACKAGE=$(python setup.py --name)", "aws codeartifact login --tool twine --domain ${DOMAIN} --domain-owner ${OWNER} --repository ${REPOSITORY}", ], commands: ["twine upload --repository codeartifact dist/${PACKAGE}-${VERSION}-py3-none-any.whl"], rolePolicyStatements: rolePolicyStatements, }); } } exports.CICDActions = CICDActions; _a = JSII_RTTI_SYMBOL_1; CICDActions[_a] = { fqn: "aws-ddk-core.CICDActions", version: "1.4.1" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions.js","sourceRoot":"","sources":["../../src/cicd/actions.ts"],"names":[],"mappings":"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","sourcesContent":["import * as codecommit from \"aws-cdk-lib/aws-codecommit\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\nimport * as pipelines from \"aws-cdk-lib/pipelines\";\nimport { Construct } from \"constructs\";\nimport { getCodeArtifactPublishPolicyStatements } from \"./utils\";\n\nexport interface GetSynthActionProps {\n  readonly codePipelineSource?: pipelines.IFileSetProducer;\n  readonly cdkVersion?: string;\n  readonly partition?: string;\n  readonly region?: string;\n  readonly account?: string;\n  readonly rolePolicyStatements?: iam.PolicyStatement[];\n  readonly codeartifactRepository?: string;\n  readonly codeartifactDomain?: string;\n  readonly codeartifactDomainOwner?: string;\n  readonly additionalInstallCommands?: string[];\n  readonly env?: { [key: string]: string };\n}\n\nexport interface CodeCommitSourceActionProps {\n  readonly repositoryName: string;\n  readonly branch: string;\n  readonly props?: pipelines.ConnectionSourceOptions;\n}\n\nexport interface CodeArtifactPublishActionProps {\n  readonly partition: string;\n  readonly region: string;\n  readonly account: string;\n  readonly codeartifactRepository: string;\n  readonly codeartifactDomain: string;\n  readonly codeartifactDomainOwner: string;\n  readonly codePipelineSource?: pipelines.CodePipelineSource;\n  readonly rolePolicyStatements?: iam.PolicyStatement[];\n}\n\nexport class CICDActions {\n  public static getCodeCommitSourceAction(\n    scope: Construct,\n    props: CodeCommitSourceActionProps,\n  ): pipelines.CodePipelineSource {\n    return pipelines.CodePipelineSource.codeCommit(\n      codecommit.Repository.fromRepositoryName(scope, props.repositoryName, props.repositoryName),\n      props.branch,\n      props.props,\n    );\n  }\n\n  public static getSynthAction(props: GetSynthActionProps): pipelines.CodeBuildStep {\n    var installCommands;\n    installCommands = [`npm install -g aws-cdk@${props.cdkVersion ? props.cdkVersion : \"latest\"}`];\n\n    // if (all([codeArtifactRepository, codeArtifactDomain, codeArtifactDomainOwner])) {\n    //   if (!rolePolicyStatements) {\n    //     rolePolicyStatements = _get_codeartifact_read_policy_statements(partition, region, account, codeArtifactDomain, codeArtifactRepository);\n    //   }\n\n    //   install_commands.psuh(`aws codeartifact login --tool pip --repository ${codeArtifactRepository} --domain ${codeArtifactDomain} --domain-owner ${codeArtifactDomainOwner}`);\n    // }\n    if (props.additionalInstallCommands != undefined && props.additionalInstallCommands.length > 0) {\n      installCommands = installCommands.concat(props.additionalInstallCommands); // will need to be replaced with `npm install aws-ddk-core@${version}` when available\n    }\n    return new pipelines.CodeBuildStep(\"Synth\", {\n      input: props.codePipelineSource,\n      installCommands: installCommands,\n      commands: [\"cdk synth\"],\n      rolePolicyStatements: props.rolePolicyStatements,\n    });\n  }\n\n  public static getCfnNagAction(\n    fileSetProducer: pipelines.IFileSetProducer,\n    stageName: string = \"CFNNag\",\n    failBuild?: boolean,\n  ): pipelines.ShellStep {\n    return new pipelines.ShellStep(stageName, {\n      input: fileSetProducer,\n      installCommands: [\"gem install cfn-nag\"],\n      env: {\n        FAIL_BUILD: failBuild ? \"true\" : \"false\",\n      },\n      commands: [\n        'cfn_nag_scan --input-path ./ --template-pattern \".*.template.json\" && scan_result=\"SUCCESS\" || echo scan_result=\"FAILED\"',\n        'if [[ \"$FAIL_BUILD\" = \"true\" && \"$scan_result\" = \"FAILED\" ]]; then printf \"\\n\\nFailing pipeline as possible insecure configurations were detected\\n\\n\" && exit 1; fi',\n      ],\n    });\n  }\n\n  public static getBanditAction(\n    codePipelineSource: pipelines.CodePipelineSource,\n    stageName: string = \"Bandit\",\n  ): pipelines.ShellStep {\n    return new pipelines.ShellStep(stageName, {\n      input: codePipelineSource,\n      installCommands: [\"pip install bandit\"],\n      commands: [\"bandit -r -ll -ii .\"],\n    });\n  }\n\n  public static getTestsAction(\n    fileSetProducer: pipelines.IFileSetProducer,\n    commands: string[] = [\"./test.sh\"],\n    installCommands: string[] = [\"pip install -r requirements-dev.txt\", \"pip install -r requirements.txt\"],\n    stageName: string = \"Tests\",\n  ) {\n    return new pipelines.ShellStep(stageName, {\n      input: fileSetProducer,\n      installCommands: installCommands,\n      commands: commands,\n    });\n  }\n\n  public static getCodeArtifactPublishAction(\n    partition: string,\n    region: string,\n    account: string,\n    codeartifactRepository: string,\n    codeartifactDomain: string,\n    codeartifactDomainOwner: string,\n    codePipelineSource?: pipelines.CodePipelineSource,\n    rolePolicyStatements: iam.PolicyStatement[] = getCodeArtifactPublishPolicyStatements(\n      partition,\n      region,\n      account,\n      codeartifactDomain,\n      codeartifactRepository,\n    ),\n  ): pipelines.CodeBuildStep {\n    var rolePolicyStatements =\n      rolePolicyStatements ??\n      getCodeArtifactPublishPolicyStatements(partition, region, account, codeartifactDomain, codeartifactRepository);\n\n    return new pipelines.CodeBuildStep(\"BuildAndUploadArtifact\", {\n      input: codePipelineSource,\n      buildEnvironment: {\n        environmentVariables: {\n          DOMAIN: {\n            value: codeartifactDomain,\n          },\n          OWNER: {\n            value: codeartifactDomainOwner,\n          },\n          REPOSITORY: {\n            value: codeartifactRepository,\n          },\n        },\n      },\n      installCommands: [\n        \"pip install wheel twine\",\n        \"pip install -U -r requirements.txt\",\n        \"python setup.py bdist_wheel\",\n        \"export VERSION=$(python setup.py --version)\",\n        \"export PACKAGE=$(python setup.py --name)\",\n        \"aws codeartifact login --tool twine --domain ${DOMAIN} --domain-owner ${OWNER} --repository ${REPOSITORY}\",\n      ],\n      commands: [\"twine upload --repository codeartifact dist/${PACKAGE}-${VERSION}-py3-none-any.whl\"],\n      rolePolicyStatements: rolePolicyStatements,\n    });\n  }\n}\n"]}