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

com.urbanairship.api.experiments.model.Experiment Maven / Gradle / Ivy

/*
 * Copyright (c) 2013-2017.  Urban Airship and Contributors
 */

package com.urbanairship.api.experiments.model;

import com.google.common.base.Preconditions;
import com.google.common.collect.Lists;
import com.urbanairship.api.push.model.Campaigns;
import com.urbanairship.api.push.model.DeviceTypeData;
import com.urbanairship.api.push.model.Orchestration;
import com.urbanairship.api.push.model.audience.Selector;
import com.urbanairship.api.push.model.audience.SelectorType;
import com.urbanairship.api.push.model.notification.email.MessageType;

import java.math.BigDecimal;
import java.util.List;
import java.util.Objects;
import java.util.Optional;

/**
 * Represents a set of varied pushes to send as part of an A/B experiment.
 */
public final class Experiment extends ExperimentModelObject {

    private final Optional name;
    private final Optional description;
    private final Optional control;
    private final Selector audience;
    private final DeviceTypeData deviceTypes;
    private final List variants;
    private final Optional orchestration;
    private final Optional messageType;
    private final Optional campaigns;

    private Experiment(Builder builder) {
        this.name = Optional.ofNullable(builder.name);
        this.description = Optional.ofNullable(builder.description);
        this.control = Optional.ofNullable(builder.control);
        this.audience = builder.audience;
        this.deviceTypes = builder.deviceTypes;
        this.variants = builder.variants;
        this.orchestration = Optional.ofNullable(builder.orchestration);
        this.messageType = Optional.ofNullable(builder.messageType);
        this.campaigns = Optional.ofNullable(builder.campaigns);

    }

    /**
     * Experiment builder
     *
     * @return Builder
     */
    public static Builder newBuilder() {
        return new Builder();
    }

    /**
     * Get the name of the experiment.
     *
     * @return an Optional String
     */
    public Optional getName() {
        return name;
    }

    /**
     * Get the description for the experiment.
     *
     * @return an Optional String
     */
    public Optional getDescription() {
        return description;
    }

    /**
     * Get the control group for the experiment. A control is a float between 0 and 1, e.g., 0.4,
     * representing the proportion of the audience that will not receive a push.
     * The remaining audience is split between the variants.
     *
     * @return an Optional BigDecimal
     */
    public Optional getControl() {
        return control;
    }

    /**
     * Get the audience for the experiment.
     *
     * @return an Audience object
     */
    public Selector getAudience() {
        return audience;
    }

    /**
     * Boolean indicating whether audience is SelectorType.ALL
     *
     * @return Boolean
     */
    public boolean isBroadcast() {
        return audience.getType().equals(SelectorType.ALL);
    }

    /**
     * Get the device types for the experiment.
     *
     * @return a DeviceTypeData object
     */
    public DeviceTypeData getDeviceTypes() {
        return deviceTypes;
    }

    /**
     * Get the variants for the experiment. A variant defines a push that will be sent to a subset of the experiment's
     * audience.
     *
     * @return variants List<Variant>
     */
    public List getVariants() {
        return variants;
    }

    /**
     * Get the orchestration for the experiment.
     *
     * @return an Orchestration object
     */
    public Optional getOrchestration() {
        return orchestration;
    }

    /**
     * Get the message type for the experiment.
     *
     * @return an MessageType object
     */
    public Optional getMessageType() {
        return messageType;
    }

    /**
     * Get the campaigns object for the experiment.
     *
     * @return an Campaigns object
     */
    public Optional getCampaigns() {
        return campaigns;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Experiment that = (Experiment) o;
        return Objects.equals(name, that.name) &&
                Objects.equals(description, that.description) &&
                Objects.equals(control, that.control) &&
                Objects.equals(audience, that.audience) &&
                Objects.equals(deviceTypes, that.deviceTypes) &&
                Objects.equals(variants, that.variants) &&
                Objects.equals(orchestration, that.orchestration) &&
                Objects.equals(messageType, that.messageType) &&
                Objects.equals(campaigns, that.campaigns);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, description, control, audience, deviceTypes,
                variants, orchestration, messageType, campaigns);
    }

    @Override
    public String toString() {
        return "Experiment{" +
                "name=" + name +
                ", description=" + description +
                ", control=" + control +
                ", audience=" + audience +
                ", deviceTypes=" + deviceTypes +
                ", variants=" + variants +
                ", orchestration=" + orchestration +
                ", messageType=" + messageType +
                ", campaigns=" + campaigns +
                '}';
    }

    /**
     * Experiment Builder
     */
    public static class Builder {

        private String name = null;
        private String description = null;
        private BigDecimal control = null;
        private Selector audience = null;
        private DeviceTypeData deviceTypes = null;
        private final List variants = Lists.newArrayList();
        private Orchestration orchestration = null;
        private MessageType messageType = null;
        private Campaigns campaigns = null;

        private Builder() {
        }

        /**
         * Set the experiment name.
         *
         * @param name String
         * @return Builder
         */
        public Builder setName(String name) {
            this.name = name;
            return this;
        }

        /**
         * Set the experiment description.
         *
         * @param description String
         * @return Builder
         */
        public Builder setDescription(String description) {
            this.description = description;
            return this;
        }

        /**
         * Set the control group for the experiment. A control is a float between 0 and 1, e.g., 0.4,
         * representing the proportion of the audience that will not receive a push.
         * The remaining audience is split between the variants.
         *
         * @param control BigDecimal
         * @return Builder
         */
        public Builder setControl(BigDecimal control) {
            this.control = control;
            return this;
        }

        /**
         * Set the audience for the experiment.
         *
         * @param audience Selector
         * @return Builder
         */
        public Builder setAudience(Selector audience) {
            this.audience = audience;
            return this;
        }

        /**
         * Set the device types for the experiment.
         *
         * @param deviceTypes DeviceTypeData
         * @return Builder
         */
        public Builder setDeviceTypes(DeviceTypeData deviceTypes) {
            this.deviceTypes = deviceTypes;
            return this;
        }

        /**
         * Add a variant to the experiment. A variant defines a push that will be sent to a subset of the experiment's
         * audience.
         *
         * @param variant List<Variant>
         * @return Builder
         */
        public Builder addVariant(Variant variant) {
            variants.add(variant);
            return this;
        }

        public Builder addAllVariants(List variants) {
            this.variants.addAll(variants);
            return this;
        }

        /**
         * Set the Orchestration for the experiment.
         *
         * @param orchestration Orchestration
         * @return Builder
         */
        public Builder setOrchestration(Orchestration orchestration) {
            this.orchestration = orchestration;
            return this;
        }

        /**
         * Set the message type for the experiment.
         *
         * @param messageType MessageType
         * @return Builder
         */
        public Builder setMessageType(MessageType messageType) {
            this.messageType = messageType;
            return this;
        }

        /**
         * Set the campaigns for the experiment.
         *
         * @param campaigns Campaigns
         * @return Builder
         */
        public Builder setCampaigns(Campaigns campaigns) {
            this.campaigns = campaigns;
            return this;
        }

        /**
         * Build an Experiment object. Will fail if any of the following
         * preconditions are not met.
         * 
         * 1. Audience must be set.
         * 2. DeviceTypes (device types) must be set.
         * 3. At least one variant must be present.
         * 
* * @return Experiment * @throws IllegalArgumentException if illegal arguments are used * @throws NullPointerException if audience, deviceTypes, or variants is not set */ public Experiment build() { Preconditions.checkNotNull(audience, "'audience' must be set"); Preconditions.checkNotNull(deviceTypes, "'device_types' must be set"); Preconditions.checkNotNull(variants, "An experiment requires at least one variant."); Preconditions.checkArgument(variants.size() > 0, "At least one variant must be present."); return new Experiment(this); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy