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

com.urbanairship.api.push.model.notification.ios.IOSDevicePayload Maven / Gradle / Ivy

There is a newer version: 9.4.2
Show newest version
/*
 * 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 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) {
        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;
    }

    /**
     * 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;
    }

    @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);
    }

    @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);
    }

    @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 +
                '}';
    }

    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 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;
        }

        /**
         * 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));
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy