diff options
author | Dominik Schürmann <dominik@dominikschuermann.de> | 2013-01-10 19:32:35 +0100 |
---|---|---|
committer | Dominik Schürmann <dominik@dominikschuermann.de> | 2013-01-10 19:32:35 +0100 |
commit | b83d82146b10d2c01f5124cddaf68d823cc44c65 (patch) | |
tree | 2bb072921b84169f301956e3ffdb14ebf2f641ee | |
parent | 275bcc443e869e7106ef0971b8d8cde8f006cf51 (diff) | |
download | open-keychain-b83d82146b10d2c01f5124cddaf68d823cc44c65.tar.gz open-keychain-b83d82146b10d2c01f5124cddaf68d823cc44c65.tar.bz2 open-keychain-b83d82146b10d2c01f5124cddaf68d823cc44c65.zip |
Synchronizing methods in ApgKeyService
-rw-r--r-- | APG/src/org/thialfihar/android/apg/service/ApgKeyService.java | 62 |
1 files changed, 40 insertions, 22 deletions
diff --git a/APG/src/org/thialfihar/android/apg/service/ApgKeyService.java b/APG/src/org/thialfihar/android/apg/service/ApgKeyService.java index d5325673b..9a184c71f 100644 --- a/APG/src/org/thialfihar/android/apg/service/ApgKeyService.java +++ b/APG/src/org/thialfihar/android/apg/service/ApgKeyService.java @@ -32,7 +32,7 @@ import android.os.RemoteException; /** * TODO: * - * - is this service thread safe? Probably not! + * - is this service thread safe? * */ public class ApgKeyService extends Service { @@ -57,6 +57,43 @@ public class ApgKeyService extends Service { } /** + * Synchronized implementation of getPublicKeyRings + */ + private synchronized void getPublicKeyRingsSafe(long[] masterKeyIds, + boolean asAsciiArmoredStringArray, IApgGetKeyringsHandler handler) + throws RemoteException { + if (asAsciiArmoredStringArray) { + ArrayList<String> output = ProviderHelper.getPublicKeyRingsAsArmoredString(mContext, + masterKeyIds); + + handler.onSuccess(null, output); + } else { + byte[] outputBytes = ProviderHelper + .getPublicKeyRingsAsByteArray(mContext, masterKeyIds); + handler.onSuccess(outputBytes, null); + } + } + + /** + * Synchronized implementation of getSecretKeyRings + */ + private synchronized void getSecretKeyRingsSafe(long[] masterKeyIds, + boolean asAsciiArmoredStringArray, IApgGetKeyringsHandler handler) + throws RemoteException { + if (asAsciiArmoredStringArray) { + ArrayList<String> output = ProviderHelper.getSecretKeyRingsAsArmoredString(mContext, + masterKeyIds); + + handler.onSuccess(null, output); + } else { + byte[] outputBytes = ProviderHelper + .getSecretKeyRingsAsByteArray(mContext, masterKeyIds); + handler.onSuccess(outputBytes, null); + } + + } + + /** * This is the implementation of the interface IApgKeyService. All methods are oneway, meaning * asynchronous and return to the client using handlers. * @@ -67,32 +104,13 @@ public class ApgKeyService extends Service { @Override public void getPublicKeyRings(long[] masterKeyIds, boolean asAsciiArmoredStringArray, IApgGetKeyringsHandler handler) throws RemoteException { - if (asAsciiArmoredStringArray) { - ArrayList<String> output = ProviderHelper.getPublicKeyRingsAsArmoredString( - mContext, masterKeyIds); - - handler.onSuccess(null, output); - } else { - byte[] outputBytes = ProviderHelper.getPublicKeyRingsAsByteArray(mContext, - masterKeyIds); - handler.onSuccess(outputBytes, null); - } + getPublicKeyRingsSafe(masterKeyIds, asAsciiArmoredStringArray, handler); } @Override public void getSecretKeyRings(long[] masterKeyIds, boolean asAsciiArmoredStringArray, IApgGetKeyringsHandler handler) throws RemoteException { - if (asAsciiArmoredStringArray) { - ArrayList<String> output = ProviderHelper.getSecretKeyRingsAsArmoredString( - mContext, masterKeyIds); - - handler.onSuccess(null, output); - } else { - byte[] outputBytes = ProviderHelper.getSecretKeyRingsAsByteArray(mContext, - masterKeyIds); - handler.onSuccess(outputBytes, null); - } - + getSecretKeyRingsSafe(masterKeyIds, asAsciiArmoredStringArray, handler); } }; |