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

com.urbanairship.api.push.model.PushResponse 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;


import com.google.common.collect.ImmutableList;
import com.urbanairship.api.common.model.ErrorDetails;

import java.util.Objects;
import java.util.Optional;

/**
 * Represents a response from the Urban Airship API for Push Notifications.
 */
public final class PushResponse {

    private final Optional operationId;
    private final Optional> pushIds;
    private final boolean ok;
    private final Optional> messageIds;
    private final Optional> contentUrls;
    private final Optional> localizedIds;
    private final Optional error;
    private final Optional errorDetails;

    public PushResponse(String operationId, ImmutableList pushIds, boolean ok,
                        ImmutableList messageIds, ImmutableList contentUrls,
                        ImmutableList localizedIds,
                        String error,
                        ErrorDetails errorDetails) {
        this.operationId = Optional.ofNullable(operationId);
        this.pushIds = Optional.ofNullable(pushIds);
        this.ok = ok;
        this.messageIds = Optional.ofNullable(messageIds);
        this.localizedIds = Optional.ofNullable(localizedIds);
        this.contentUrls = Optional.ofNullable(contentUrls);
        this.error = Optional.ofNullable(error);
        this.errorDetails = Optional.ofNullable(errorDetails);
    
    }

    public static Builder newBuilder() {
        return new Builder();
    }

    /**
     * Get the operation id for this response. This is used by Urban Airship
     * to track an operation through our system, and should be used when support
     * is needed.
     *
     * @return Operation id for this API request
     */
    public Optional getOperationId() {
        return operationId;
    }

    /**
     * List of push id's, one for every actual push message that moves through
     * the API. This is useful for tracking an individual message as part of
     * an operation, and can be used when support is needed.
     *
     * @return List of push ids.
     */
    public Optional> getPushIds() {
        return pushIds;
    }

    /**
     * Get the response status as a boolean
     * @return Response status
     */
    public boolean getOk() {
        return ok;
    }

    public Optional> getMessageIds() {
        return messageIds;
    }

    public Optional> getContentUrls() {
        return contentUrls;
    }

    public Optional> getLocalizedIds() {
        return localizedIds;
    }

    /**
     * Get the error if present
     *
     * @return An Optional String
     */
    public Optional getError() {
        return error;
    }

    /**
     * Get the error details if present
     *
     * @return An Optional String
     */
    public Optional getErrorDetails() {
        return errorDetails;
    }

    @Override
    public String toString() {
        return "PushResponse{" +
                "operationId=" + operationId +
                ", pushIds=" + pushIds +
                ", ok=" + ok +
                ", messagesIds=" + messageIds +
                ", contentUrls=" + contentUrls +
                ", localizedIds=" + localizedIds +
                ", error=" + error +
                ", errorDetails=" + errorDetails +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        PushResponse that = (PushResponse) o;
        return ok == that.ok && Objects.equals(operationId, that.operationId) &&
                Objects.equals(pushIds, that.pushIds) && Objects.equals(messageIds, that.messageIds) &&
                Objects.equals(contentUrls, that.contentUrls) &&
                Objects.equals(localizedIds, that.localizedIds) && Objects.equals(error, that.error) &&
                Objects.equals(errorDetails, that.errorDetails);
    }

    @Override
    public int hashCode() {
        return Objects.hash(operationId, pushIds, ok, messageIds, contentUrls, localizedIds, error, errorDetails);
    }

    /**
     * PushResponse Builder
     */
    public static class Builder {
        private String operationId;
        private ImmutableList.Builder pushIds = ImmutableList.builder();
        private boolean ok = false;
        private ImmutableList.Builder messageIds = ImmutableList.builder();
        private ImmutableList.Builder contentUrls = ImmutableList.builder();
        private ImmutableList.Builder localizedIds = ImmutableList.builder();
        private String error;
        private ErrorDetails errorDetails;

        private Builder() {
        }

        public Builder setOperationId(String operationId) {
            this.operationId = operationId;
            return this;
        }

        public Builder addPushId(String pushId) {
            this.pushIds.add(pushId);
            return this;
        }

        public Builder addAllPushIds(Iterable pushIds) {
            this.pushIds.addAll(pushIds);
            return this;
        }

        public Builder setOk(boolean ok) {
            this.ok = ok;
            return this;
        }

        public Builder addMessageId(String messageId) {
            this.messageIds.add(messageId);
            return this;
        }

        public Builder addAllMessageIds(Iterable messageIds) {
            this.messageIds.addAll(messageIds);
            return this;
        }

        public Builder addContentUrl(String contentUrl) {
            this.contentUrls.add(contentUrl);
            return this;
        }

        public Builder addAllContentUrls(Iterable contentUrls) {
            this.contentUrls.addAll(contentUrls);
            return this;
        }

        public Builder addLocalizedId(String localizedId) {
            this.localizedIds.add(localizedId);
            return this;
        }

        public Builder addAllLocalizedIds(Iterable localizedIds) {
            this.localizedIds.addAll(localizedIds);
            return this;
        }

        public Builder setError(String error) {
            this.error = error;
            return this;
        }
    
        public Builder setErrorDetails(ErrorDetails errorDetails) {
            this.errorDetails = errorDetails;
            return this;
        }

        public PushResponse build() {
            return new PushResponse(operationId, pushIds.build(), ok, messageIds.build(), contentUrls.build(),
                    localizedIds.build(), error
                    , errorDetails);

        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy