createProject method

Future<CreateProjectOutput> createProject({
  1. required ProjectArtifacts artifacts,
  2. required ProjectEnvironment environment,
  3. required String name,
  4. required String serviceRole,
  5. required ProjectSource source,
  6. bool? badgeEnabled,
  7. ProjectBuildBatchConfig? buildBatchConfig,
  8. ProjectCache? cache,
  9. String? description,
  10. String? encryptionKey,
  11. List<ProjectFileSystemLocation>? fileSystemLocations,
  12. LogsConfig? logsConfig,
  13. int? queuedTimeoutInMinutes,
  14. List<ProjectArtifacts>? secondaryArtifacts,
  15. List<ProjectSourceVersion>? secondarySourceVersions,
  16. List<ProjectSource>? secondarySources,
  17. String? sourceVersion,
  18. List<Tag>? tags,
  19. int? timeoutInMinutes,
  20. VpcConfig? vpcConfig,
})

Creates a build project.

May throw InvalidInputException. May throw ResourceAlreadyExistsException. May throw AccountLimitExceededException.

Parameter artifacts : Information about the build output artifacts for the build project.

Parameter environment : Information about the build environment for the build project.

Parameter name : The name of the build project.

Parameter serviceRole : The ARN of the AWS Identity and Access Management (IAM) role that enables AWS CodeBuild to interact with dependent AWS services on behalf of the AWS account.

Parameter source : Information about the build input source code for the build project.

Parameter badgeEnabled : Set this to true to generate a publicly accessible URL for your project's build badge.

Parameter buildBatchConfig : A ProjectBuildBatchConfig object that defines the batch build options for the project.

Parameter cache : Stores recently used information so that it can be quickly accessed at a later time.

Parameter description : A description that makes the build project easy to identify.

Parameter encryptionKey : The AWS Key Management Service (AWS KMS) customer master key (CMK) to be used for encrypting the build output artifacts. You can specify either the Amazon Resource Name (ARN) of the CMK or, if available, the CMK's alias (using the format alias/<alias-name>).

Parameter fileSystemLocations : An array of 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.

Parameter logsConfig : Information about logs for the build project. These can be logs in Amazon CloudWatch Logs, logs uploaded to a specified S3 bucket, or both.

Parameter queuedTimeoutInMinutes : The number of minutes a build is allowed to be queued before it times out.

Parameter secondaryArtifacts : An array of ProjectArtifacts objects.

Parameter secondarySourceVersions : An array of ProjectSourceVersion objects. If secondarySourceVersions is specified at the build level, then they take precedence over these secondarySourceVersions (at the project level).

Parameter secondarySources : An array of ProjectSource objects.

Parameter sourceVersion : A version of the build input to be built for this project. If not specified, the latest version is used. If specified, it must be one of:

  • For AWS CodeCommit: the commit ID, branch, or Git tag to use.
  • For GitHub: the commit ID, pull request ID, branch name, or tag name that corresponds to the version of the source code you want to build. If a pull request ID is specified, it must use the format pr/pull-request-ID (for example pr/25). If a branch name is specified, the branch's HEAD commit ID is used. If not specified, the default branch's HEAD commit ID is used.
  • For Bitbucket: the commit ID, branch name, or tag name that corresponds to the version of the source code you want to build. If a branch name is specified, the branch's HEAD commit ID is used. If not specified, the default branch's HEAD commit ID is used.
  • For Amazon Simple Storage Service (Amazon S3): the version ID of the object that represents the build input ZIP file to use.
If sourceVersion is specified at the build level, then that version takes precedence over this sourceVersion (at the project level).

For more information, see Source Version Sample with CodeBuild in the AWS CodeBuild User Guide.

Parameter tags : A list of tag key and value pairs associated with this build project.

These tags are available for use by AWS services that support AWS CodeBuild build project tags.

Parameter timeoutInMinutes : How long, in minutes, from 5 to 480 (8 hours), for AWS CodeBuild to wait before it times out any build that has not been marked as completed. The default is 60 minutes.

Parameter vpcConfig : VpcConfig enables AWS CodeBuild to access resources in an Amazon VPC.

Implementation

Future<CreateProjectOutput> createProject({
  required ProjectArtifacts artifacts,
  required ProjectEnvironment environment,
  required String name,
  required String serviceRole,
  required ProjectSource source,
  bool? badgeEnabled,
  ProjectBuildBatchConfig? buildBatchConfig,
  ProjectCache? cache,
  String? description,
  String? encryptionKey,
  List<ProjectFileSystemLocation>? fileSystemLocations,
  LogsConfig? logsConfig,
  int? queuedTimeoutInMinutes,
  List<ProjectArtifacts>? secondaryArtifacts,
  List<ProjectSourceVersion>? secondarySourceVersions,
  List<ProjectSource>? secondarySources,
  String? sourceVersion,
  List<Tag>? tags,
  int? timeoutInMinutes,
  VpcConfig? vpcConfig,
}) async {
  ArgumentError.checkNotNull(artifacts, 'artifacts');
  ArgumentError.checkNotNull(environment, 'environment');
  ArgumentError.checkNotNull(name, 'name');
  _s.validateStringLength(
    'name',
    name,
    2,
    255,
    isRequired: true,
  );
  ArgumentError.checkNotNull(serviceRole, 'serviceRole');
  _s.validateStringLength(
    'serviceRole',
    serviceRole,
    1,
    1152921504606846976,
    isRequired: true,
  );
  ArgumentError.checkNotNull(source, 'source');
  _s.validateStringLength(
    'description',
    description,
    0,
    255,
  );
  _s.validateStringLength(
    'encryptionKey',
    encryptionKey,
    1,
    1152921504606846976,
  );
  _s.validateNumRange(
    'queuedTimeoutInMinutes',
    queuedTimeoutInMinutes,
    5,
    480,
  );
  _s.validateNumRange(
    'timeoutInMinutes',
    timeoutInMinutes,
    5,
    480,
  );
  final headers = <String, String>{
    'Content-Type': 'application/x-amz-json-1.1',
    'X-Amz-Target': 'CodeBuild_20161006.CreateProject'
  };
  final jsonResponse = await _protocol.send(
    method: 'POST',
    requestUri: '/',
    exceptionFnMap: _exceptionFns,
    // TODO queryParams
    headers: headers,
    payload: {
      'artifacts': artifacts,
      'environment': environment,
      'name': name,
      'serviceRole': serviceRole,
      'source': source,
      if (badgeEnabled != null) 'badgeEnabled': badgeEnabled,
      if (buildBatchConfig != null) 'buildBatchConfig': buildBatchConfig,
      if (cache != null) 'cache': cache,
      if (description != null) 'description': description,
      if (encryptionKey != null) 'encryptionKey': encryptionKey,
      if (fileSystemLocations != null)
        'fileSystemLocations': fileSystemLocations,
      if (logsConfig != null) 'logsConfig': logsConfig,
      if (queuedTimeoutInMinutes != null)
        'queuedTimeoutInMinutes': queuedTimeoutInMinutes,
      if (secondaryArtifacts != null)
        'secondaryArtifacts': secondaryArtifacts,
      if (secondarySourceVersions != null)
        'secondarySourceVersions': secondarySourceVersions,
      if (secondarySources != null) 'secondarySources': secondarySources,
      if (sourceVersion != null) 'sourceVersion': sourceVersion,
      if (tags != null) 'tags': tags,
      if (timeoutInMinutes != null) 'timeoutInMinutes': timeoutInMinutes,
      if (vpcConfig != null) 'vpcConfig': vpcConfig,
    },
  );

  return CreateProjectOutput.fromJson(jsonResponse.body);
}