Chromium Code Reviews| Index: sync/android/java/src/org/chromium/sync/signin/AuthException.java |
| diff --git a/sync/android/java/src/org/chromium/sync/signin/AuthException.java b/sync/android/java/src/org/chromium/sync/signin/AuthException.java |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..34376e623589b9d5dd4260c14408d6516b99ee27 |
| --- /dev/null |
| +++ b/sync/android/java/src/org/chromium/sync/signin/AuthException.java |
| @@ -0,0 +1,56 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +package org.chromium.sync.signin; |
| + |
| +import android.content.Intent; |
| + |
| +/* |
| + * AuthException abstracts away authenticator specific exceptions behind a single interface. |
| + * It is used for passing information that is useful for better handling of errors. |
| + */ |
| +public class AuthException extends Exception { |
| + private final boolean mIsTransientError; |
| + private final Intent mRecoveryIntent; |
| + private final Exception mInnerException; |
| + |
| + /* |
| + * A simple constructor that stores all the error handling information and makes it available to |
| + * the handler. |
| + * @param isTransientError Whether the error is transient and we can retry. |
| + * @param recoveryIntent An intent that can be used to recover from this error. |
| + * Thus, a user recoverable error is not transient, since it requires explicit user handling |
| + * before retry. |
| + */ |
| + public AuthException(boolean isTransientError, Intent recoveryIntent, Exception exception) { |
| + assert !isTransientError || recoveryIntent == null; |
| + assert exception != null; |
| + mIsTransientError = isTransientError; |
| + mRecoveryIntent = recoveryIntent; |
| + mInnerException = exception; |
|
Bernhard Bauer
2015/11/20 18:55:42
You could pass this one to the super constructor i
knn
2015/11/23 11:35:32
Done.
|
| + } |
| + |
| + /* |
| + * @return Whether the error is transient and we can retry. |
| + */ |
| + public boolean isTransientError() { |
| + return mIsTransientError; |
| + } |
| + |
| + /* |
| + * @return An intent that can be used to recover from this error if it is recoverabale by user |
| + * intervention, else {@code null}. |
| + */ |
| + public Intent getRecoveryIntent() { |
| + return mRecoveryIntent; |
| + } |
| + |
| + /* |
| + * @return The original exception that is encapsulated by this AuthException. |
| + * Used for logging. |
| + */ |
| + public Exception getInnerException() { |
| + return mInnerException; |
| + } |
| +} |