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