aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2014-09-03 02:42:05 +0200
committerVincent Breitmoser <valodim@mugenguild.com>2014-09-03 02:43:06 +0200
commit7bc424a8cb1c3d4d4c77778f27bd18fe61da0736 (patch)
tree0350e5ec8fab966159963572224d2151f0b0451f /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider
parente9b14585f5eecddf8c22b2e68aa1a0500682ba3a (diff)
downloadopen-keychain-7bc424a8cb1c3d4d4c77778f27bd18fe61da0736.tar.gz
open-keychain-7bc424a8cb1c3d4d4c77778f27bd18fe61da0736.tar.bz2
open-keychain-7bc424a8cb1c3d4d4c77778f27bd18fe61da0736.zip
work on passphrase caching, make use of cached SecretKeyType data (WIP!)
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/CachedPublicKeyRing.java17
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java11
2 files changed, 17 insertions, 11 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/CachedPublicKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/CachedPublicKeyRing.java
index 18b02156d..cfb4a915e 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/CachedPublicKeyRing.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/CachedPublicKeyRing.java
@@ -27,6 +27,7 @@ import org.sufficientlysecure.keychain.pgp.KeyRing;
import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;
import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;
import org.sufficientlysecure.keychain.provider.KeychainContract.Keys;
+import org.sufficientlysecure.keychain.provider.ProviderHelper.NotFoundException;
import org.sufficientlysecure.keychain.util.Log;
/** This implementation of KeyRing provides a cached view of PublicKeyRing
@@ -226,16 +227,12 @@ public class CachedPublicKeyRing extends KeyRing {
return mProviderHelper.getContentResolver().query(keysUri, null, null, null, null);
}
- public SecretKeyType getSecretKeyType(long keyId) throws PgpGeneralException {
- try {
- Object data = mProviderHelper.getGenericData(Keys.buildKeysUri(mUri),
- KeyRings.HAS_SECRET,
- ProviderHelper.FIELD_TYPE_INTEGER,
- KeyRings.KEY_ID + " = " + Long.toString(keyId));
- return SecretKeyType.fromNum(((Long) data).intValue());
- } catch(ProviderHelper.NotFoundException e) {
- throw new PgpGeneralException(e);
- }
+ public SecretKeyType getSecretKeyType(long keyId) throws NotFoundException {
+ Object data = mProviderHelper.getGenericData(Keys.buildKeysUri(mUri),
+ KeyRings.HAS_SECRET,
+ ProviderHelper.FIELD_TYPE_INTEGER,
+ KeyRings.KEY_ID + " = " + Long.toString(keyId));
+ return SecretKeyType.fromNum(((Long) data).intValue());
}
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java
index bfa95280e..186a0fc88 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java
@@ -141,7 +141,11 @@ public class ProviderHelper {
public static final int FIELD_TYPE_BLOB = 5;
public Object getGenericData(Uri uri, String column, int type) throws NotFoundException {
- return getGenericData(uri, new String[]{column}, new int[]{type}, null).get(column);
+ Object result = getGenericData(uri, new String[]{column}, new int[]{type}, null).get(column);
+ if (result == null) {
+ throw new NotFoundException();
+ }
+ return result;
}
public Object getGenericData(Uri uri, String column, int type, String selection)
@@ -229,6 +233,11 @@ public class ProviderHelper {
}
+ public long getMasterKeyId(long subKeyId) throws NotFoundException {
+ return (Long) getGenericData(KeyRings.buildUnifiedKeyRingsFindBySubkeyUri(subKeyId),
+ KeyRings.MASTER_KEY_ID, FIELD_TYPE_INTEGER);
+ }
+
public CachedPublicKeyRing getCachedPublicKeyRing(Uri queryUri) {
return new CachedPublicKeyRing(this, queryUri);
}