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

software.amazon.awssdk.services.connect.model.QuickConnectConfig 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.connect.model;

import java.io.Serializable;
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.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;

/**
 * 

* Contains configuration settings for a quick connect. *

*/ @Generated("software.amazon.awssdk:codegen") public final class QuickConnectConfig implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField QUICK_CONNECT_TYPE_FIELD = SdkField. builder(MarshallingType.STRING) .memberName("QuickConnectType").getter(getter(QuickConnectConfig::quickConnectTypeAsString)) .setter(setter(Builder::quickConnectType)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("QuickConnectType").build()).build(); private static final SdkField USER_CONFIG_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("UserConfig") .getter(getter(QuickConnectConfig::userConfig)).setter(setter(Builder::userConfig)) .constructor(UserQuickConnectConfig::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("UserConfig").build()).build(); private static final SdkField QUEUE_CONFIG_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("QueueConfig") .getter(getter(QuickConnectConfig::queueConfig)).setter(setter(Builder::queueConfig)) .constructor(QueueQuickConnectConfig::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("QueueConfig").build()).build(); private static final SdkField PHONE_CONFIG_FIELD = SdkField . builder(MarshallingType.SDK_POJO).memberName("PhoneConfig") .getter(getter(QuickConnectConfig::phoneConfig)).setter(setter(Builder::phoneConfig)) .constructor(PhoneNumberQuickConnectConfig::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("PhoneConfig").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(QUICK_CONNECT_TYPE_FIELD, USER_CONFIG_FIELD, QUEUE_CONFIG_FIELD, PHONE_CONFIG_FIELD)); private static final long serialVersionUID = 1L; private final String quickConnectType; private final UserQuickConnectConfig userConfig; private final QueueQuickConnectConfig queueConfig; private final PhoneNumberQuickConnectConfig phoneConfig; private QuickConnectConfig(BuilderImpl builder) { this.quickConnectType = builder.quickConnectType; this.userConfig = builder.userConfig; this.queueConfig = builder.queueConfig; this.phoneConfig = builder.phoneConfig; } /** *

* The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are prompted to * assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #quickConnectType} * will return {@link QuickConnectType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available * from {@link #quickConnectTypeAsString}. *

* * @return The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are * prompted to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). * @see QuickConnectType */ public final QuickConnectType quickConnectType() { return QuickConnectType.fromValue(quickConnectType); } /** *

* The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are prompted to * assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). *

*

* If the service returns an enum value that is not available in the current SDK version, {@link #quickConnectType} * will return {@link QuickConnectType#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available * from {@link #quickConnectTypeAsString}. *

* * @return The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are * prompted to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). * @see QuickConnectType */ public final String quickConnectTypeAsString() { return quickConnectType; } /** *

* The user configuration. This is required only if QuickConnectType is USER. *

* * @return The user configuration. This is required only if QuickConnectType is USER. */ public final UserQuickConnectConfig userConfig() { return userConfig; } /** *

* The queue configuration. This is required only if QuickConnectType is QUEUE. *

* * @return The queue configuration. This is required only if QuickConnectType is QUEUE. */ public final QueueQuickConnectConfig queueConfig() { return queueConfig; } /** *

* The phone configuration. This is required only if QuickConnectType is PHONE_NUMBER. *

* * @return The phone configuration. This is required only if QuickConnectType is PHONE_NUMBER. */ public final PhoneNumberQuickConnectConfig phoneConfig() { return phoneConfig; } @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 + Objects.hashCode(quickConnectTypeAsString()); hashCode = 31 * hashCode + Objects.hashCode(userConfig()); hashCode = 31 * hashCode + Objects.hashCode(queueConfig()); hashCode = 31 * hashCode + Objects.hashCode(phoneConfig()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof QuickConnectConfig)) { return false; } QuickConnectConfig other = (QuickConnectConfig) obj; return Objects.equals(quickConnectTypeAsString(), other.quickConnectTypeAsString()) && Objects.equals(userConfig(), other.userConfig()) && Objects.equals(queueConfig(), other.queueConfig()) && Objects.equals(phoneConfig(), other.phoneConfig()); } /** * 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("QuickConnectConfig").add("QuickConnectType", quickConnectTypeAsString()) .add("UserConfig", userConfig()).add("QueueConfig", queueConfig()).add("PhoneConfig", phoneConfig()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "QuickConnectType": return Optional.ofNullable(clazz.cast(quickConnectTypeAsString())); case "UserConfig": return Optional.ofNullable(clazz.cast(userConfig())); case "QueueConfig": return Optional.ofNullable(clazz.cast(queueConfig())); case "PhoneConfig": return Optional.ofNullable(clazz.cast(phoneConfig())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((QuickConnectConfig) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are prompted * to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). *

* * @param quickConnectType * The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are * prompted to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue * (QUEUE). * @see QuickConnectType * @return Returns a reference to this object so that method calls can be chained together. * @see QuickConnectType */ Builder quickConnectType(String quickConnectType); /** *

* The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are prompted * to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue (QUEUE). *

* * @param quickConnectType * The type of quick connect. In the Amazon Connect console, when you create a quick connect, you are * prompted to assign one of the following types: Agent (USER), External (PHONE_NUMBER), or Queue * (QUEUE). * @see QuickConnectType * @return Returns a reference to this object so that method calls can be chained together. * @see QuickConnectType */ Builder quickConnectType(QuickConnectType quickConnectType); /** *

* The user configuration. This is required only if QuickConnectType is USER. *

* * @param userConfig * The user configuration. This is required only if QuickConnectType is USER. * @return Returns a reference to this object so that method calls can be chained together. */ Builder userConfig(UserQuickConnectConfig userConfig); /** *

* The user configuration. This is required only if QuickConnectType is USER. *

* This is a convenience that creates an instance of the {@link UserQuickConnectConfig.Builder} avoiding the * need to create one manually via {@link UserQuickConnectConfig#builder()}. * * When the {@link Consumer} completes, {@link UserQuickConnectConfig.Builder#build()} is called immediately and * its result is passed to {@link #userConfig(UserQuickConnectConfig)}. * * @param userConfig * a consumer that will call methods on {@link UserQuickConnectConfig.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #userConfig(UserQuickConnectConfig) */ default Builder userConfig(Consumer userConfig) { return userConfig(UserQuickConnectConfig.builder().applyMutation(userConfig).build()); } /** *

* The queue configuration. This is required only if QuickConnectType is QUEUE. *

* * @param queueConfig * The queue configuration. This is required only if QuickConnectType is QUEUE. * @return Returns a reference to this object so that method calls can be chained together. */ Builder queueConfig(QueueQuickConnectConfig queueConfig); /** *

* The queue configuration. This is required only if QuickConnectType is QUEUE. *

* This is a convenience that creates an instance of the {@link QueueQuickConnectConfig.Builder} avoiding the * need to create one manually via {@link QueueQuickConnectConfig#builder()}. * * When the {@link Consumer} completes, {@link QueueQuickConnectConfig.Builder#build()} is called immediately * and its result is passed to {@link #queueConfig(QueueQuickConnectConfig)}. * * @param queueConfig * a consumer that will call methods on {@link QueueQuickConnectConfig.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #queueConfig(QueueQuickConnectConfig) */ default Builder queueConfig(Consumer queueConfig) { return queueConfig(QueueQuickConnectConfig.builder().applyMutation(queueConfig).build()); } /** *

* The phone configuration. This is required only if QuickConnectType is PHONE_NUMBER. *

* * @param phoneConfig * The phone configuration. This is required only if QuickConnectType is PHONE_NUMBER. * @return Returns a reference to this object so that method calls can be chained together. */ Builder phoneConfig(PhoneNumberQuickConnectConfig phoneConfig); /** *

* The phone configuration. This is required only if QuickConnectType is PHONE_NUMBER. *

* This is a convenience that creates an instance of the {@link PhoneNumberQuickConnectConfig.Builder} avoiding * the need to create one manually via {@link PhoneNumberQuickConnectConfig#builder()}. * * When the {@link Consumer} completes, {@link PhoneNumberQuickConnectConfig.Builder#build()} is called * immediately and its result is passed to {@link #phoneConfig(PhoneNumberQuickConnectConfig)}. * * @param phoneConfig * a consumer that will call methods on {@link PhoneNumberQuickConnectConfig.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #phoneConfig(PhoneNumberQuickConnectConfig) */ default Builder phoneConfig(Consumer phoneConfig) { return phoneConfig(PhoneNumberQuickConnectConfig.builder().applyMutation(phoneConfig).build()); } } static final class BuilderImpl implements Builder { private String quickConnectType; private UserQuickConnectConfig userConfig; private QueueQuickConnectConfig queueConfig; private PhoneNumberQuickConnectConfig phoneConfig; private BuilderImpl() { } private BuilderImpl(QuickConnectConfig model) { quickConnectType(model.quickConnectType); userConfig(model.userConfig); queueConfig(model.queueConfig); phoneConfig(model.phoneConfig); } public final String getQuickConnectType() { return quickConnectType; } @Override public final Builder quickConnectType(String quickConnectType) { this.quickConnectType = quickConnectType; return this; } @Override public final Builder quickConnectType(QuickConnectType quickConnectType) { this.quickConnectType(quickConnectType == null ? null : quickConnectType.toString()); return this; } public final void setQuickConnectType(String quickConnectType) { this.quickConnectType = quickConnectType; } public final UserQuickConnectConfig.Builder getUserConfig() { return userConfig != null ? userConfig.toBuilder() : null; } @Override public final Builder userConfig(UserQuickConnectConfig userConfig) { this.userConfig = userConfig; return this; } public final void setUserConfig(UserQuickConnectConfig.BuilderImpl userConfig) { this.userConfig = userConfig != null ? userConfig.build() : null; } public final QueueQuickConnectConfig.Builder getQueueConfig() { return queueConfig != null ? queueConfig.toBuilder() : null; } @Override public final Builder queueConfig(QueueQuickConnectConfig queueConfig) { this.queueConfig = queueConfig; return this; } public final void setQueueConfig(QueueQuickConnectConfig.BuilderImpl queueConfig) { this.queueConfig = queueConfig != null ? queueConfig.build() : null; } public final PhoneNumberQuickConnectConfig.Builder getPhoneConfig() { return phoneConfig != null ? phoneConfig.toBuilder() : null; } @Override public final Builder phoneConfig(PhoneNumberQuickConnectConfig phoneConfig) { this.phoneConfig = phoneConfig; return this; } public final void setPhoneConfig(PhoneNumberQuickConnectConfig.BuilderImpl phoneConfig) { this.phoneConfig = phoneConfig != null ? phoneConfig.build() : null; } @Override public QuickConnectConfig build() { return new QuickConnectConfig(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy