com.urbanairship.api.channel.model.open.OpenChannel Maven / Gradle / Ivy
package com.urbanairship.api.channel.model.open;
import com.google.common.base.Objects;
import com.google.common.base.Optional;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableMap;
import java.util.Map;
/**
* Open Platform Options Object.
*/
public class OpenChannel {
private final String openPlatformName;
private final Optional oldAddress;
private final Optional> identifiers;
private OpenChannel() {
this(null, Optional.absent(), Optional.>absent());
}
@Override
public String toString() {
return "OpenChannel{" +
"openPlatformName='" + openPlatformName + '\'' +
", oldAddress=" + oldAddress +
", identifiers=" + identifiers +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
OpenChannel that = (OpenChannel) o;
return Objects.equal(openPlatformName, that.openPlatformName) &&
Objects.equal(oldAddress, that.oldAddress) &&
Objects.equal(identifiers, that.identifiers);
}
@Override
public int hashCode() {
return Objects.hashCode(openPlatformName, oldAddress, identifiers);
}
private OpenChannel(String openPlatformName,
Optional oldAddress,
Optional> identifiers) {
this.openPlatformName = openPlatformName;
this.oldAddress = oldAddress;
this.identifiers = identifiers;
}
private OpenChannel(Builder builder) {
this.openPlatformName = builder.openPlatformName;
this.oldAddress = Optional.fromNullable(builder.oldAddress);
if (builder.identifiers.build().isEmpty()) {
this.identifiers = Optional.absent();
} else {
this.identifiers = Optional.of(builder.identifiers.build());
}
}
/**
* New OpenChannel Builder.
* @return Builder
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the canonical name of the open platform on which the channel is registered.
* @return String openPlatformName
*/
public String getOpenPlatformName() {
return openPlatformName;
}
/**
* Get the old address. If for any reason the primary identifier of the record changes, include this key,
* and all tag and identifier information associated with the channel will be preserved,
* while the address will be replaced with the new value in 'address'.
* After a call swapping the address, new registrations referencing
* the old address will be assumed to represent a new channel.
* @return Optional String oldAddress
*/
public Optional getOldAddress() {
return oldAddress;
}
/**
* Get identifiers. Optional, array of string pairs. These will be delivered in open channels payloads,
* but cannot be used for segmentations. Maximum of 100 pairs of string values.
* This value should be exhaustive whenever this key is present—values will not be unioned
* with existing identifiers, they will replace them, similar to "set_tags": true above.
* @return Optional ImmutableMap of Strings
*/
public Optional> getIdentifiers() {
return identifiers;
}
/**
* OpenChannel Builder
*/
public final static class Builder {
private String openPlatformName = null;
private String oldAddress = null;
private ImmutableMap.Builder identifiers = ImmutableMap.builder();
private Builder() { }
/**
* Set the canonical name of the open platform on which the channel is registered.
*
* @param platformName String
* @return OpenChannel Builder
*/
public Builder setOpenPlatformName(String platformName) {
this.openPlatformName = platformName;
return this;
}
/**
* Set old address. If for any reason the primary identifier of the record changes, include this key,
* and all tag and identifier information associated with the channel will be preserved,
* while the address will be replaced with the new value in 'address'.
* After a call swapping the address, new registrations referencing
* the old address will be assumed to represent a new channel.
* @param oldAddress String
* @return OpenChannel Builder
*/
public Builder setOldAddress(String oldAddress) {
this.oldAddress = oldAddress;
return this;
}
/**
* Add identifier. Optional, array of string pairs. These will be delivered in open channels payloads,
* but cannot be used for segmentations. Maximum of 100 pairs of string values.
* This value should be exhaustive whenever this key is present—values will not be unioned
* with existing identifiers, they will replace them, similar to "set_tags": true above.
* @param key String
* @param value String
* @return OpenChannel Builder
*/
public Builder addIdentifier(String key, String value) {
this.identifiers.put(key, value);
return this;
}
/**
* Add all identifiers. Optional, array of string pairs. These will be delivered in open channels payloads,
* but cannot be used for segmentations. Maximum of 100 pairs of string values.
* This value should be exhaustive whenever this key is present—values will not be unioned
* with existing identifiers, they will replace them, similar to "set_tags": true above.
* @param entries Map of Strings
* @return OpenChannel Builder
*/
public Builder addAllIdentifierEntries(Map entries) {
this.identifiers.putAll(entries);
return this;
}
/**
* Build the OpenChannel object
* @return OpenChannel
*/
public OpenChannel build() {
Preconditions.checkNotNull(openPlatformName, "Open platform name must not be null.");
return new OpenChannel(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy