software.amazon.awscdk.services.codebuild.GitHubEnterpriseSourceProps Maven / Gradle / Ivy
Show all versions of codebuild Show documentation
package software.amazon.awscdk.services.codebuild;
/**
* Construction properties for {@link GitHubEnterpriseSource}.
*/
@javax.annotation.Generated(value = "jsii-pacmak/0.22.0 (build 14afdde)", date = "2020-03-18T10:30:24.480Z")
@software.amazon.jsii.Jsii(module = software.amazon.awscdk.services.codebuild.$Module.class, fqn = "@aws-cdk/aws-codebuild.GitHubEnterpriseSourceProps")
@software.amazon.jsii.Jsii.Proxy(GitHubEnterpriseSourceProps.Jsii$Proxy.class)
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public interface GitHubEnterpriseSourceProps extends software.amazon.jsii.JsiiSerializable, software.amazon.awscdk.services.codebuild.SourceProps {
/**
* The HTTPS URL of the repository in your GitHub Enterprise installation.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
java.lang.String getHttpsCloneUrl();
/**
* The commit ID, pull request ID, branch name, or tag name that corresponds to the version of the source code you want to build.
*
* Default: the default branch's HEAD commit ID is used
*
* Example:
*
*
{@code
* // Example automatically generated without compilation. See https://github.com/aws/jsii/issues/826
* "mybranch";}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.lang.String getBranchOrRef() {
return null;
}
/**
* The depth of history to download.
*
* Minimum value is 0.
* If this value is 0, greater than 25, or not provided,
* then the full history is downloaded with each build of the project.
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.lang.Number getCloneDepth() {
return null;
}
/**
* Whether to ignore SSL errors when connecting to the repository.
*
* Default: false
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.lang.Boolean getIgnoreSslErrors() {
return null;
}
/**
* Whether to send notifications on your build's start and end.
*
* Default: true
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.lang.Boolean getReportBuildStatus() {
return null;
}
/**
* Whether to create a webhook that will trigger a build every time an event happens in the repository.
*
* Default: true if any `webhookFilters` were provided, false otherwise
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.lang.Boolean getWebhook() {
return null;
}
/**
* A list of webhook filters that can constraint what events in the repository will trigger a build.
*
* A build is triggered if any of the provided filter groups match.
* Only valid if webhook
was not provided as false.
*
* Default: every push and every Pull Request (create or update) triggers a build
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
default java.util.List getWebhookFilters() {
return null;
}
/**
* @return a {@link Builder} of {@link GitHubEnterpriseSourceProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
static Builder builder() {
return new Builder();
}
/**
* A builder for {@link GitHubEnterpriseSourceProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public static final class Builder {
private java.lang.String httpsCloneUrl;
private java.lang.String branchOrRef;
private java.lang.Number cloneDepth;
private java.lang.Boolean ignoreSslErrors;
private java.lang.Boolean reportBuildStatus;
private java.lang.Boolean webhook;
private java.util.List webhookFilters;
private java.lang.String identifier;
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getHttpsCloneUrl}
* @param httpsCloneUrl The HTTPS URL of the repository in your GitHub Enterprise installation. This parameter is required.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder httpsCloneUrl(java.lang.String httpsCloneUrl) {
this.httpsCloneUrl = httpsCloneUrl;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getBranchOrRef}
* @param branchOrRef The commit ID, pull request ID, branch name, or tag name that corresponds to the version of the source code you want to build.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder branchOrRef(java.lang.String branchOrRef) {
this.branchOrRef = branchOrRef;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getCloneDepth}
* @param cloneDepth The depth of history to download.
* Minimum value is 0.
* If this value is 0, greater than 25, or not provided,
* then the full history is downloaded with each build of the project.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder cloneDepth(java.lang.Number cloneDepth) {
this.cloneDepth = cloneDepth;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getIgnoreSslErrors}
* @param ignoreSslErrors Whether to ignore SSL errors when connecting to the repository.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder ignoreSslErrors(java.lang.Boolean ignoreSslErrors) {
this.ignoreSslErrors = ignoreSslErrors;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getReportBuildStatus}
* @param reportBuildStatus Whether to send notifications on your build's start and end.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder reportBuildStatus(java.lang.Boolean reportBuildStatus) {
this.reportBuildStatus = reportBuildStatus;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getWebhook}
* @param webhook Whether to create a webhook that will trigger a build every time an event happens in the repository.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder webhook(java.lang.Boolean webhook) {
this.webhook = webhook;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getWebhookFilters}
* @param webhookFilters A list of webhook filters that can constraint what events in the repository will trigger a build.
* A build is triggered if any of the provided filter groups match.
* Only valid if webhook
was not provided as false.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder webhookFilters(java.util.List webhookFilters) {
this.webhookFilters = webhookFilters;
return this;
}
/**
* Sets the value of {@link GitHubEnterpriseSourceProps#getIdentifier}
* @param identifier The source identifier.
* This property is required on secondary sources.
* @return {@code this}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public Builder identifier(java.lang.String identifier) {
this.identifier = identifier;
return this;
}
/**
* Builds the configured instance.
* @return a new instance of {@link GitHubEnterpriseSourceProps}
* @throws NullPointerException if any required attribute was not provided
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
public GitHubEnterpriseSourceProps build() {
return new Jsii$Proxy(httpsCloneUrl, branchOrRef, cloneDepth, ignoreSslErrors, reportBuildStatus, webhook, webhookFilters, identifier);
}
}
/**
* An implementation for {@link GitHubEnterpriseSourceProps}
*/
@software.amazon.jsii.Stability(software.amazon.jsii.Stability.Level.Stable)
final class Jsii$Proxy extends software.amazon.jsii.JsiiObject implements GitHubEnterpriseSourceProps {
private final java.lang.String httpsCloneUrl;
private final java.lang.String branchOrRef;
private final java.lang.Number cloneDepth;
private final java.lang.Boolean ignoreSslErrors;
private final java.lang.Boolean reportBuildStatus;
private final java.lang.Boolean webhook;
private final java.util.List webhookFilters;
private final java.lang.String identifier;
/**
* Constructor that initializes the object based on values retrieved from the JsiiObject.
* @param objRef Reference to the JSII managed object.
*/
protected Jsii$Proxy(final software.amazon.jsii.JsiiObjectRef objRef) {
super(objRef);
this.httpsCloneUrl = this.jsiiGet("httpsCloneUrl", java.lang.String.class);
this.branchOrRef = this.jsiiGet("branchOrRef", java.lang.String.class);
this.cloneDepth = this.jsiiGet("cloneDepth", java.lang.Number.class);
this.ignoreSslErrors = this.jsiiGet("ignoreSslErrors", java.lang.Boolean.class);
this.reportBuildStatus = this.jsiiGet("reportBuildStatus", java.lang.Boolean.class);
this.webhook = this.jsiiGet("webhook", java.lang.Boolean.class);
this.webhookFilters = this.jsiiGet("webhookFilters", software.amazon.jsii.NativeType.listOf(software.amazon.jsii.NativeType.forClass(software.amazon.awscdk.services.codebuild.FilterGroup.class)));
this.identifier = this.jsiiGet("identifier", java.lang.String.class);
}
/**
* Constructor that initializes the object based on literal property values passed by the {@link Builder}.
*/
private Jsii$Proxy(final java.lang.String httpsCloneUrl, final java.lang.String branchOrRef, final java.lang.Number cloneDepth, final java.lang.Boolean ignoreSslErrors, final java.lang.Boolean reportBuildStatus, final java.lang.Boolean webhook, final java.util.List webhookFilters, final java.lang.String identifier) {
super(software.amazon.jsii.JsiiObject.InitializationMode.JSII);
this.httpsCloneUrl = java.util.Objects.requireNonNull(httpsCloneUrl, "httpsCloneUrl is required");
this.branchOrRef = branchOrRef;
this.cloneDepth = cloneDepth;
this.ignoreSslErrors = ignoreSslErrors;
this.reportBuildStatus = reportBuildStatus;
this.webhook = webhook;
this.webhookFilters = webhookFilters;
this.identifier = identifier;
}
@Override
public java.lang.String getHttpsCloneUrl() {
return this.httpsCloneUrl;
}
@Override
public java.lang.String getBranchOrRef() {
return this.branchOrRef;
}
@Override
public java.lang.Number getCloneDepth() {
return this.cloneDepth;
}
@Override
public java.lang.Boolean getIgnoreSslErrors() {
return this.ignoreSslErrors;
}
@Override
public java.lang.Boolean getReportBuildStatus() {
return this.reportBuildStatus;
}
@Override
public java.lang.Boolean getWebhook() {
return this.webhook;
}
@Override
public java.util.List getWebhookFilters() {
return this.webhookFilters;
}
@Override
public java.lang.String getIdentifier() {
return this.identifier;
}
@Override
public com.fasterxml.jackson.databind.JsonNode $jsii$toJson() {
final com.fasterxml.jackson.databind.ObjectMapper om = software.amazon.jsii.JsiiObjectMapper.INSTANCE;
final com.fasterxml.jackson.databind.node.ObjectNode data = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
data.set("httpsCloneUrl", om.valueToTree(this.getHttpsCloneUrl()));
if (this.getBranchOrRef() != null) {
data.set("branchOrRef", om.valueToTree(this.getBranchOrRef()));
}
if (this.getCloneDepth() != null) {
data.set("cloneDepth", om.valueToTree(this.getCloneDepth()));
}
if (this.getIgnoreSslErrors() != null) {
data.set("ignoreSslErrors", om.valueToTree(this.getIgnoreSslErrors()));
}
if (this.getReportBuildStatus() != null) {
data.set("reportBuildStatus", om.valueToTree(this.getReportBuildStatus()));
}
if (this.getWebhook() != null) {
data.set("webhook", om.valueToTree(this.getWebhook()));
}
if (this.getWebhookFilters() != null) {
data.set("webhookFilters", om.valueToTree(this.getWebhookFilters()));
}
if (this.getIdentifier() != null) {
data.set("identifier", om.valueToTree(this.getIdentifier()));
}
final com.fasterxml.jackson.databind.node.ObjectNode struct = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
struct.set("fqn", om.valueToTree("@aws-cdk/aws-codebuild.GitHubEnterpriseSourceProps"));
struct.set("data", data);
final com.fasterxml.jackson.databind.node.ObjectNode obj = com.fasterxml.jackson.databind.node.JsonNodeFactory.instance.objectNode();
obj.set("$jsii.struct", struct);
return obj;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
GitHubEnterpriseSourceProps.Jsii$Proxy that = (GitHubEnterpriseSourceProps.Jsii$Proxy) o;
if (!httpsCloneUrl.equals(that.httpsCloneUrl)) return false;
if (this.branchOrRef != null ? !this.branchOrRef.equals(that.branchOrRef) : that.branchOrRef != null) return false;
if (this.cloneDepth != null ? !this.cloneDepth.equals(that.cloneDepth) : that.cloneDepth != null) return false;
if (this.ignoreSslErrors != null ? !this.ignoreSslErrors.equals(that.ignoreSslErrors) : that.ignoreSslErrors != null) return false;
if (this.reportBuildStatus != null ? !this.reportBuildStatus.equals(that.reportBuildStatus) : that.reportBuildStatus != null) return false;
if (this.webhook != null ? !this.webhook.equals(that.webhook) : that.webhook != null) return false;
if (this.webhookFilters != null ? !this.webhookFilters.equals(that.webhookFilters) : that.webhookFilters != null) return false;
return this.identifier != null ? this.identifier.equals(that.identifier) : that.identifier == null;
}
@Override
public int hashCode() {
int result = this.httpsCloneUrl.hashCode();
result = 31 * result + (this.branchOrRef != null ? this.branchOrRef.hashCode() : 0);
result = 31 * result + (this.cloneDepth != null ? this.cloneDepth.hashCode() : 0);
result = 31 * result + (this.ignoreSslErrors != null ? this.ignoreSslErrors.hashCode() : 0);
result = 31 * result + (this.reportBuildStatus != null ? this.reportBuildStatus.hashCode() : 0);
result = 31 * result + (this.webhook != null ? this.webhook.hashCode() : 0);
result = 31 * result + (this.webhookFilters != null ? this.webhookFilters.hashCode() : 0);
result = 31 * result + (this.identifier != null ? this.identifier.hashCode() : 0);
return result;
}
}
}