com.urbanairship.api.channel.model.ChannelView Maven / Gradle / Ivy
/*
* Copyright (c) 2013-2016. Urban Airship and Contributors
*/
package com.urbanairship.api.channel.model;
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 com.google.common.collect.ImmutableSet;
import com.urbanairship.api.channel.model.ios.IosSettings;
import com.urbanairship.api.channel.model.open.OpenChannel;
import com.urbanairship.api.channel.model.web.WebSettings;
import org.apache.commons.lang.StringUtils;
import org.joda.time.DateTime;
import java.util.Map;
/**
* Represents a single channel object.
*/
public final class ChannelView {
private final String channelId;
private final String channelType;
private final boolean installed;
private final boolean optIn;
private final Optional background;
private final Optional pushAddress;
private final DateTime created;
private final Optional lastRegistration;
private final Optional alias;
private final ImmutableSet tags;
private final ImmutableMap> tagGroups;
private final Optional iosSettings;
private final Optional web;
private final Optional open;
private final Optional address;
private final Optional namedUser;
private final ImmutableMap attributes;
private final ImmutableMap deviceAttributes;
private final Optional commercialOptedIn;
private final Optional commercialOptedOut;
private final Optional transactionalOptedIn;
private final Optional transactionalOptedOut;
private ChannelView(Builder builder) {
this.channelId = builder.channelId;
this.channelType = builder.channelType;
this.installed = builder.installed;
this.optIn = builder.optIn;
this.background = Optional.fromNullable(builder.background);
this.pushAddress = Optional.fromNullable(builder.pushAddress);
this.created = builder.created;
this.lastRegistration = Optional.fromNullable(builder.lastRegistration);
this.alias = Optional.fromNullable(builder.alias);
this.tags = builder.tags.build();
this.tagGroups = builder.tagGroups.build();
this.iosSettings = Optional.fromNullable(builder.iosSettings);
this.web = Optional.fromNullable(builder.webSettings);
this.open = Optional.fromNullable(builder.openChannel);
this.address = Optional.fromNullable(builder.address);
this.namedUser = Optional.fromNullable(builder.namedUser);
this.attributes = builder.attributes.build();
this.deviceAttributes = builder.deviceAttributes.build();
this.commercialOptedIn = Optional.fromNullable(builder.commercialOptedIn);
this.commercialOptedOut = Optional.fromNullable(builder.commercialOptedOut);
this.transactionalOptedIn = Optional.fromNullable(builder.transactionalOptedIn);
this.transactionalOptedOut = Optional.fromNullable(builder.transactionalOptedOut);
}
/**
* New ChannelView builder.
*
* @return builder
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the channel ID
*
* @return String channel ID
*/
public String getChannelId() {
return channelId;
}
/**
* Get the channel type
*
* @return String channelType
*/
public String getChannelType() {
return channelType;
}
/**
* Get the installed status as a boolean
*
* @return boolean installed status
*/
public boolean isInstalled() {
return installed;
}
/**
* Get the opt-in status as a boolean
*
* @return boolean opt-in status
*/
public boolean isOptIn() {
return optIn;
}
/**
* Get the background status as a boolean
*
* @return Optional boolean background status
*/
public Optional getBackground() {
return background;
}
/**
* Get the push address
*
* @return Optional String push address
*/
public Optional getPushAddress() {
return pushAddress;
}
/**
* Get the time when the channel was created
*
* @return DateTime of creation
*/
public DateTime getCreated() {
return created;
}
/**
* Get the time of last registration
*
* @return Optional DateTime of last registration
*/
public Optional getLastRegistration() {
return lastRegistration;
}
/**
* Get the associated alias
*
* @return Optional String alias
*/
public Optional getAlias() {
return alias;
}
/**
* Get any associated tags
*
* @return ImmutableSet of tags
*/
public ImmutableSet getTags() {
return tags;
}
/**
* Get any associated tag groups and tags
*
* @return ImmutableMap of tag groups and the relevant Immutable sets of tags
*/
public ImmutableMap> getTagGroups() {
return tagGroups;
}
/**
* Get the iOS settings
*
* @return Optional IosSettings
*/
public Optional getIosSettings() {
return iosSettings;
}
/**
* Get the WebSettings displayed only for WebSettings channels
*
* @return Optional WebSettings
*/
public Optional getWebSettings() {
return web;
}
/**
* Get the OpenChannel Platform Options Object.
*
* @return Optional OpenChannel
*/
public Optional getOpen() {
return open;
}
/**
* Get the address. The primary identifier of a record. For example,
* in an SMS integration, it could be the end user’s phone number.
*
* @return Optional String address
*/
public Optional getAddress() {
return address;
}
/**
* Get the named user. A Named User is a proprietary identifier
* that maps customer-chosen IDs, e.g., CRM data, to Channels.
*
* @return Optional String namedUser
*/
public Optional getNamedUser() {
return namedUser;
}
/**
* Get attributes associated with the channel.
*
* @return Map of Strings attributes
*/
public ImmutableMap getAttributes() {
return attributes;
}
/**
* Get device attributes associated with the channel.
*
* @return Map of Strings deviceAttributes
*/
public ImmutableMap getDeviceAttributes() {
return deviceAttributes;
}
/**
* Get the time of commercialOptedIn date
*
* @return Optional DateTime of commercialOptedIn date
*/
public Optional getCommercialOptedIn() {
return commercialOptedIn;
}
/**
* Get the time of commercialOptedOut date
*
* @return Optional DateTime of commercialOptedOut date
*/
public Optional getCommercialOptedOut() {
return commercialOptedOut;
}
/**
* Get the time of transactionalOptedIn date
*
* @return Optional DateTime of transactionalOptedIn date
*/
public Optional getTransactionalOptedIn() {
return transactionalOptedIn;
}
/**
* Get the time of transactionalOptedOut date
*
* @return Optional DateTime of transactionalOptedOut date
*/
public Optional getTransactionalOptedOut() {
return transactionalOptedOut;
}
@Override
public String toString() {
return "ChannelView{" +
"channelId='" + channelId + '\'' +
", channelType='" + channelType + '\'' +
", installed=" + installed +
", optIn=" + optIn +
", background=" + background +
", pushAddress=" + pushAddress +
", created=" + created +
", lastRegistration=" + lastRegistration +
", alias=" + alias +
", tags=" + tags +
", tagGroups=" + tagGroups +
", iosSettings=" + iosSettings +
", web=" + web +
", open=" + open +
", address=" + address +
", namedUser=" + namedUser +
", attributes=" + attributes +
", deviceAttributes=" + deviceAttributes +
", commercialOptedIn=" + commercialOptedIn +
", commercialOptedOut=" + commercialOptedOut +
", transactionalOptedIn=" + transactionalOptedIn +
", transactionalOptedOut=" + transactionalOptedOut +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
ChannelView that = (ChannelView) o;
return installed == that.installed &&
optIn == that.optIn &&
Objects.equal(channelId, that.channelId) &&
Objects.equal(channelType, that.channelType) &&
Objects.equal(background, that.background) &&
Objects.equal(pushAddress, that.pushAddress) &&
Objects.equal(created, that.created) &&
Objects.equal(lastRegistration, that.lastRegistration) &&
Objects.equal(alias, that.alias) &&
Objects.equal(tags, that.tags) &&
Objects.equal(tagGroups, that.tagGroups) &&
Objects.equal(iosSettings, that.iosSettings) &&
Objects.equal(web, that.web) &&
Objects.equal(open, that.open) &&
Objects.equal(address, that.address) &&
Objects.equal(namedUser, that.namedUser) &&
Objects.equal(attributes, that.attributes) &&
Objects.equal(deviceAttributes, that.deviceAttributes) &&
Objects.equal(commercialOptedIn, that.commercialOptedIn) &&
Objects.equal(commercialOptedOut, that.commercialOptedOut) &&
Objects.equal(transactionalOptedIn, that.transactionalOptedIn) &&
Objects.equal(transactionalOptedOut, that.transactionalOptedOut);
}
@Override
public int hashCode() {
return Objects.hashCode(channelId, channelType, installed, optIn, background, pushAddress, created, lastRegistration,
alias, tags, tagGroups, iosSettings, web, open, address, namedUser, attributes, deviceAttributes, commercialOptedIn, commercialOptedOut, transactionalOptedIn, transactionalOptedOut);
}
public final static class Builder {
private final ImmutableSet.Builder tags = ImmutableSet.builder();
private final ImmutableMap.Builder> tagGroups = ImmutableMap.builder();
private final ImmutableMap.Builder attributes = ImmutableMap.builder();
private final ImmutableMap.Builder deviceAttributes = ImmutableMap.builder();
private String channelId = null;
private String channelType = null;
private Boolean optIn = null;
private Boolean installed = null;
private Boolean background = null;
private String pushAddress = null;
private DateTime created = null;
private DateTime lastRegistration = null;
private String alias = null;
private IosSettings iosSettings = null;
private WebSettings webSettings = null;
private OpenChannel openChannel = null;
private String address = null;
private String namedUser = null;
private DateTime commercialOptedIn = null;
private DateTime commercialOptedOut = null;
private DateTime transactionalOptedIn = null;
private DateTime transactionalOptedOut = null;
private Builder() {
}
/**
* Add all attributes to the channel.
*
* @param attributes Map of Strings attributes
* @return Builder
*/
public Builder addAllAttributes(Map attributes) {
for (String key : attributes.keySet()) {
this.attributes.put(key, String.valueOf(attributes.get(key)));
}
return this;
}
/**
* Add all device attributes to the channel.
*
* @param deviceAttributes Map of Strings deviceAttributes
* @return Builder
*/
public Builder addAllDeviceAttributes(Map deviceAttributes) {
for (String key : deviceAttributes.keySet()) {
this.deviceAttributes.put(key, String.valueOf(deviceAttributes.get(key)));
}
return this;
}
/**
* Set the channel ID
*
* @param channelId String
* @return Builder
*/
public Builder setChannelId(String channelId) {
this.channelId = channelId;
return this;
}
/**
* Set the channel type
*
* @param channelType String
* @return Builder
*/
public Builder setChannelType(String channelType) {
this.channelType = channelType;
return this;
}
/**
* Set the installed status
*
* @param installed boolean
* @return Builder
*/
public Builder setInstalled(Boolean installed) {
this.installed = installed;
return this;
}
/**
* Set the opt-in status
*
* @param optIn boolean
* @return Builder
*/
public Builder setOptIn(Boolean optIn) {
this.optIn = optIn;
return this;
}
/**
* Set the background status
*
* @param background boolean
* @return Builder
*/
public Builder setBackground(Boolean background) {
this.background = background;
return this;
}
/**
* Set the push address
*
* @param pushAddress String
* @return Builder
*/
public Builder setPushAddress(String pushAddress) {
this.pushAddress = pushAddress;
return this;
}
/**
* Set the created time
* @param created DateTime
* @return Builder
*/
public Builder setCreated(DateTime created) {
this.created = created;
return this;
}
/**
* Set the last registration time
* @param lastRegistration DateTime
* @return Builder
*/
public Builder setLastRegistration(DateTime lastRegistration) {
this.lastRegistration = lastRegistration;
return this;
}
/**
* Set the alias
*
* @param alias String
* @return Builder
*/
public Builder setAlias(String alias) {
this.alias = alias;
return this;
}
/**
* Set the channel tags
*
* @param tags Iterable of tags
* @return Builder
*/
public Builder addAllTags(Iterable tags) {
Preconditions.checkNotNull(tags);
for (String tag : tags) {
this.tags.add(tag);
}
return this;
}
/**
* Add a tag
*
* @param tag String
* @return Builder
*/
public Builder addTag(String tag) {
if (StringUtils.isNotBlank(tag)) {
this.tags.add(tag);
}
return this;
}
/**
* Add a tag group with tags
*
* @param tagGroup A map entry of a tag group and ImmutableSet of tags
* @return Builder
*/
public Builder addTagGroup(Map.Entry> tagGroup) {
if (!tagGroup.getKey().isEmpty()) {
this.tagGroups.put(tagGroup);
}
return this;
}
/**
* Add all the tag groups with tags
*
* @param tagGroups ImmutableMap of tag groups and ImmutableSets of tags
* @return Builder
*/
public Builder addAllTagGroups(ImmutableMap> tagGroups) {
if (!tagGroups.isEmpty()) {
this.tagGroups.putAll(tagGroups);
}
return this;
}
/**
* Set the iOS settings
*
* @param iosSettings IosSettings
* @return Builder
*/
public Builder setIosSettings(IosSettings iosSettings) {
this.iosSettings = iosSettings;
return this;
}
/**
* Set the webSettings object
*
* @param webSettings WebSettings
* @return Builder
*/
public Builder setWebSettings(WebSettings webSettings) {
this.webSettings = webSettings;
return this;
}
/**
* Set the OpenChannel Platform Options Object.
* @param openChannel OpenChannel
* @return Builder
*/
public Builder setOpenChannel(OpenChannel openChannel) {
this.openChannel = openChannel;
return this;
}
/**
* Set the address. The primary identifier of a record. For example,
* in an SMS integration, it could be the end user’s phone number.
* @param address String
* @return Builder
*/
public Builder setAddress(String address) {
this.address = address;
return this;
}
/**
* Set the named user.
* @param namedUser String
* @return Builder
*/
public Builder setNamedUser(String namedUser) {
this.namedUser = namedUser;
return this;
}
/**
* Set the commercialOptedIn time
* @param commercialOptedIn DateTime
* @return Builder
*/
public Builder setCommercialOptedIn(DateTime commercialOptedIn) {
this.commercialOptedIn = commercialOptedIn;
return this;
}
/**
* Set the commercialOptedOut time
* @param commercialOptedOut DateTime
* @return Builder
*/
public Builder setCommercialOptedOut(DateTime commercialOptedOut) {
this.commercialOptedOut = commercialOptedOut;
return this;
}
/**
* Set the transactionalOptedIn time
* @param transactionalOptedIn DateTime
* @return Builder
*/
public Builder setTransactionalOptedIn(DateTime transactionalOptedIn) {
this.transactionalOptedIn = transactionalOptedIn;
return this;
}
/**
* Set the transactionalOptedOut time
* @param transactionalOptedOut DateTime
* @return Builder
*/
public Builder setTransactionalOptedOut(DateTime transactionalOptedOut) {
this.transactionalOptedOut = transactionalOptedOut;
return this;
}
/**
* Build the ChannelView object
* @return ChannelView
*/
public ChannelView build() {
Preconditions.checkNotNull(channelId);
Preconditions.checkNotNull(channelType);
Preconditions.checkNotNull(installed);
Preconditions.checkNotNull(optIn);
Preconditions.checkNotNull(created);
return new ChannelView(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy