All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.codestarconnections.model.GetResourceSyncStatusResponse Maven / Gradle / Ivy

/*
 * 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.HashMap;
import java.util.List;
import java.util.Map;
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.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 GetResourceSyncStatusResponse extends CodeStarConnectionsResponse implements
        ToCopyableBuilder {
    private static final SdkField DESIRED_STATE_FIELD = SdkField. builder(MarshallingType.SDK_POJO)
            .memberName("DesiredState").getter(getter(GetResourceSyncStatusResponse::desiredState))
            .setter(setter(Builder::desiredState)).constructor(Revision::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("DesiredState").build()).build();

    private static final SdkField LATEST_SUCCESSFUL_SYNC_FIELD = SdkField
            . builder(MarshallingType.SDK_POJO).memberName("LatestSuccessfulSync")
            .getter(getter(GetResourceSyncStatusResponse::latestSuccessfulSync)).setter(setter(Builder::latestSuccessfulSync))
            .constructor(ResourceSyncAttempt::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LatestSuccessfulSync").build())
            .build();

    private static final SdkField LATEST_SYNC_FIELD = SdkField
            . builder(MarshallingType.SDK_POJO).memberName("LatestSync")
            .getter(getter(GetResourceSyncStatusResponse::latestSync)).setter(setter(Builder::latestSync))
            .constructor(ResourceSyncAttempt::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LatestSync").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(DESIRED_STATE_FIELD,
            LATEST_SUCCESSFUL_SYNC_FIELD, LATEST_SYNC_FIELD));

    private static final Map> SDK_NAME_TO_FIELD = memberNameToFieldInitializer();

    private final Revision desiredState;

    private final ResourceSyncAttempt latestSuccessfulSync;

    private final ResourceSyncAttempt latestSync;

    private GetResourceSyncStatusResponse(BuilderImpl builder) {
        super(builder);
        this.desiredState = builder.desiredState;
        this.latestSuccessfulSync = builder.latestSuccessfulSync;
        this.latestSync = builder.latestSync;
    }

    /**
     * 

* The desired state of the Amazon Web Services resource for the sync status with the Git repository. *

* * @return The desired state of the Amazon Web Services resource for the sync status with the Git repository. */ public final Revision desiredState() { return desiredState; } /** *

* The latest successful sync for the sync status with the Git repository. *

* * @return The latest successful sync for the sync status with the Git repository. */ public final ResourceSyncAttempt latestSuccessfulSync() { return latestSuccessfulSync; } /** *

* The latest sync for the sync status with the Git repository, whether successful or not. *

* * @return The latest sync for the sync status with the Git repository, whether successful or not. */ public final ResourceSyncAttempt latestSync() { return latestSync; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + super.hashCode(); hashCode = 31 * hashCode + Objects.hashCode(desiredState()); hashCode = 31 * hashCode + Objects.hashCode(latestSuccessfulSync()); hashCode = 31 * hashCode + Objects.hashCode(latestSync()); 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 GetResourceSyncStatusResponse)) { return false; } GetResourceSyncStatusResponse other = (GetResourceSyncStatusResponse) obj; return Objects.equals(desiredState(), other.desiredState()) && Objects.equals(latestSuccessfulSync(), other.latestSuccessfulSync()) && Objects.equals(latestSync(), other.latestSync()); } /** * 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("GetResourceSyncStatusResponse").add("DesiredState", desiredState()) .add("LatestSuccessfulSync", latestSuccessfulSync()).add("LatestSync", latestSync()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "DesiredState": return Optional.ofNullable(clazz.cast(desiredState())); case "LatestSuccessfulSync": return Optional.ofNullable(clazz.cast(latestSuccessfulSync())); case "LatestSync": return Optional.ofNullable(clazz.cast(latestSync())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } @Override public final Map> sdkFieldNameToField() { return SDK_NAME_TO_FIELD; } private static Map> memberNameToFieldInitializer() { Map> map = new HashMap<>(); map.put("DesiredState", DESIRED_STATE_FIELD); map.put("LatestSuccessfulSync", LATEST_SUCCESSFUL_SYNC_FIELD); map.put("LatestSync", LATEST_SYNC_FIELD); return Collections.unmodifiableMap(map); } private static Function getter(Function g) { return obj -> g.apply((GetResourceSyncStatusResponse) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends CodeStarConnectionsResponse.Builder, SdkPojo, CopyableBuilder { /** *

* The desired state of the Amazon Web Services resource for the sync status with the Git repository. *

* * @param desiredState * The desired state of the Amazon Web Services resource for the sync status with the Git repository. * @return Returns a reference to this object so that method calls can be chained together. */ Builder desiredState(Revision desiredState); /** *

* The desired state of the Amazon Web Services resource for the sync status with the Git repository. *

* This is a convenience method that creates an instance of the {@link Revision.Builder} avoiding the need to * create one manually via {@link Revision#builder()}. * *

* When the {@link Consumer} completes, {@link Revision.Builder#build()} is called immediately and its result is * passed to {@link #desiredState(Revision)}. * * @param desiredState * a consumer that will call methods on {@link Revision.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #desiredState(Revision) */ default Builder desiredState(Consumer desiredState) { return desiredState(Revision.builder().applyMutation(desiredState).build()); } /** *

* The latest successful sync for the sync status with the Git repository. *

* * @param latestSuccessfulSync * The latest successful sync for the sync status with the Git repository. * @return Returns a reference to this object so that method calls can be chained together. */ Builder latestSuccessfulSync(ResourceSyncAttempt latestSuccessfulSync); /** *

* The latest successful sync for the sync status with the Git repository. *

* This is a convenience method that creates an instance of the {@link ResourceSyncAttempt.Builder} avoiding the * need to create one manually via {@link ResourceSyncAttempt#builder()}. * *

* When the {@link Consumer} completes, {@link ResourceSyncAttempt.Builder#build()} is called immediately and * its result is passed to {@link #latestSuccessfulSync(ResourceSyncAttempt)}. * * @param latestSuccessfulSync * a consumer that will call methods on {@link ResourceSyncAttempt.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #latestSuccessfulSync(ResourceSyncAttempt) */ default Builder latestSuccessfulSync(Consumer latestSuccessfulSync) { return latestSuccessfulSync(ResourceSyncAttempt.builder().applyMutation(latestSuccessfulSync).build()); } /** *

* The latest sync for the sync status with the Git repository, whether successful or not. *

* * @param latestSync * The latest sync for the sync status with the Git repository, whether successful or not. * @return Returns a reference to this object so that method calls can be chained together. */ Builder latestSync(ResourceSyncAttempt latestSync); /** *

* The latest sync for the sync status with the Git repository, whether successful or not. *

* This is a convenience method that creates an instance of the {@link ResourceSyncAttempt.Builder} avoiding the * need to create one manually via {@link ResourceSyncAttempt#builder()}. * *

* When the {@link Consumer} completes, {@link ResourceSyncAttempt.Builder#build()} is called immediately and * its result is passed to {@link #latestSync(ResourceSyncAttempt)}. * * @param latestSync * a consumer that will call methods on {@link ResourceSyncAttempt.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #latestSync(ResourceSyncAttempt) */ default Builder latestSync(Consumer latestSync) { return latestSync(ResourceSyncAttempt.builder().applyMutation(latestSync).build()); } } static final class BuilderImpl extends CodeStarConnectionsResponse.BuilderImpl implements Builder { private Revision desiredState; private ResourceSyncAttempt latestSuccessfulSync; private ResourceSyncAttempt latestSync; private BuilderImpl() { } private BuilderImpl(GetResourceSyncStatusResponse model) { super(model); desiredState(model.desiredState); latestSuccessfulSync(model.latestSuccessfulSync); latestSync(model.latestSync); } public final Revision.Builder getDesiredState() { return desiredState != null ? desiredState.toBuilder() : null; } public final void setDesiredState(Revision.BuilderImpl desiredState) { this.desiredState = desiredState != null ? desiredState.build() : null; } @Override public final Builder desiredState(Revision desiredState) { this.desiredState = desiredState; return this; } public final ResourceSyncAttempt.Builder getLatestSuccessfulSync() { return latestSuccessfulSync != null ? latestSuccessfulSync.toBuilder() : null; } public final void setLatestSuccessfulSync(ResourceSyncAttempt.BuilderImpl latestSuccessfulSync) { this.latestSuccessfulSync = latestSuccessfulSync != null ? latestSuccessfulSync.build() : null; } @Override public final Builder latestSuccessfulSync(ResourceSyncAttempt latestSuccessfulSync) { this.latestSuccessfulSync = latestSuccessfulSync; return this; } public final ResourceSyncAttempt.Builder getLatestSync() { return latestSync != null ? latestSync.toBuilder() : null; } public final void setLatestSync(ResourceSyncAttempt.BuilderImpl latestSync) { this.latestSync = latestSync != null ? latestSync.build() : null; } @Override public final Builder latestSync(ResourceSyncAttempt latestSync) { this.latestSync = latestSync; return this; } @Override public GetResourceSyncStatusResponse build() { return new GetResourceSyncStatusResponse(this); } @Override public List> sdkFields() { return SDK_FIELDS; } @Override public Map> sdkFieldNameToField() { return SDK_NAME_TO_FIELD; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy