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