1d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd/*
2d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * Copyright (C) 2015 The Android Open Source Project
3d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd *
4d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * Licensed under the Apache License, Version 2.0 (the "License");
5d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * you may not use this file except in compliance with the License.
6d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * You may obtain a copy of the License at
7d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd *
8d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd *      http://www.apache.org/licenses/LICENSE-2.0
9d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd *
10d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * Unless required by applicable law or agreed to in writing, software
11d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * distributed under the License is distributed on an "AS IS" BASIS,
12d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * See the License for the specific language governing permissions and
14d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * limitations under the License.
15d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd */
16d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
17d3b009ae55651f1e60950342468e3c37fdeb0796Mike Doddpackage com.android.messaging.sms;
18d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
19d3b009ae55651f1e60950342468e3c37fdeb0796Mike Doddimport com.android.messaging.datamodel.data.MessageData;
20d3b009ae55651f1e60950342468e3c37fdeb0796Mike Doddimport com.android.messaging.util.Assert;
21d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
22d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd/**
23d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd * Exception for MMS failures
24d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd */
25d3b009ae55651f1e60950342468e3c37fdeb0796Mike Doddpublic class MmsFailureException extends Exception {
26d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    private static final long serialVersionUID = 1L;
27d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
28d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
29d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * Hint of how we should retry in case of failure. Take values defined in MmsUtils.
30d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
31d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public final int retryHint;
32d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
33d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
34d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * If set, provides a more detailed reason for the failure.
35d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
36d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public final int rawStatus;
37d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
38d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    private void checkRetryHint() {
39d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        Assert.isTrue(retryHint == MmsUtils.MMS_REQUEST_AUTO_RETRY
40d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd                || retryHint == MmsUtils.MMS_REQUEST_MANUAL_RETRY
41d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd                || retryHint == MmsUtils.MMS_REQUEST_NO_RETRY);
42d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
43d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
44d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * Creates a new MmsFailureException.
45d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     *
46d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param retryHint Hint for how to retry
47d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
48d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public MmsFailureException(final int retryHint) {
49d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        super();
50d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.retryHint = retryHint;
51d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        checkRetryHint();
52d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.rawStatus = MessageData.RAW_TELEPHONY_STATUS_UNDEFINED;
53d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
54d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
55d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public MmsFailureException(final int retryHint, final int rawStatus) {
56d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        super();
57d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.retryHint = retryHint;
58d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        checkRetryHint();
59d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.rawStatus = rawStatus;
60d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
61d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
62d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
63d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * Creates a new MmsFailureException with the specified detail message.
64d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     *
65d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param retryHint Hint for how to retry
66d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param message the detail message.
67d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
68d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public MmsFailureException(final int retryHint, String message) {
69d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        super(message);
70d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.retryHint = retryHint;
71d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        checkRetryHint();
72d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.rawStatus = MessageData.RAW_TELEPHONY_STATUS_UNDEFINED;
73d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
74d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
75d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
76d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * Creates a new MmsFailureException with the specified cause.
77d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     *
78d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param retryHint Hint for how to retry
79d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param cause the cause.
80d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
81d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public MmsFailureException(final int retryHint, Throwable cause) {
82d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        super(cause);
83d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.retryHint = retryHint;
84d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        checkRetryHint();
85d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.rawStatus = MessageData.RAW_TELEPHONY_STATUS_UNDEFINED;
86d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
87d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd
88d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    /**
89d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * Creates a new MmsFailureException
90d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * with the specified detail message and cause.
91d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     *
92d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param retryHint Hint for how to retry
93d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param message the detail message.
94d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     * @param cause the cause.
95d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd     */
96d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    public MmsFailureException(final int retryHint, String message, Throwable cause) {
97d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        super(message, cause);
98d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.retryHint = retryHint;
99d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        checkRetryHint();
100d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd        this.rawStatus = MessageData.RAW_TELEPHONY_STATUS_UNDEFINED;
101d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd    }
102d3b009ae55651f1e60950342468e3c37fdeb0796Mike Dodd}
103