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

software.amazon.awssdk.services.eventbridge.model.CreateEndpointRequest 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.eventbridge.model;

import java.util.Arrays;
import java.util.Collection;
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 java.util.stream.Collectors;
import java.util.stream.Stream;
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.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
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 CreateEndpointRequest extends EventBridgeRequest implements
        ToCopyableBuilder {
    private static final SdkField NAME_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Name")
            .getter(getter(CreateEndpointRequest::name)).setter(setter(Builder::name))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Name").build()).build();

    private static final SdkField DESCRIPTION_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("Description").getter(getter(CreateEndpointRequest::description)).setter(setter(Builder::description))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Description").build()).build();

    private static final SdkField ROUTING_CONFIG_FIELD = SdkField
            . builder(MarshallingType.SDK_POJO).memberName("RoutingConfig")
            .getter(getter(CreateEndpointRequest::routingConfig)).setter(setter(Builder::routingConfig))
            .constructor(RoutingConfig::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RoutingConfig").build()).build();

    private static final SdkField REPLICATION_CONFIG_FIELD = SdkField
            . builder(MarshallingType.SDK_POJO).memberName("ReplicationConfig")
            .getter(getter(CreateEndpointRequest::replicationConfig)).setter(setter(Builder::replicationConfig))
            .constructor(ReplicationConfig::builder)
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ReplicationConfig").build()).build();

    private static final SdkField> EVENT_BUSES_FIELD = SdkField
            .> builder(MarshallingType.LIST)
            .memberName("EventBuses")
            .getter(getter(CreateEndpointRequest::eventBuses))
            .setter(setter(Builder::eventBuses))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("EventBuses").build(),
                    ListTrait
                            .builder()
                            .memberLocationName(null)
                            .memberFieldInfo(
                                    SdkField. builder(MarshallingType.SDK_POJO)
                                            .constructor(EndpointEventBus::builder)
                                            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
                                                    .locationName("member").build()).build()).build()).build();

    private static final SdkField ROLE_ARN_FIELD = SdkField. builder(MarshallingType.STRING)
            .memberName("RoleArn").getter(getter(CreateEndpointRequest::roleArn)).setter(setter(Builder::roleArn))
            .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RoleArn").build()).build();

    private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(NAME_FIELD, DESCRIPTION_FIELD,
            ROUTING_CONFIG_FIELD, REPLICATION_CONFIG_FIELD, EVENT_BUSES_FIELD, ROLE_ARN_FIELD));

    private final String name;

    private final String description;

    private final RoutingConfig routingConfig;

    private final ReplicationConfig replicationConfig;

    private final List eventBuses;

    private final String roleArn;

    private CreateEndpointRequest(BuilderImpl builder) {
        super(builder);
        this.name = builder.name;
        this.description = builder.description;
        this.routingConfig = builder.routingConfig;
        this.replicationConfig = builder.replicationConfig;
        this.eventBuses = builder.eventBuses;
        this.roleArn = builder.roleArn;
    }

    /**
     * 

* The name of the global endpoint. For example, "Name":"us-east-2-custom_bus_A-endpoint". *

* * @return The name of the global endpoint. For example, "Name":"us-east-2-custom_bus_A-endpoint". */ public final String name() { return name; } /** *

* A description of the global endpoint. *

* * @return A description of the global endpoint. */ public final String description() { return description; } /** *

* Configure the routing policy, including the health check and secondary Region.. *

* * @return Configure the routing policy, including the health check and secondary Region.. */ public final RoutingConfig routingConfig() { return routingConfig; } /** *

* Enable or disable event replication. The default state is ENABLED which means you must supply a * RoleArn. If you don't have a RoleArn or you don't want event replication enabled, set * the state to DISABLED. *

* * @return Enable or disable event replication. The default state is ENABLED which means you must * supply a RoleArn. If you don't have a RoleArn or you don't want event * replication enabled, set the state to DISABLED. */ public final ReplicationConfig replicationConfig() { return replicationConfig; } /** * For responses, this returns true if the service returned a value for the EventBuses property. This DOES NOT check * that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). This is * useful because the SDK will never return a null collection or map, but you may need to differentiate between the * service returning nothing (or null) and the service returning an empty collection or map. For requests, this * returns true if a value for the property was specified in the request builder, and false if a value was not * specified. */ public final boolean hasEventBuses() { return eventBuses != null && !(eventBuses instanceof SdkAutoConstructList); } /** *

* Define the event buses used. *

* *

* The names of the event buses must be identical in each Region. *

*
*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasEventBuses} method. *

* * @return Define the event buses used.

*

* The names of the event buses must be identical in each Region. *

*/ public final List eventBuses() { return eventBuses; } /** *

* The ARN of the role used for replication. *

* * @return The ARN of the role used for replication. */ public final String roleArn() { return roleArn; } @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(name()); hashCode = 31 * hashCode + Objects.hashCode(description()); hashCode = 31 * hashCode + Objects.hashCode(routingConfig()); hashCode = 31 * hashCode + Objects.hashCode(replicationConfig()); hashCode = 31 * hashCode + Objects.hashCode(hasEventBuses() ? eventBuses() : null); hashCode = 31 * hashCode + Objects.hashCode(roleArn()); 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 CreateEndpointRequest)) { return false; } CreateEndpointRequest other = (CreateEndpointRequest) obj; return Objects.equals(name(), other.name()) && Objects.equals(description(), other.description()) && Objects.equals(routingConfig(), other.routingConfig()) && Objects.equals(replicationConfig(), other.replicationConfig()) && hasEventBuses() == other.hasEventBuses() && Objects.equals(eventBuses(), other.eventBuses()) && Objects.equals(roleArn(), other.roleArn()); } /** * 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("CreateEndpointRequest").add("Name", name()).add("Description", description()) .add("RoutingConfig", routingConfig()).add("ReplicationConfig", replicationConfig()) .add("EventBuses", hasEventBuses() ? eventBuses() : null).add("RoleArn", roleArn()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "Name": return Optional.ofNullable(clazz.cast(name())); case "Description": return Optional.ofNullable(clazz.cast(description())); case "RoutingConfig": return Optional.ofNullable(clazz.cast(routingConfig())); case "ReplicationConfig": return Optional.ofNullable(clazz.cast(replicationConfig())); case "EventBuses": return Optional.ofNullable(clazz.cast(eventBuses())); case "RoleArn": return Optional.ofNullable(clazz.cast(roleArn())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((CreateEndpointRequest) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends EventBridgeRequest.Builder, SdkPojo, CopyableBuilder { /** *

* The name of the global endpoint. For example, "Name":"us-east-2-custom_bus_A-endpoint". *

* * @param name * The name of the global endpoint. For example, "Name":"us-east-2-custom_bus_A-endpoint". * @return Returns a reference to this object so that method calls can be chained together. */ Builder name(String name); /** *

* A description of the global endpoint. *

* * @param description * A description of the global endpoint. * @return Returns a reference to this object so that method calls can be chained together. */ Builder description(String description); /** *

* Configure the routing policy, including the health check and secondary Region.. *

* * @param routingConfig * Configure the routing policy, including the health check and secondary Region.. * @return Returns a reference to this object so that method calls can be chained together. */ Builder routingConfig(RoutingConfig routingConfig); /** *

* Configure the routing policy, including the health check and secondary Region.. *

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

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

* Enable or disable event replication. The default state is ENABLED which means you must supply a * RoleArn. If you don't have a RoleArn or you don't want event replication enabled, * set the state to DISABLED. *

* * @param replicationConfig * Enable or disable event replication. The default state is ENABLED which means you must * supply a RoleArn. If you don't have a RoleArn or you don't want event * replication enabled, set the state to DISABLED. * @return Returns a reference to this object so that method calls can be chained together. */ Builder replicationConfig(ReplicationConfig replicationConfig); /** *

* Enable or disable event replication. The default state is ENABLED which means you must supply a * RoleArn. If you don't have a RoleArn or you don't want event replication enabled, * set the state to DISABLED. *

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

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

* Define the event buses used. *

* *

* The names of the event buses must be identical in each Region. *

*
* * @param eventBuses * Define the event buses used.

*

* The names of the event buses must be identical in each Region. *

* @return Returns a reference to this object so that method calls can be chained together. */ Builder eventBuses(Collection eventBuses); /** *

* Define the event buses used. *

* *

* The names of the event buses must be identical in each Region. *

*
* * @param eventBuses * Define the event buses used.

*

* The names of the event buses must be identical in each Region. *

* @return Returns a reference to this object so that method calls can be chained together. */ Builder eventBuses(EndpointEventBus... eventBuses); /** *

* Define the event buses used. *

* *

* The names of the event buses must be identical in each Region. *

*
This is a convenience method that creates an instance of the * {@link software.amazon.awssdk.services.eventbridge.model.EndpointEventBus.Builder} avoiding the need to * create one manually via {@link software.amazon.awssdk.services.eventbridge.model.EndpointEventBus#builder()}. * *

* When the {@link Consumer} completes, * {@link software.amazon.awssdk.services.eventbridge.model.EndpointEventBus.Builder#build()} is called * immediately and its result is passed to {@link #eventBuses(List)}. * * @param eventBuses * a consumer that will call methods on * {@link software.amazon.awssdk.services.eventbridge.model.EndpointEventBus.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #eventBuses(java.util.Collection) */ Builder eventBuses(Consumer... eventBuses); /** *

* The ARN of the role used for replication. *

* * @param roleArn * The ARN of the role used for replication. * @return Returns a reference to this object so that method calls can be chained together. */ Builder roleArn(String roleArn); @Override Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration); @Override Builder overrideConfiguration(Consumer builderConsumer); } static final class BuilderImpl extends EventBridgeRequest.BuilderImpl implements Builder { private String name; private String description; private RoutingConfig routingConfig; private ReplicationConfig replicationConfig; private List eventBuses = DefaultSdkAutoConstructList.getInstance(); private String roleArn; private BuilderImpl() { } private BuilderImpl(CreateEndpointRequest model) { super(model); name(model.name); description(model.description); routingConfig(model.routingConfig); replicationConfig(model.replicationConfig); eventBuses(model.eventBuses); roleArn(model.roleArn); } public final String getName() { return name; } public final void setName(String name) { this.name = name; } @Override public final Builder name(String name) { this.name = name; return this; } public final String getDescription() { return description; } public final void setDescription(String description) { this.description = description; } @Override public final Builder description(String description) { this.description = description; return this; } public final RoutingConfig.Builder getRoutingConfig() { return routingConfig != null ? routingConfig.toBuilder() : null; } public final void setRoutingConfig(RoutingConfig.BuilderImpl routingConfig) { this.routingConfig = routingConfig != null ? routingConfig.build() : null; } @Override public final Builder routingConfig(RoutingConfig routingConfig) { this.routingConfig = routingConfig; return this; } public final ReplicationConfig.Builder getReplicationConfig() { return replicationConfig != null ? replicationConfig.toBuilder() : null; } public final void setReplicationConfig(ReplicationConfig.BuilderImpl replicationConfig) { this.replicationConfig = replicationConfig != null ? replicationConfig.build() : null; } @Override public final Builder replicationConfig(ReplicationConfig replicationConfig) { this.replicationConfig = replicationConfig; return this; } public final List getEventBuses() { List result = EndpointEventBusListCopier.copyToBuilder(this.eventBuses); if (result instanceof SdkAutoConstructList) { return null; } return result; } public final void setEventBuses(Collection eventBuses) { this.eventBuses = EndpointEventBusListCopier.copyFromBuilder(eventBuses); } @Override public final Builder eventBuses(Collection eventBuses) { this.eventBuses = EndpointEventBusListCopier.copy(eventBuses); return this; } @Override @SafeVarargs public final Builder eventBuses(EndpointEventBus... eventBuses) { eventBuses(Arrays.asList(eventBuses)); return this; } @Override @SafeVarargs public final Builder eventBuses(Consumer... eventBuses) { eventBuses(Stream.of(eventBuses).map(c -> EndpointEventBus.builder().applyMutation(c).build()) .collect(Collectors.toList())); return this; } public final String getRoleArn() { return roleArn; } public final void setRoleArn(String roleArn) { this.roleArn = roleArn; } @Override public final Builder roleArn(String roleArn) { this.roleArn = roleArn; return this; } @Override public Builder overrideConfiguration(AwsRequestOverrideConfiguration overrideConfiguration) { super.overrideConfiguration(overrideConfiguration); return this; } @Override public Builder overrideConfiguration(Consumer builderConsumer) { super.overrideConfiguration(builderConsumer); return this; } @Override public CreateEndpointRequest build() { return new CreateEndpointRequest(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy