Class PipelineProjectProps.Builder

java.lang.Object
software.amazon.awscdk.services.codebuild.PipelineProjectProps.Builder
All Implemented Interfaces:
software.amazon.jsii.Builder<PipelineProjectProps>
Enclosing interface:
PipelineProjectProps

@Stability(Stable) public static final class PipelineProjectProps.Builder extends Object implements software.amazon.jsii.Builder<PipelineProjectProps>
A builder for PipelineProjectProps
  • Constructor Details

    • Builder

      public Builder()
  • Method Details

    • allowAllOutbound

      @Stability(Stable) public PipelineProjectProps.Builder allowAllOutbound(Boolean allowAllOutbound)
      Parameters:
      allowAllOutbound - Whether to allow the CodeBuild to send all network traffic. If set to false, you must individually add traffic rules to allow the CodeBuild project to connect to network targets.

      Only used if 'vpc' is supplied.

      Returns:
      this
    • badge

      @Stability(Stable) public PipelineProjectProps.Builder badge(Boolean badge)
      Parameters:
      badge - Indicates whether AWS CodeBuild generates a publicly accessible URL for your project's build badge. For more information, see Build Badges Sample in the AWS CodeBuild User Guide.
      Returns:
      this
    • buildSpec

      @Stability(Stable) public PipelineProjectProps.Builder buildSpec(BuildSpec buildSpec)
      Parameters:
      buildSpec - Filename or contents of buildspec in JSON format.
      Returns:
      this
    • cache

      @Stability(Stable) public PipelineProjectProps.Builder cache(Cache cache)
      Parameters:
      cache - Caching strategy to use.
      Returns:
      this
    • checkSecretsInPlainTextEnvVariables

      @Stability(Stable) public PipelineProjectProps.Builder checkSecretsInPlainTextEnvVariables(Boolean checkSecretsInPlainTextEnvVariables)
      Parameters:
      checkSecretsInPlainTextEnvVariables - Whether to check for the presence of any secrets in the environment variables of the default type, BuildEnvironmentVariableType.PLAINTEXT. Since using a secret for the value of that kind of variable would result in it being displayed in plain text in the AWS Console, the construct will throw an exception if it detects a secret was passed there. Pass this property as false if you want to skip this validation, and keep using a secret in a plain text environment variable.
      Returns:
      this
    • concurrentBuildLimit

      @Stability(Stable) public PipelineProjectProps.Builder concurrentBuildLimit(Number concurrentBuildLimit)
      Parameters:
      concurrentBuildLimit - Maximum number of concurrent builds. Minimum value is 1 and maximum is account build limit.
      Returns:
      this
    • description

      @Stability(Stable) public PipelineProjectProps.Builder description(String description)
      Parameters:
      description - A description of the project. Use the description to identify the purpose of the project.
      Returns:
      this
    • encryptionKey

      @Stability(Stable) public PipelineProjectProps.Builder encryptionKey(IKey encryptionKey)
      Parameters:
      encryptionKey - Encryption key to use to read and write artifacts.
      Returns:
      this
    • environment

      @Stability(Stable) public PipelineProjectProps.Builder environment(BuildEnvironment environment)
      Parameters:
      environment - Build environment to use for the build.
      Returns:
      this
    • environmentVariables

      @Stability(Stable) public PipelineProjectProps.Builder environmentVariables(Map<String,? extends BuildEnvironmentVariable> environmentVariables)
      Parameters:
      environmentVariables - Additional environment variables to add to the build environment.
      Returns:
      this
    • fileSystemLocations

      @Stability(Stable) public PipelineProjectProps.Builder fileSystemLocations(List<? extends IFileSystemLocation> fileSystemLocations)
      Parameters:
      fileSystemLocations - An ProjectFileSystemLocation objects for a CodeBuild build project. A ProjectFileSystemLocation object specifies the identifier, location, mountOptions, mountPoint, and type of a file system created using Amazon Elastic File System.
      Returns:
      this
    • grantReportGroupPermissions

      @Stability(Stable) public PipelineProjectProps.Builder grantReportGroupPermissions(Boolean grantReportGroupPermissions)
      Parameters:
      grantReportGroupPermissions - Add permissions to this project's role to create and use test report groups with name starting with the name of this project. That is the standard report group that gets created when a simple name (in contrast to an ARN) is used in the 'reports' section of the buildspec of this project. This is usually harmless, but you can turn these off if you don't plan on using test reports in this project.
      Returns:
      this
    • logging

      @Stability(Stable) public PipelineProjectProps.Builder logging(LoggingOptions logging)
      Parameters:
      logging - Information about logs for the build project. A project can create logs in Amazon CloudWatch Logs, an S3 bucket, or both.
      Returns:
      this
    • projectName

      @Stability(Stable) public PipelineProjectProps.Builder projectName(String projectName)
      Parameters:
      projectName - The physical, human-readable name of the CodeBuild Project.
      Returns:
      this
    • queuedTimeout

      @Stability(Stable) public PipelineProjectProps.Builder queuedTimeout(Duration queuedTimeout)
      Parameters:
      queuedTimeout - The number of minutes after which AWS CodeBuild stops the build if it's still in queue. For valid values, see the timeoutInMinutes field in the AWS CodeBuild User Guide.
      Returns:
      this
    • role

      @Stability(Stable) public PipelineProjectProps.Builder role(IRole role)
      Parameters:
      role - Service Role to assume while running the build.
      Returns:
      this
    • securityGroups

      @Stability(Stable) public PipelineProjectProps.Builder securityGroups(List<? extends ISecurityGroup> securityGroups)
      Parameters:
      securityGroups - What security group to associate with the codebuild project's network interfaces. If no security group is identified, one will be created automatically.

      Only used if 'vpc' is supplied.

      Returns:
      this
    • ssmSessionPermissions

      @Stability(Stable) public PipelineProjectProps.Builder ssmSessionPermissions(Boolean ssmSessionPermissions)
      Parameters:
      ssmSessionPermissions - Add the permissions necessary for debugging builds with SSM Session Manager. If the following prerequisites have been met:

      • The necessary permissions have been added by setting this flag to true.
      • The build image has the SSM agent installed (true for default CodeBuild images).
      • The build is started with debugSessionEnabled set to true.

      Then the build container can be paused and inspected using Session Manager by invoking the codebuild-breakpoint command somewhere during the build.

      codebuild-breakpoint commands will be ignored if the build is not started with debugSessionEnabled=true.

      Returns:
      this
    • subnetSelection

      @Stability(Stable) public PipelineProjectProps.Builder subnetSelection(SubnetSelection subnetSelection)
      Parameters:
      subnetSelection - Where to place the network interfaces within the VPC. To access AWS services, your CodeBuild project needs to be in one of the following types of subnets:

      1. Subnets with access to the internet (of type PRIVATE_WITH_EGRESS).
      2. Private subnets unconnected to the internet, but with VPC endpoints for the necessary services.

      If you don't specify a subnet selection, the default behavior is to use PRIVATE_WITH_EGRESS subnets first if they exist, then PRIVATE_WITHOUT_EGRESS, and finally PUBLIC subnets. If your VPC doesn't have PRIVATE_WITH_EGRESS subnets but you need AWS service access, add VPC Endpoints to your private subnets.

      Returns:
      this
    • timeout

      @Stability(Stable) public PipelineProjectProps.Builder timeout(Duration timeout)
      Parameters:
      timeout - The number of minutes after which AWS CodeBuild stops the build if it's not complete. For valid values, see the timeoutInMinutes field in the AWS CodeBuild User Guide.
      Returns:
      this
    • visibility

      @Stability(Stable) public PipelineProjectProps.Builder visibility(ProjectVisibility visibility)
      Parameters:
      visibility - Specifies the visibility of the project's builds.
      Returns:
      this
    • vpc

      @Stability(Stable) public PipelineProjectProps.Builder vpc(IVpc vpc)
      Sets the value of CommonProjectProps.getVpc()
      Parameters:
      vpc - VPC network to place codebuild network interfaces. Specify this if the codebuild project needs to access resources in a VPC.
      Returns:
      this
    • build

      @Stability(Stable) public PipelineProjectProps build()
      Builds the configured instance.
      Specified by:
      build in interface software.amazon.jsii.Builder<PipelineProjectProps>
      Returns:
      a new instance of PipelineProjectProps
      Throws:
      NullPointerException - if any required attribute was not provided