software.amazon.awssdk.services.codestarconnections.model.CreateSyncConfigurationRequest Maven / Gradle / Ivy
Show all versions of codestarconnections Show documentation
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
* the License. A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package software.amazon.awssdk.services.codestarconnections.model;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.awscore.AwsRequestOverrideConfiguration;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*/
@Generated("software.amazon.awssdk:codegen")
public final class CreateSyncConfigurationRequest extends CodeStarConnectionsRequest implements
ToCopyableBuilder {
private static final SdkField BRANCH_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Branch")
.getter(getter(CreateSyncConfigurationRequest::branch)).setter(setter(Builder::branch))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Branch").build()).build();
private static final SdkField CONFIG_FILE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ConfigFile").getter(getter(CreateSyncConfigurationRequest::configFile))
.setter(setter(Builder::configFile))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ConfigFile").build()).build();
private static final SdkField REPOSITORY_LINK_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("RepositoryLinkId").getter(getter(CreateSyncConfigurationRequest::repositoryLinkId))
.setter(setter(Builder::repositoryLinkId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RepositoryLinkId").build()).build();
private static final SdkField RESOURCE_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("ResourceName").getter(getter(CreateSyncConfigurationRequest::resourceName))
.setter(setter(Builder::resourceName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ResourceName").build()).build();
private static final SdkField ROLE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("RoleArn").getter(getter(CreateSyncConfigurationRequest::roleArn)).setter(setter(Builder::roleArn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RoleArn").build()).build();
private static final SdkField SYNC_TYPE_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("SyncType").getter(getter(CreateSyncConfigurationRequest::syncTypeAsString))
.setter(setter(Builder::syncType))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SyncType").build()).build();
private static final SdkField PUBLISH_DEPLOYMENT_STATUS_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("PublishDeploymentStatus")
.getter(getter(CreateSyncConfigurationRequest::publishDeploymentStatusAsString))
.setter(setter(Builder::publishDeploymentStatus))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PublishDeploymentStatus").build())
.build();
private static final SdkField TRIGGER_RESOURCE_UPDATE_ON_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("TriggerResourceUpdateOn")
.getter(getter(CreateSyncConfigurationRequest::triggerResourceUpdateOnAsString))
.setter(setter(Builder::triggerResourceUpdateOn))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TriggerResourceUpdateOn").build())
.build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(BRANCH_FIELD,
CONFIG_FILE_FIELD, REPOSITORY_LINK_ID_FIELD, RESOURCE_NAME_FIELD, ROLE_ARN_FIELD, SYNC_TYPE_FIELD,
PUBLISH_DEPLOYMENT_STATUS_FIELD, TRIGGER_RESOURCE_UPDATE_ON_FIELD));
private final String branch;
private final String configFile;
private final String repositoryLinkId;
private final String resourceName;
private final String roleArn;
private final String syncType;
private final String publishDeploymentStatus;
private final String triggerResourceUpdateOn;
private CreateSyncConfigurationRequest(BuilderImpl builder) {
super(builder);
this.branch = builder.branch;
this.configFile = builder.configFile;
this.repositoryLinkId = builder.repositoryLinkId;
this.resourceName = builder.resourceName;
this.roleArn = builder.roleArn;
this.syncType = builder.syncType;
this.publishDeploymentStatus = builder.publishDeploymentStatus;
this.triggerResourceUpdateOn = builder.triggerResourceUpdateOn;
}
/**
*
* The branch in the repository from which changes will be synced.
*
*
* @return The branch in the repository from which changes will be synced.
*/
public final String branch() {
return branch;
}
/**
*
* The file name of the configuration file that manages syncing between the connection and the repository. This
* configuration file is stored in the repository.
*
*
* @return The file name of the configuration file that manages syncing between the connection and the repository.
* This configuration file is stored in the repository.
*/
public final String configFile() {
return configFile;
}
/**
*
* The ID of the repository link created for the connection. A repository link allows Git sync to monitor and sync
* changes to files in a specified Git repository.
*
*
* @return The ID of the repository link created for the connection. A repository link allows Git sync to monitor
* and sync changes to files in a specified Git repository.
*/
public final String repositoryLinkId() {
return repositoryLinkId;
}
/**
*
* The name of the Amazon Web Services resource (for example, a CloudFormation stack in the case of CFN_STACK_SYNC)
* that will be synchronized from the linked repository.
*
*
* @return The name of the Amazon Web Services resource (for example, a CloudFormation stack in the case of
* CFN_STACK_SYNC) that will be synchronized from the linked repository.
*/
public final String resourceName() {
return resourceName;
}
/**
*
* The ARN of the IAM role that grants permission for Amazon Web Services to use Git sync to update a given Amazon
* Web Services resource on your behalf.
*
*
* @return The ARN of the IAM role that grants permission for Amazon Web Services to use Git sync to update a given
* Amazon Web Services resource on your behalf.
*/
public final String roleArn() {
return roleArn;
}
/**
*
* The type of sync configuration.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #syncType} will
* return {@link SyncConfigurationType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available
* from {@link #syncTypeAsString}.
*
*
* @return The type of sync configuration.
* @see SyncConfigurationType
*/
public final SyncConfigurationType syncType() {
return SyncConfigurationType.fromValue(syncType);
}
/**
*
* The type of sync configuration.
*
*
* If the service returns an enum value that is not available in the current SDK version, {@link #syncType} will
* return {@link SyncConfigurationType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available
* from {@link #syncTypeAsString}.
*
*
* @return The type of sync configuration.
* @see SyncConfigurationType
*/
public final String syncTypeAsString() {
return syncType;
}
/**
*
* Whether to enable or disable publishing of deployment status to source providers.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #publishDeploymentStatus} will return {@link PublishDeploymentStatus#UNKNOWN_TO_SDK_VERSION}. The raw
* value returned by the service is available from {@link #publishDeploymentStatusAsString}.
*
*
* @return Whether to enable or disable publishing of deployment status to source providers.
* @see PublishDeploymentStatus
*/
public final PublishDeploymentStatus publishDeploymentStatus() {
return PublishDeploymentStatus.fromValue(publishDeploymentStatus);
}
/**
*
* Whether to enable or disable publishing of deployment status to source providers.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #publishDeploymentStatus} will return {@link PublishDeploymentStatus#UNKNOWN_TO_SDK_VERSION}. The raw
* value returned by the service is available from {@link #publishDeploymentStatusAsString}.
*
*
* @return Whether to enable or disable publishing of deployment status to source providers.
* @see PublishDeploymentStatus
*/
public final String publishDeploymentStatusAsString() {
return publishDeploymentStatus;
}
/**
*
* When to trigger Git sync to begin the stack update.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #triggerResourceUpdateOn} will return {@link TriggerResourceUpdateOn#UNKNOWN_TO_SDK_VERSION}. The raw
* value returned by the service is available from {@link #triggerResourceUpdateOnAsString}.
*
*
* @return When to trigger Git sync to begin the stack update.
* @see TriggerResourceUpdateOn
*/
public final TriggerResourceUpdateOn triggerResourceUpdateOn() {
return TriggerResourceUpdateOn.fromValue(triggerResourceUpdateOn);
}
/**
*
* When to trigger Git sync to begin the stack update.
*
*
* If the service returns an enum value that is not available in the current SDK version,
* {@link #triggerResourceUpdateOn} will return {@link TriggerResourceUpdateOn#UNKNOWN_TO_SDK_VERSION}. The raw
* value returned by the service is available from {@link #triggerResourceUpdateOnAsString}.
*
*
* @return When to trigger Git sync to begin the stack update.
* @see TriggerResourceUpdateOn
*/
public final String triggerResourceUpdateOnAsString() {
return triggerResourceUpdateOn;
}
@Override
public Builder toBuilder() {
return new BuilderImpl(this);
}
public static Builder builder() {
return new BuilderImpl();
}
public static Class extends Builder> serializableBuilderClass() {
return BuilderImpl.class;
}
@Override
public final int hashCode() {
int hashCode = 1;
hashCode = 31 * hashCode + super.hashCode();
hashCode = 31 * hashCode + Objects.hashCode(branch());
hashCode = 31 * hashCode + Objects.hashCode(configFile());
hashCode = 31 * hashCode + Objects.hashCode(repositoryLinkId());
hashCode = 31 * hashCode + Objects.hashCode(resourceName());
hashCode = 31 * hashCode + Objects.hashCode(roleArn());
hashCode = 31 * hashCode + Objects.hashCode(syncTypeAsString());
hashCode = 31 * hashCode + Objects.hashCode(publishDeploymentStatusAsString());
hashCode = 31 * hashCode + Objects.hashCode(triggerResourceUpdateOnAsString());
return hashCode;
}
@Override
public final boolean equals(Object obj) {
return super.equals(obj) && equalsBySdkFields(obj);
}
@Override
public final boolean equalsBySdkFields(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof CreateSyncConfigurationRequest)) {
return false;
}
CreateSyncConfigurationRequest other = (CreateSyncConfigurationRequest) obj;
return Objects.equals(branch(), other.branch()) && Objects.equals(configFile(), other.configFile())
&& Objects.equals(repositoryLinkId(), other.repositoryLinkId())
&& Objects.equals(resourceName(), other.resourceName()) && Objects.equals(roleArn(), other.roleArn())
&& Objects.equals(syncTypeAsString(), other.syncTypeAsString())
&& Objects.equals(publishDeploymentStatusAsString(), other.publishDeploymentStatusAsString())
&& Objects.equals(triggerResourceUpdateOnAsString(), other.triggerResourceUpdateOnAsString());
}
/**
* Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be
* redacted from this string using a placeholder value.
*/
@Override
public final String toString() {
return ToString.builder("CreateSyncConfigurationRequest").add("Branch", branch()).add("ConfigFile", configFile())
.add("RepositoryLinkId", repositoryLinkId()).add("ResourceName", resourceName()).add("RoleArn", roleArn())
.add("SyncType", syncTypeAsString()).add("PublishDeploymentStatus", publishDeploymentStatusAsString())
.add("TriggerResourceUpdateOn", triggerResourceUpdateOnAsString()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "Branch":
return Optional.ofNullable(clazz.cast(branch()));
case "ConfigFile":
return Optional.ofNullable(clazz.cast(configFile()));
case "RepositoryLinkId":
return Optional.ofNullable(clazz.cast(repositoryLinkId()));
case "ResourceName":
return Optional.ofNullable(clazz.cast(resourceName()));
case "RoleArn":
return Optional.ofNullable(clazz.cast(roleArn()));
case "SyncType":
return Optional.ofNullable(clazz.cast(syncTypeAsString()));
case "PublishDeploymentStatus":
return Optional.ofNullable(clazz.cast(publishDeploymentStatusAsString()));
case "TriggerResourceUpdateOn":
return Optional.ofNullable(clazz.cast(triggerResourceUpdateOnAsString()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function