Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
software.amazon.awssdk.services.pinpoint.model.WriteCampaignRequest Maven / Gradle / Ivy
Go to download
The AWS Java SDK for Amazon Pinpoint module holds the client classes that are used for communicating
with Amazon Pinpoint Service
/*
* 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.pinpoint.model;
import java.beans.Transient;
import java.io.Serializable;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
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 java.util.stream.Collectors;
import java.util.stream.Stream;
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.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.traits.MapTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructMap;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructMap;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;
/**
*
* Specifies the configuration and other settings for a campaign.
*
*/
@Generated("software.amazon.awssdk:codegen")
public final class WriteCampaignRequest implements SdkPojo, Serializable,
ToCopyableBuilder {
private static final SdkField> ADDITIONAL_TREATMENTS_FIELD = SdkField
.> builder(MarshallingType.LIST)
.memberName("AdditionalTreatments")
.getter(getter(WriteCampaignRequest::additionalTreatments))
.setter(setter(Builder::additionalTreatments))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("AdditionalTreatments").build(),
ListTrait
.builder()
.memberLocationName(null)
.memberFieldInfo(
SdkField. builder(MarshallingType.SDK_POJO)
.constructor(WriteTreatmentResource::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("member").build()).build()).build()).build();
private static final SdkField CUSTOM_DELIVERY_CONFIGURATION_FIELD = SdkField
. builder(MarshallingType.SDK_POJO)
.memberName("CustomDeliveryConfiguration")
.getter(getter(WriteCampaignRequest::customDeliveryConfiguration))
.setter(setter(Builder::customDeliveryConfiguration))
.constructor(CustomDeliveryConfiguration::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("CustomDeliveryConfiguration")
.build()).build();
private static final SdkField DESCRIPTION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("Description").getter(getter(WriteCampaignRequest::description)).setter(setter(Builder::description))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Description").build()).build();
private static final SdkField HOLDOUT_PERCENT_FIELD = SdkField. builder(MarshallingType.INTEGER)
.memberName("HoldoutPercent").getter(getter(WriteCampaignRequest::holdoutPercent))
.setter(setter(Builder::holdoutPercent))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("HoldoutPercent").build()).build();
private static final SdkField HOOK_FIELD = SdkField. builder(MarshallingType.SDK_POJO)
.memberName("Hook").getter(getter(WriteCampaignRequest::hook)).setter(setter(Builder::hook))
.constructor(CampaignHook::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Hook").build()).build();
private static final SdkField IS_PAUSED_FIELD = SdkField. builder(MarshallingType.BOOLEAN)
.memberName("IsPaused").getter(getter(WriteCampaignRequest::isPaused)).setter(setter(Builder::isPaused))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("IsPaused").build()).build();
private static final SdkField LIMITS_FIELD = SdkField. builder(MarshallingType.SDK_POJO)
.memberName("Limits").getter(getter(WriteCampaignRequest::limits)).setter(setter(Builder::limits))
.constructor(CampaignLimits::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Limits").build()).build();
private static final SdkField MESSAGE_CONFIGURATION_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("MessageConfiguration")
.getter(getter(WriteCampaignRequest::messageConfiguration)).setter(setter(Builder::messageConfiguration))
.constructor(MessageConfiguration::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("MessageConfiguration").build())
.build();
private static final SdkField NAME_FIELD = SdkField. builder(MarshallingType.STRING).memberName("Name")
.getter(getter(WriteCampaignRequest::name)).setter(setter(Builder::name))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Name").build()).build();
private static final SdkField SCHEDULE_FIELD = SdkField. builder(MarshallingType.SDK_POJO)
.memberName("Schedule").getter(getter(WriteCampaignRequest::schedule)).setter(setter(Builder::schedule))
.constructor(Schedule::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Schedule").build()).build();
private static final SdkField SEGMENT_ID_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("SegmentId").getter(getter(WriteCampaignRequest::segmentId)).setter(setter(Builder::segmentId))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SegmentId").build()).build();
private static final SdkField SEGMENT_VERSION_FIELD = SdkField. builder(MarshallingType.INTEGER)
.memberName("SegmentVersion").getter(getter(WriteCampaignRequest::segmentVersion))
.setter(setter(Builder::segmentVersion))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("SegmentVersion").build()).build();
private static final SdkField> TAGS_FIELD = SdkField
.> builder(MarshallingType.MAP)
.memberName("tags")
.getter(getter(WriteCampaignRequest::tags))
.setter(setter(Builder::tags))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("tags").build(),
MapTrait.builder()
.keyLocationName("key")
.valueLocationName("value")
.valueFieldInfo(
SdkField. builder(MarshallingType.STRING)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD)
.locationName("value").build()).build()).build()).build();
private static final SdkField TEMPLATE_CONFIGURATION_FIELD = SdkField
. builder(MarshallingType.SDK_POJO).memberName("TemplateConfiguration")
.getter(getter(WriteCampaignRequest::templateConfiguration)).setter(setter(Builder::templateConfiguration))
.constructor(TemplateConfiguration::builder)
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TemplateConfiguration").build())
.build();
private static final SdkField TREATMENT_DESCRIPTION_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("TreatmentDescription").getter(getter(WriteCampaignRequest::treatmentDescription))
.setter(setter(Builder::treatmentDescription))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TreatmentDescription").build())
.build();
private static final SdkField TREATMENT_NAME_FIELD = SdkField. builder(MarshallingType.STRING)
.memberName("TreatmentName").getter(getter(WriteCampaignRequest::treatmentName))
.setter(setter(Builder::treatmentName))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("TreatmentName").build()).build();
private static final SdkField PRIORITY_FIELD = SdkField. builder(MarshallingType.INTEGER)
.memberName("Priority").getter(getter(WriteCampaignRequest::priority)).setter(setter(Builder::priority))
.traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Priority").build()).build();
private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(ADDITIONAL_TREATMENTS_FIELD,
CUSTOM_DELIVERY_CONFIGURATION_FIELD, DESCRIPTION_FIELD, HOLDOUT_PERCENT_FIELD, HOOK_FIELD, IS_PAUSED_FIELD,
LIMITS_FIELD, MESSAGE_CONFIGURATION_FIELD, NAME_FIELD, SCHEDULE_FIELD, SEGMENT_ID_FIELD, SEGMENT_VERSION_FIELD,
TAGS_FIELD, TEMPLATE_CONFIGURATION_FIELD, TREATMENT_DESCRIPTION_FIELD, TREATMENT_NAME_FIELD, PRIORITY_FIELD));
private static final long serialVersionUID = 1L;
private final List additionalTreatments;
private final CustomDeliveryConfiguration customDeliveryConfiguration;
private final String description;
private final Integer holdoutPercent;
private final CampaignHook hook;
private final Boolean isPaused;
private final CampaignLimits limits;
private final MessageConfiguration messageConfiguration;
private final String name;
private final Schedule schedule;
private final String segmentId;
private final Integer segmentVersion;
private final Map tags;
private final TemplateConfiguration templateConfiguration;
private final String treatmentDescription;
private final String treatmentName;
private final Integer priority;
private WriteCampaignRequest(BuilderImpl builder) {
this.additionalTreatments = builder.additionalTreatments;
this.customDeliveryConfiguration = builder.customDeliveryConfiguration;
this.description = builder.description;
this.holdoutPercent = builder.holdoutPercent;
this.hook = builder.hook;
this.isPaused = builder.isPaused;
this.limits = builder.limits;
this.messageConfiguration = builder.messageConfiguration;
this.name = builder.name;
this.schedule = builder.schedule;
this.segmentId = builder.segmentId;
this.segmentVersion = builder.segmentVersion;
this.tags = builder.tags;
this.templateConfiguration = builder.templateConfiguration;
this.treatmentDescription = builder.treatmentDescription;
this.treatmentName = builder.treatmentName;
this.priority = builder.priority;
}
/**
* For responses, this returns true if the service returned a value for the AdditionalTreatments 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 hasAdditionalTreatments() {
return additionalTreatments != null && !(additionalTreatments instanceof SdkAutoConstructList);
}
/**
*
* An array of requests that defines additional treatments for the campaign, in addition to the default treatment
* for the campaign.
*
*
* 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 #hasAdditionalTreatments} method.
*
*
* @return An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
*/
public final List additionalTreatments() {
return additionalTreatments;
}
/**
*
* The delivery configuration settings for sending the campaign through a custom channel. This object is required if
* the MessageConfiguration object for the campaign specifies a CustomMessage object.
*
*
* @return The delivery configuration settings for sending the campaign through a custom channel. This object is
* required if the MessageConfiguration object for the campaign specifies a CustomMessage object.
*/
public final CustomDeliveryConfiguration customDeliveryConfiguration() {
return customDeliveryConfiguration;
}
/**
*
* A custom description of the campaign.
*
*
* @return A custom description of the campaign.
*/
public final String description() {
return description;
}
/**
*
* The allocated percentage of users (segment members) who shouldn't receive messages from the campaign.
*
*
* @return The allocated percentage of users (segment members) who shouldn't receive messages from the campaign.
*/
public final Integer holdoutPercent() {
return holdoutPercent;
}
/**
*
* The settings for the AWS Lambda function to invoke as a code hook for the campaign. You can use this hook to
* customize the segment that's used by the campaign.
*
*
* @return The settings for the AWS Lambda function to invoke as a code hook for the campaign. You can use this hook
* to customize the segment that's used by the campaign.
*/
public final CampaignHook hook() {
return hook;
}
/**
*
* Specifies whether to pause the campaign. A paused campaign doesn't run unless you resume it by changing this
* value to false.
*
*
* @return Specifies whether to pause the campaign. A paused campaign doesn't run unless you resume it by changing
* this value to false.
*/
public final Boolean isPaused() {
return isPaused;
}
/**
*
* The messaging limits for the campaign.
*
*
* @return The messaging limits for the campaign.
*/
public final CampaignLimits limits() {
return limits;
}
/**
*
* The message configuration settings for the campaign.
*
*
* @return The message configuration settings for the campaign.
*/
public final MessageConfiguration messageConfiguration() {
return messageConfiguration;
}
/**
*
* A custom name for the campaign.
*
*
* @return A custom name for the campaign.
*/
public final String name() {
return name;
}
/**
*
* The schedule settings for the campaign.
*
*
* @return The schedule settings for the campaign.
*/
public final Schedule schedule() {
return schedule;
}
/**
*
* The unique identifier for the segment to associate with the campaign.
*
*
* @return The unique identifier for the segment to associate with the campaign.
*/
public final String segmentId() {
return segmentId;
}
/**
*
* The version of the segment to associate with the campaign.
*
*
* @return The version of the segment to associate with the campaign.
*/
public final Integer segmentVersion() {
return segmentVersion;
}
/**
* For responses, this returns true if the service returned a value for the Tags 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 hasTags() {
return tags != null && !(tags instanceof SdkAutoConstructMap);
}
/**
*
* A string-to-string map of key-value pairs that defines the tags to associate with the campaign. Each tag consists
* of a required tag key and an associated tag value.
*
*
* 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 #hasTags} method.
*
*
* @return A string-to-string map of key-value pairs that defines the tags to associate with the campaign. Each tag
* consists of a required tag key and an associated tag value.
*/
public final Map tags() {
return tags;
}
/**
*
* The message template to use for the campaign.
*
*
* @return The message template to use for the campaign.
*/
public final TemplateConfiguration templateConfiguration() {
return templateConfiguration;
}
/**
*
* A custom description of the default treatment for the campaign.
*
*
* @return A custom description of the default treatment for the campaign.
*/
public final String treatmentDescription() {
return treatmentDescription;
}
/**
*
* A custom name of the default treatment for the campaign, if the campaign has multiple treatments. A
* treatment is a variation of a campaign that's used for A/B testing.
*
*
* @return A custom name of the default treatment for the campaign, if the campaign has multiple treatments. A
* treatment is a variation of a campaign that's used for A/B testing.
*/
public final String treatmentName() {
return treatmentName;
}
/**
*
* Defines the priority of the campaign, used to decide the order of messages displayed to user if there are
* multiple messages scheduled to be displayed at the same moment.
*
*
* @return Defines the priority of the campaign, used to decide the order of messages displayed to user if there are
* multiple messages scheduled to be displayed at the same moment.
*/
public final Integer priority() {
return priority;
}
@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 + Objects.hashCode(hasAdditionalTreatments() ? additionalTreatments() : null);
hashCode = 31 * hashCode + Objects.hashCode(customDeliveryConfiguration());
hashCode = 31 * hashCode + Objects.hashCode(description());
hashCode = 31 * hashCode + Objects.hashCode(holdoutPercent());
hashCode = 31 * hashCode + Objects.hashCode(hook());
hashCode = 31 * hashCode + Objects.hashCode(isPaused());
hashCode = 31 * hashCode + Objects.hashCode(limits());
hashCode = 31 * hashCode + Objects.hashCode(messageConfiguration());
hashCode = 31 * hashCode + Objects.hashCode(name());
hashCode = 31 * hashCode + Objects.hashCode(schedule());
hashCode = 31 * hashCode + Objects.hashCode(segmentId());
hashCode = 31 * hashCode + Objects.hashCode(segmentVersion());
hashCode = 31 * hashCode + Objects.hashCode(hasTags() ? tags() : null);
hashCode = 31 * hashCode + Objects.hashCode(templateConfiguration());
hashCode = 31 * hashCode + Objects.hashCode(treatmentDescription());
hashCode = 31 * hashCode + Objects.hashCode(treatmentName());
hashCode = 31 * hashCode + Objects.hashCode(priority());
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 WriteCampaignRequest)) {
return false;
}
WriteCampaignRequest other = (WriteCampaignRequest) obj;
return hasAdditionalTreatments() == other.hasAdditionalTreatments()
&& Objects.equals(additionalTreatments(), other.additionalTreatments())
&& Objects.equals(customDeliveryConfiguration(), other.customDeliveryConfiguration())
&& Objects.equals(description(), other.description()) && Objects.equals(holdoutPercent(), other.holdoutPercent())
&& Objects.equals(hook(), other.hook()) && Objects.equals(isPaused(), other.isPaused())
&& Objects.equals(limits(), other.limits())
&& Objects.equals(messageConfiguration(), other.messageConfiguration()) && Objects.equals(name(), other.name())
&& Objects.equals(schedule(), other.schedule()) && Objects.equals(segmentId(), other.segmentId())
&& Objects.equals(segmentVersion(), other.segmentVersion()) && hasTags() == other.hasTags()
&& Objects.equals(tags(), other.tags()) && Objects.equals(templateConfiguration(), other.templateConfiguration())
&& Objects.equals(treatmentDescription(), other.treatmentDescription())
&& Objects.equals(treatmentName(), other.treatmentName()) && Objects.equals(priority(), other.priority());
}
/**
* 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("WriteCampaignRequest")
.add("AdditionalTreatments", hasAdditionalTreatments() ? additionalTreatments() : null)
.add("CustomDeliveryConfiguration", customDeliveryConfiguration()).add("Description", description())
.add("HoldoutPercent", holdoutPercent()).add("Hook", hook()).add("IsPaused", isPaused()).add("Limits", limits())
.add("MessageConfiguration", messageConfiguration()).add("Name", name()).add("Schedule", schedule())
.add("SegmentId", segmentId()).add("SegmentVersion", segmentVersion()).add("Tags", hasTags() ? tags() : null)
.add("TemplateConfiguration", templateConfiguration()).add("TreatmentDescription", treatmentDescription())
.add("TreatmentName", treatmentName()).add("Priority", priority()).build();
}
public final Optional getValueForField(String fieldName, Class clazz) {
switch (fieldName) {
case "AdditionalTreatments":
return Optional.ofNullable(clazz.cast(additionalTreatments()));
case "CustomDeliveryConfiguration":
return Optional.ofNullable(clazz.cast(customDeliveryConfiguration()));
case "Description":
return Optional.ofNullable(clazz.cast(description()));
case "HoldoutPercent":
return Optional.ofNullable(clazz.cast(holdoutPercent()));
case "Hook":
return Optional.ofNullable(clazz.cast(hook()));
case "IsPaused":
return Optional.ofNullable(clazz.cast(isPaused()));
case "Limits":
return Optional.ofNullable(clazz.cast(limits()));
case "MessageConfiguration":
return Optional.ofNullable(clazz.cast(messageConfiguration()));
case "Name":
return Optional.ofNullable(clazz.cast(name()));
case "Schedule":
return Optional.ofNullable(clazz.cast(schedule()));
case "SegmentId":
return Optional.ofNullable(clazz.cast(segmentId()));
case "SegmentVersion":
return Optional.ofNullable(clazz.cast(segmentVersion()));
case "tags":
return Optional.ofNullable(clazz.cast(tags()));
case "TemplateConfiguration":
return Optional.ofNullable(clazz.cast(templateConfiguration()));
case "TreatmentDescription":
return Optional.ofNullable(clazz.cast(treatmentDescription()));
case "TreatmentName":
return Optional.ofNullable(clazz.cast(treatmentName()));
case "Priority":
return Optional.ofNullable(clazz.cast(priority()));
default:
return Optional.empty();
}
}
@Override
public final List> sdkFields() {
return SDK_FIELDS;
}
private static Function getter(Function g) {
return obj -> g.apply((WriteCampaignRequest) obj);
}
private static BiConsumer setter(BiConsumer s) {
return (obj, val) -> s.accept((Builder) obj, val);
}
public interface Builder extends SdkPojo, CopyableBuilder {
/**
*
* An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
*
*
* @param additionalTreatments
* An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder additionalTreatments(Collection additionalTreatments);
/**
*
* An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
*
*
* @param additionalTreatments
* An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder additionalTreatments(WriteTreatmentResource... additionalTreatments);
/**
*
* An array of requests that defines additional treatments for the campaign, in addition to the default
* treatment for the campaign.
*
* This is a convenience that creates an instance of the {@link List.Builder} avoiding
* the need to create one manually via {@link List#builder()}.
*
* When the {@link Consumer} completes, {@link List.Builder#build()} is called
* immediately and its result is passed to {@link #additionalTreatments(List)}.
*
* @param additionalTreatments
* a consumer that will call methods on {@link List.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #additionalTreatments(List)
*/
Builder additionalTreatments(Consumer... additionalTreatments);
/**
*
* The delivery configuration settings for sending the campaign through a custom channel. This object is
* required if the MessageConfiguration object for the campaign specifies a CustomMessage object.
*
*
* @param customDeliveryConfiguration
* The delivery configuration settings for sending the campaign through a custom channel. This object is
* required if the MessageConfiguration object for the campaign specifies a CustomMessage object.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder customDeliveryConfiguration(CustomDeliveryConfiguration customDeliveryConfiguration);
/**
*
* The delivery configuration settings for sending the campaign through a custom channel. This object is
* required if the MessageConfiguration object for the campaign specifies a CustomMessage object.
*
* This is a convenience that creates an instance of the {@link CustomDeliveryConfiguration.Builder} avoiding
* the need to create one manually via {@link CustomDeliveryConfiguration#builder()}.
*
* When the {@link Consumer} completes, {@link CustomDeliveryConfiguration.Builder#build()} is called
* immediately and its result is passed to {@link #customDeliveryConfiguration(CustomDeliveryConfiguration)}.
*
* @param customDeliveryConfiguration
* a consumer that will call methods on {@link CustomDeliveryConfiguration.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #customDeliveryConfiguration(CustomDeliveryConfiguration)
*/
default Builder customDeliveryConfiguration(Consumer customDeliveryConfiguration) {
return customDeliveryConfiguration(CustomDeliveryConfiguration.builder().applyMutation(customDeliveryConfiguration)
.build());
}
/**
*
* A custom description of the campaign.
*
*
* @param description
* A custom description of the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder description(String description);
/**
*
* The allocated percentage of users (segment members) who shouldn't receive messages from the campaign.
*
*
* @param holdoutPercent
* The allocated percentage of users (segment members) who shouldn't receive messages from the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder holdoutPercent(Integer holdoutPercent);
/**
*
* The settings for the AWS Lambda function to invoke as a code hook for the campaign. You can use this hook to
* customize the segment that's used by the campaign.
*
*
* @param hook
* The settings for the AWS Lambda function to invoke as a code hook for the campaign. You can use this
* hook to customize the segment that's used by the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder hook(CampaignHook hook);
/**
*
* The settings for the AWS Lambda function to invoke as a code hook for the campaign. You can use this hook to
* customize the segment that's used by the campaign.
*
* This is a convenience that creates an instance of the {@link CampaignHook.Builder} avoiding the need to
* create one manually via {@link CampaignHook#builder()}.
*
* When the {@link Consumer} completes, {@link CampaignHook.Builder#build()} is called immediately and its
* result is passed to {@link #hook(CampaignHook)}.
*
* @param hook
* a consumer that will call methods on {@link CampaignHook.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #hook(CampaignHook)
*/
default Builder hook(Consumer hook) {
return hook(CampaignHook.builder().applyMutation(hook).build());
}
/**
*
* Specifies whether to pause the campaign. A paused campaign doesn't run unless you resume it by changing this
* value to false.
*
*
* @param isPaused
* Specifies whether to pause the campaign. A paused campaign doesn't run unless you resume it by
* changing this value to false.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder isPaused(Boolean isPaused);
/**
*
* The messaging limits for the campaign.
*
*
* @param limits
* The messaging limits for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder limits(CampaignLimits limits);
/**
*
* The messaging limits for the campaign.
*
* This is a convenience that creates an instance of the {@link CampaignLimits.Builder} avoiding the need to
* create one manually via {@link CampaignLimits#builder()}.
*
* When the {@link Consumer} completes, {@link CampaignLimits.Builder#build()} is called immediately and its
* result is passed to {@link #limits(CampaignLimits)}.
*
* @param limits
* a consumer that will call methods on {@link CampaignLimits.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #limits(CampaignLimits)
*/
default Builder limits(Consumer limits) {
return limits(CampaignLimits.builder().applyMutation(limits).build());
}
/**
*
* The message configuration settings for the campaign.
*
*
* @param messageConfiguration
* The message configuration settings for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder messageConfiguration(MessageConfiguration messageConfiguration);
/**
*
* The message configuration settings for the campaign.
*
* This is a convenience that creates an instance of the {@link MessageConfiguration.Builder} avoiding the need
* to create one manually via {@link MessageConfiguration#builder()}.
*
* When the {@link Consumer} completes, {@link MessageConfiguration.Builder#build()} is called immediately and
* its result is passed to {@link #messageConfiguration(MessageConfiguration)}.
*
* @param messageConfiguration
* a consumer that will call methods on {@link MessageConfiguration.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #messageConfiguration(MessageConfiguration)
*/
default Builder messageConfiguration(Consumer messageConfiguration) {
return messageConfiguration(MessageConfiguration.builder().applyMutation(messageConfiguration).build());
}
/**
*
* A custom name for the campaign.
*
*
* @param name
* A custom name for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder name(String name);
/**
*
* The schedule settings for the campaign.
*
*
* @param schedule
* The schedule settings for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder schedule(Schedule schedule);
/**
*
* The schedule settings for the campaign.
*
* This is a convenience that creates an instance of the {@link Schedule.Builder} avoiding the need to create
* one manually via {@link Schedule#builder()}.
*
* When the {@link Consumer} completes, {@link Schedule.Builder#build()} is called immediately and its result is
* passed to {@link #schedule(Schedule)}.
*
* @param schedule
* a consumer that will call methods on {@link Schedule.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #schedule(Schedule)
*/
default Builder schedule(Consumer schedule) {
return schedule(Schedule.builder().applyMutation(schedule).build());
}
/**
*
* The unique identifier for the segment to associate with the campaign.
*
*
* @param segmentId
* The unique identifier for the segment to associate with the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder segmentId(String segmentId);
/**
*
* The version of the segment to associate with the campaign.
*
*
* @param segmentVersion
* The version of the segment to associate with the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder segmentVersion(Integer segmentVersion);
/**
*
* A string-to-string map of key-value pairs that defines the tags to associate with the campaign. Each tag
* consists of a required tag key and an associated tag value.
*
*
* @param tags
* A string-to-string map of key-value pairs that defines the tags to associate with the campaign. Each
* tag consists of a required tag key and an associated tag value.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder tags(Map tags);
/**
*
* The message template to use for the campaign.
*
*
* @param templateConfiguration
* The message template to use for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder templateConfiguration(TemplateConfiguration templateConfiguration);
/**
*
* The message template to use for the campaign.
*
* This is a convenience that creates an instance of the {@link TemplateConfiguration.Builder} avoiding the need
* to create one manually via {@link TemplateConfiguration#builder()}.
*
* When the {@link Consumer} completes, {@link TemplateConfiguration.Builder#build()} is called immediately and
* its result is passed to {@link #templateConfiguration(TemplateConfiguration)}.
*
* @param templateConfiguration
* a consumer that will call methods on {@link TemplateConfiguration.Builder}
* @return Returns a reference to this object so that method calls can be chained together.
* @see #templateConfiguration(TemplateConfiguration)
*/
default Builder templateConfiguration(Consumer templateConfiguration) {
return templateConfiguration(TemplateConfiguration.builder().applyMutation(templateConfiguration).build());
}
/**
*
* A custom description of the default treatment for the campaign.
*
*
* @param treatmentDescription
* A custom description of the default treatment for the campaign.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder treatmentDescription(String treatmentDescription);
/**
*
* A custom name of the default treatment for the campaign, if the campaign has multiple treatments. A
* treatment is a variation of a campaign that's used for A/B testing.
*
*
* @param treatmentName
* A custom name of the default treatment for the campaign, if the campaign has multiple treatments. A
* treatment is a variation of a campaign that's used for A/B testing.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder treatmentName(String treatmentName);
/**
*
* Defines the priority of the campaign, used to decide the order of messages displayed to user if there are
* multiple messages scheduled to be displayed at the same moment.
*
*
* @param priority
* Defines the priority of the campaign, used to decide the order of messages displayed to user if there
* are multiple messages scheduled to be displayed at the same moment.
* @return Returns a reference to this object so that method calls can be chained together.
*/
Builder priority(Integer priority);
}
static final class BuilderImpl implements Builder {
private List additionalTreatments = DefaultSdkAutoConstructList.getInstance();
private CustomDeliveryConfiguration customDeliveryConfiguration;
private String description;
private Integer holdoutPercent;
private CampaignHook hook;
private Boolean isPaused;
private CampaignLimits limits;
private MessageConfiguration messageConfiguration;
private String name;
private Schedule schedule;
private String segmentId;
private Integer segmentVersion;
private Map tags = DefaultSdkAutoConstructMap.getInstance();
private TemplateConfiguration templateConfiguration;
private String treatmentDescription;
private String treatmentName;
private Integer priority;
private BuilderImpl() {
}
private BuilderImpl(WriteCampaignRequest model) {
additionalTreatments(model.additionalTreatments);
customDeliveryConfiguration(model.customDeliveryConfiguration);
description(model.description);
holdoutPercent(model.holdoutPercent);
hook(model.hook);
isPaused(model.isPaused);
limits(model.limits);
messageConfiguration(model.messageConfiguration);
name(model.name);
schedule(model.schedule);
segmentId(model.segmentId);
segmentVersion(model.segmentVersion);
tags(model.tags);
templateConfiguration(model.templateConfiguration);
treatmentDescription(model.treatmentDescription);
treatmentName(model.treatmentName);
priority(model.priority);
}
public final List getAdditionalTreatments() {
List result = ListOfWriteTreatmentResourceCopier
.copyToBuilder(this.additionalTreatments);
if (result instanceof SdkAutoConstructList) {
return null;
}
return result;
}
public final void setAdditionalTreatments(Collection additionalTreatments) {
this.additionalTreatments = ListOfWriteTreatmentResourceCopier.copyFromBuilder(additionalTreatments);
}
@Override
@Transient
public final Builder additionalTreatments(Collection additionalTreatments) {
this.additionalTreatments = ListOfWriteTreatmentResourceCopier.copy(additionalTreatments);
return this;
}
@Override
@Transient
@SafeVarargs
public final Builder additionalTreatments(WriteTreatmentResource... additionalTreatments) {
additionalTreatments(Arrays.asList(additionalTreatments));
return this;
}
@Override
@Transient
@SafeVarargs
public final Builder additionalTreatments(Consumer... additionalTreatments) {
additionalTreatments(Stream.of(additionalTreatments)
.map(c -> WriteTreatmentResource.builder().applyMutation(c).build()).collect(Collectors.toList()));
return this;
}
public final CustomDeliveryConfiguration.Builder getCustomDeliveryConfiguration() {
return customDeliveryConfiguration != null ? customDeliveryConfiguration.toBuilder() : null;
}
public final void setCustomDeliveryConfiguration(CustomDeliveryConfiguration.BuilderImpl customDeliveryConfiguration) {
this.customDeliveryConfiguration = customDeliveryConfiguration != null ? customDeliveryConfiguration.build() : null;
}
@Override
@Transient
public final Builder customDeliveryConfiguration(CustomDeliveryConfiguration customDeliveryConfiguration) {
this.customDeliveryConfiguration = customDeliveryConfiguration;
return this;
}
public final String getDescription() {
return description;
}
public final void setDescription(String description) {
this.description = description;
}
@Override
@Transient
public final Builder description(String description) {
this.description = description;
return this;
}
public final Integer getHoldoutPercent() {
return holdoutPercent;
}
public final void setHoldoutPercent(Integer holdoutPercent) {
this.holdoutPercent = holdoutPercent;
}
@Override
@Transient
public final Builder holdoutPercent(Integer holdoutPercent) {
this.holdoutPercent = holdoutPercent;
return this;
}
public final CampaignHook.Builder getHook() {
return hook != null ? hook.toBuilder() : null;
}
public final void setHook(CampaignHook.BuilderImpl hook) {
this.hook = hook != null ? hook.build() : null;
}
@Override
@Transient
public final Builder hook(CampaignHook hook) {
this.hook = hook;
return this;
}
public final Boolean getIsPaused() {
return isPaused;
}
public final void setIsPaused(Boolean isPaused) {
this.isPaused = isPaused;
}
@Override
@Transient
public final Builder isPaused(Boolean isPaused) {
this.isPaused = isPaused;
return this;
}
public final CampaignLimits.Builder getLimits() {
return limits != null ? limits.toBuilder() : null;
}
public final void setLimits(CampaignLimits.BuilderImpl limits) {
this.limits = limits != null ? limits.build() : null;
}
@Override
@Transient
public final Builder limits(CampaignLimits limits) {
this.limits = limits;
return this;
}
public final MessageConfiguration.Builder getMessageConfiguration() {
return messageConfiguration != null ? messageConfiguration.toBuilder() : null;
}
public final void setMessageConfiguration(MessageConfiguration.BuilderImpl messageConfiguration) {
this.messageConfiguration = messageConfiguration != null ? messageConfiguration.build() : null;
}
@Override
@Transient
public final Builder messageConfiguration(MessageConfiguration messageConfiguration) {
this.messageConfiguration = messageConfiguration;
return this;
}
public final String getName() {
return name;
}
public final void setName(String name) {
this.name = name;
}
@Override
@Transient
public final Builder name(String name) {
this.name = name;
return this;
}
public final Schedule.Builder getSchedule() {
return schedule != null ? schedule.toBuilder() : null;
}
public final void setSchedule(Schedule.BuilderImpl schedule) {
this.schedule = schedule != null ? schedule.build() : null;
}
@Override
@Transient
public final Builder schedule(Schedule schedule) {
this.schedule = schedule;
return this;
}
public final String getSegmentId() {
return segmentId;
}
public final void setSegmentId(String segmentId) {
this.segmentId = segmentId;
}
@Override
@Transient
public final Builder segmentId(String segmentId) {
this.segmentId = segmentId;
return this;
}
public final Integer getSegmentVersion() {
return segmentVersion;
}
public final void setSegmentVersion(Integer segmentVersion) {
this.segmentVersion = segmentVersion;
}
@Override
@Transient
public final Builder segmentVersion(Integer segmentVersion) {
this.segmentVersion = segmentVersion;
return this;
}
public final Map getTags() {
if (tags instanceof SdkAutoConstructMap) {
return null;
}
return tags;
}
public final void setTags(Map tags) {
this.tags = MapOf__stringCopier.copy(tags);
}
@Override
@Transient
public final Builder tags(Map tags) {
this.tags = MapOf__stringCopier.copy(tags);
return this;
}
public final TemplateConfiguration.Builder getTemplateConfiguration() {
return templateConfiguration != null ? templateConfiguration.toBuilder() : null;
}
public final void setTemplateConfiguration(TemplateConfiguration.BuilderImpl templateConfiguration) {
this.templateConfiguration = templateConfiguration != null ? templateConfiguration.build() : null;
}
@Override
@Transient
public final Builder templateConfiguration(TemplateConfiguration templateConfiguration) {
this.templateConfiguration = templateConfiguration;
return this;
}
public final String getTreatmentDescription() {
return treatmentDescription;
}
public final void setTreatmentDescription(String treatmentDescription) {
this.treatmentDescription = treatmentDescription;
}
@Override
@Transient
public final Builder treatmentDescription(String treatmentDescription) {
this.treatmentDescription = treatmentDescription;
return this;
}
public final String getTreatmentName() {
return treatmentName;
}
public final void setTreatmentName(String treatmentName) {
this.treatmentName = treatmentName;
}
@Override
@Transient
public final Builder treatmentName(String treatmentName) {
this.treatmentName = treatmentName;
return this;
}
public final Integer getPriority() {
return priority;
}
public final void setPriority(Integer priority) {
this.priority = priority;
}
@Override
@Transient
public final Builder priority(Integer priority) {
this.priority = priority;
return this;
}
@Override
public WriteCampaignRequest build() {
return new WriteCampaignRequest(this);
}
@Override
public List> sdkFields() {
return SDK_FIELDS;
}
}
}