com.urbanairship.api.push.model.notification.ios.IOSDevicePayload Maven / Gradle / Ivy
/*
* Copyright (c) 2013-2016. Urban Airship and Contributors
*/
package com.urbanairship.api.push.model.notification.ios;
import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableMap;
import com.urbanairship.api.push.model.DeviceType;
import com.urbanairship.api.push.model.PushExpiry;
import com.urbanairship.api.push.model.PushModelObject;
import com.urbanairship.api.push.model.notification.DevicePayloadOverride;
import com.urbanairship.api.push.model.notification.Interactive;
import com.urbanairship.api.push.model.notification.actions.Actions;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
/**
* IOSDevicePayload for iOS specific push messages.
*/
public final class IOSDevicePayload extends PushModelObject implements DevicePayloadOverride {
private final Optional alert;
private final Optional> extra;
private final Optional badge;
private final Optional contentAvailable;
private final Optional expiry;
private final Optional priority;
private final Optional category;
private final Optional interactive;
private final Optional title;
private final Optional subtitle;
private final Optional mediaAttachment;
private final Optional sound;
private final Optional mutableContent;
private final Optional collapseId;
private final Optional threadId;
private final Optional actions;
private final Optional targetContentId;
private final Optional iosTemplate;
private final Optional iosInterruptionLevel;
private final Optional relevanceScore;
private final Optional iosLiveActivity;
private IOSDevicePayload(Optional alert,
Optional badge,
Optional contentAvailable,
Optional expiry,
Optional priority,
Optional> extra,
Optional category,
Optional interactive,
Optional title,
Optional subtitle,
Optional mediaAttachment,
Optional sound,
Optional mutableContent,
Optional collapseId,
Optional threadId,
Optional actions,
Optional targetContentId,
Optional iosTemplate,
Optional iosInterruptionLevel,
Optional relevanceScore,
Optional iosLiveActivity) {
this.alert = alert;
this.badge = badge;
this.contentAvailable = contentAvailable;
this.extra = extra;
this.expiry = expiry;
this.priority = priority;
this.category = category;
this.interactive = interactive;
this.title = title;
this.subtitle = subtitle;
this.mediaAttachment = mediaAttachment;
this.sound = sound;
this.mutableContent = mutableContent;
this.collapseId = collapseId;
this.threadId = threadId;
this.actions = actions;
this.targetContentId = targetContentId;
this.iosTemplate = iosTemplate;
this.iosInterruptionLevel = iosInterruptionLevel;
this.relevanceScore = relevanceScore;
this.iosLiveActivity = iosLiveActivity;
}
/**
* Get a IOSDevicePayload Builder
* @return Builder
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the deviceType.
* @return DeviceType
*/
@Override
public DeviceType getDeviceType() {
return DeviceType.IOS;
}
/**
* Get the alert if present.
* @return Optional string representing the alert
*/
@Override
public Optional getAlert() {
return alert.isPresent() ? alert.get().getBody() : Optional.empty();
}
/**
* Get the IOSAlertData
* @return Optional IOSAlertData
*/
public Optional getAlertData() {
return alert;
}
/**
* Get IOSBadgeData
* @return Optional IOSBadgeData
*/
public Optional getBadge() {
return badge;
}
/**
* Get the content available boolean value
* @return Optional boolean representation of content available
*/
public Optional getContentAvailable() {
return contentAvailable;
}
/**
* Get a Map of the extra key value pairs
* @return Optional ImmutableMap of strings representing the key value pairs
*/
public Optional> getExtra() {
return extra;
}
/**
* Get the expiry (TTL) if present
* @return Optional PushExpiry expiry value
*/
public Optional getExpiry() {
return expiry;
}
/**
* Get the priority value
* @return Optional Integer representation of the priority
*/
public Optional getPriority() {
return priority;
}
/**
* Get the category if present
* @return Optional string representation of the category
*/
public Optional getCategory() {
return category;
}
/**
* Get the Interactive data if present
* @return Optional Interactive
*/
public Optional getInteractive() {
return interactive;
}
/**
* Get the title if present.
* @return Optional string representation of the title
*/
public Optional getTitle() {
return title;
}
/**
* Get the subtitle if present
* @return Optional string representation of the subtitle
*/
public Optional getSubtitle() {
return subtitle;
}
/**
* Get the mutable content boolean value
* @return Optional boolean representation of the mutable content
*/
public Optional getMutableContent() {
return mutableContent;
}
/**
* Get the Media Attachment object that specifies a media attachment to be
* handled by the UA Media Attachment Extension. iOS 10
* @return Optional MediaAttachment object.
*/
public Optional getMediaAttachment() {
return mediaAttachment;
}
/**
* Get the IOSSoundData if present.
* @return Optional IOSSoundData object
*/
public Optional getSoundData() { return sound; }
/**
* @deprecated The sound name can now be retrieved from getSoundData() as of 4.1.0.
*
* Gets the sound file name.
* @return String sound file name
*/
@Deprecated
public Optional getSound() {
if (!sound.isPresent()) {
return Optional.empty();
}
return sound.get().getName();
}
/**
* Get the Collapse ID String. When there is a newer message that renders an older, related message irrelevant to the client app,
* the new message replaces the older message with the same collapse ID. Similar to the GCM collapse key. iOS 10.
* @return Optional String representation of the collapse ID.
*/
public Optional getCollapseId() {
return collapseId;
}
/**
* Get the thread ID.
* @return Optional String representation of thread ID.
*/
public Optional getThreadId() {
return threadId;
}
/**
* Get the Actions.
* These describe actions to be performed by the SDK when a user interacts with the notification.
*
* @return Optional Action
*/
public Optional getActions() {
return actions;
}
/**
* Get the target content id.
* The identifier of the window to bring forward when the notification is opened. Used for multi-window content, such as App Clips.
*
* @return Optional String target content id.
*/
public Optional getTargetContentId() {
return targetContentId;
}
/**
* Get the template with iOS-specific message.
*
* @return Optional IOSTemplate iosTemplate
*/
public Optional getIosTemplate() {
return iosTemplate;
}
/**
* Get the interruption level.
*
* @return Optional IOSInterruptionLevel iosInterruptionLevel
*/
public Optional getIosInterruptionLevel() {
return iosInterruptionLevel;
}
/**
* Get the relevance score for iOS message.
*
* @return Optional Double relevanceScore
*/
public Optional getRelevanceScore(){
return relevanceScore;
}
/**
* Get the IOSLiveActivity if present.
* @return Optional IOSLiveActivity object
*/
public Optional getIosLiveActivity() { return iosLiveActivity; }
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
IOSDevicePayload that = (IOSDevicePayload) o;
return Objects.equals(alert, that.alert) &&
Objects.equals(extra, that.extra) &&
Objects.equals(badge, that.badge) &&
Objects.equals(contentAvailable, that.contentAvailable) &&
Objects.equals(expiry, that.expiry) &&
Objects.equals(priority, that.priority) &&
Objects.equals(category, that.category) &&
Objects.equals(interactive, that.interactive) &&
Objects.equals(title, that.title) &&
Objects.equals(subtitle, that.subtitle) &&
Objects.equals(mediaAttachment, that.mediaAttachment) &&
Objects.equals(sound, that.sound) &&
Objects.equals(mutableContent, that.mutableContent) &&
Objects.equals(collapseId, that.collapseId) &&
Objects.equals(threadId, that.threadId) &&
Objects.equals(actions, that.actions) &&
Objects.equals(targetContentId, that.targetContentId) &&
Objects.equals(iosTemplate, that.iosTemplate) &&
Objects.equals(iosInterruptionLevel, that.iosInterruptionLevel) &&
Objects.equals(relevanceScore, that.relevanceScore) &&
Objects.equals(iosLiveActivity, that.iosLiveActivity);
}
@Override
public int hashCode() {
return Objects.hash(alert, extra, badge, contentAvailable, expiry, priority, category, interactive, title, subtitle,
mediaAttachment, sound, mutableContent, collapseId, threadId, actions, targetContentId, iosTemplate,
iosInterruptionLevel, relevanceScore, iosLiveActivity);
}
@Override
public String toString() {
return "IOSDevicePayload{" +
"alert=" + alert +
", extra=" + extra +
", badge=" + badge +
", contentAvailable=" + contentAvailable +
", expiry=" + expiry +
", priority=" + priority +
", category=" + category +
", interactive=" + interactive +
", title=" + title +
", subtitle=" + subtitle +
", mediaAttachment=" + mediaAttachment +
", sound=" + sound +
", mutableContent=" + mutableContent +
", collapseId=" + collapseId +
", threadId=" + threadId +
", actions=" + actions +
", targetContentId=" + targetContentId +
", iosTemplate=" + iosTemplate +
", iosInterruptionLevel=" + iosInterruptionLevel +
", relevanceScore=" + relevanceScore +
", iosLiveActivity=" + iosLiveActivity +
'}';
}
public static class Builder {
private IOSAlertData alert = null;
private IOSBadgeData badge = null;
private Boolean contentAvailable = null;
private ImmutableMap.Builder extra = null;
private PushExpiry expiry = null;
private Integer priority = null;
private String category = null;
private Interactive interactive = null;
private String title = null;
private String subtitle = null;
private MediaAttachment mediaAttachment = null;
private IOSSoundData sound = null;
private Boolean mutableContent = null;
private String collapseId = null;
private String threadId = null;
private Actions actions;
private String targetContentId;
private IOSTemplate iosTemplate;
private IOSInterruptionLevel iosInterruptionLevel;
private Double relevanceScore;
private IOSLiveActivity iosLiveActivity;
private Builder() { }
/**
* Create an IOSAlertData object with the given alert string. This is a
* shortcut for setting an alert data object when no additional iOS
* APNS payload options are needed.
*
* @param alert String alert
* @return Builder
*/
public Builder setAlert(String alert) {
this.alert = IOSAlertData.newBuilder()
.setBody(alert)
.build();
return this;
}
/**
* Set the IOSAlertData object.
* @param alert IOSAlertData
* @return Builder
*/
public Builder setAlert(IOSAlertData alert) {
this.alert = alert;
return this;
}
/**
* Set the badge data.
* @param badge IOSBadgeData
* @return Builder
*/
public Builder setBadge(IOSBadgeData badge) {
this.badge = badge;
return this;
}
/**
* Set the flag indicating content availability.
* @param value Boolean for content availability.
* @return Builder
*/
public Builder setContentAvailable(boolean value) {
this.contentAvailable = value;
return this;
}
/**
* Set the expiry
* @param value Integer
* @return Builder
**/
public Builder setExpiry(PushExpiry value) {
this.expiry = value;
return this;
}
/**
* Set the priority
* @param value Integer
* @return Builder
**/
public Builder setPriority(int value) {
this.priority = value;
return this;
}
/**
* Add an extra key value pair to the notification payload. Maximum
* payload is 2000 bytes.
* @param key String key
* @param value String value
* @return Builder
*/
public Builder addExtraEntry(String key, String value) {
if (extra == null) {
extra = ImmutableMap.builder();
}
this.extra.put(key, value);
return this;
}
/**
* Add key value pairs to payload. Maximum payload is 2000 bytes.
* @param entries Map of key value pairs
* @return Builder.
*/
public Builder addAllExtraEntries(Map entries) {
if (extra == null) {
extra = ImmutableMap.builder();
}
this.extra.putAll(entries);
return this;
}
/**
* Set the category
* @param value String
* @return Builder
*/
public Builder setCategory(String value) {
this.category = value;
return this;
}
/**
* Set the Interactive object
* @param value Interactive
* @return Builder
*/
public Builder setInteractive(Interactive value) {
this.interactive = value;
return this;
}
/**
* Set the title
* @param value String
* @return Builder
*/
public Builder setTitle(String value) {
this.title = value;
return this;
}
public Builder setSubtitle(String value){
this.subtitle = value;
return this;
}
/**
* Set the media attachment.
* @param value MediaAttachment
* @return Builder
*/
public Builder setMediaAttachment(MediaAttachment value) {
this.mediaAttachment = value;
return this;
}
/**
* Set the IOSSoundData object.
*
* @param value IOSSoundData
* @return Builder
*/
public Builder setSoundData(IOSSoundData value) {
this.sound = value;
return this;
}
/**
* @deprecated This can now be set using setSoundData as of 4.1.0.
*
* Sets the name of the IOSSoundData object. This is a shortcut for when the only value pertaining to the 'sound' key is a sound file name.
*
* @param name String
* @return Builder
*/
@Deprecated
public Builder setSound(String name) {
this.sound = IOSSoundData.newBuilder()
.setName(name)
.build();
return this;
}
/**
* Set the mutable content
* @param value Boolean
* @return Builder
*/
public Builder setMutableContent(Boolean value) {
this.mutableContent = value;
return this;
}
/**
* Set the collapse ID. When there is a newer message that renders an older, related message irrelevant to the client app, the new message replaces the older message with the same collapse ID.
* @param value String
* @return Builder
*/
public Builder setCollapseId(String value) {
this.collapseId = value;
return this;
}
/**
* Set the thread ID.
* @param value String
* @return Builder
*/
public Builder setThreadId(String value) {
this.threadId = value;
return this;
}
/**
* Set the Actions.
* These describe actions to be performed by the SDK when a user interacts with the notification.
*
* @return Builder
* @param actions Actions
*/
public Builder setActions(Actions actions) {
this.actions = actions;
return this;
}
/**
* Set the target content id.
* The identifier of the window to bring forward when the notification is opened. Used for multi-window content, such as App Clips.
*
* @return Builder
* @param targetContentId String
*/
public Builder setTargetContentId(String targetContentId) {
this.targetContentId = targetContentId;
return this;
}
/**
* Set a template with iOS-specific message.
*
* @param iosTemplate IOSTemplate
* @return Builder
*/
public Builder setIosTemplate(IOSTemplate iosTemplate) {
this.iosTemplate = iosTemplate;
return this;
}
/**
* Set an interruption level.
*
* @param iosInterruptionLevel IOSInterruptionLevel
* @return Builder
*/
public Builder setIosInterruptionLevel(IOSInterruptionLevel iosInterruptionLevel) {
this.iosInterruptionLevel = iosInterruptionLevel;
return this;
}
/**
* Set the relevance score.
*
* @param relevanceScore Double
* @return Builder
*/
public Builder setRelevanceScore(Double relevanceScore) {
Preconditions.checkArgument(
relevanceScore >= 0.0 && relevanceScore <= 1.0,
"Relevance score must be a number between 0.0 and 1.0."
);
this.relevanceScore = relevanceScore;
return this;
}
/**
* Set Live Activity.
*
* @param iosLiveActivity IOSLiveActivity
* @return Builder
*/
public Builder setIosLiveActivity(IOSLiveActivity iosLiveActivity) {
this.iosLiveActivity = iosLiveActivity;
return this;
}
/**
* Build IOSDevicePayload
* @return IOSDevicePayload
*/
public IOSDevicePayload build() {
// Yes, empty payloads are valid (for Passes)
return new IOSDevicePayload(Optional.ofNullable(alert),
Optional.ofNullable(badge),
Optional.ofNullable(contentAvailable),
Optional.ofNullable(expiry),
Optional.ofNullable(priority),
extra == null ? Optional.>empty() : Optional.ofNullable(extra.build()),
Optional.ofNullable(category),
Optional.ofNullable(interactive),
Optional.ofNullable(title),
Optional.ofNullable(subtitle),
Optional.ofNullable(mediaAttachment),
Optional.ofNullable(sound),
Optional.ofNullable(mutableContent),
Optional.ofNullable(collapseId),
Optional.ofNullable(threadId),
Optional.ofNullable(actions),
Optional.ofNullable(targetContentId),
Optional.ofNullable(iosTemplate),
Optional.ofNullable(iosInterruptionLevel),
Optional.ofNullable(relevanceScore),
Optional.ofNullable(iosLiveActivity));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy