aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2014-08-21 00:02:33 +0200
committerVincent Breitmoser <valodim@mugenguild.com>2014-08-21 00:02:33 +0200
commitad9339b23d0192a8d0b41e9a4cd33c132cdb7f0e (patch)
treef5805cc531129f2baa958e13cd138af9b92acdf3 /OpenKeychain
parent63ca81d8717bad8df9a9c159126612eb62867647 (diff)
parent3ace5052e7b7b63c2de745b5626d9d08773174b7 (diff)
downloadopen-keychain-ad9339b23d0192a8d0b41e9a4cd33c132cdb7f0e.tar.gz
open-keychain-ad9339b23d0192a8d0b41e9a4cd33c132cdb7f0e.tar.bz2
open-keychain-ad9339b23d0192a8d0b41e9a4cd33c132cdb7f0e.zip
Merge branch 'master' of github.com:open-keychain/open-keychain
Diffstat (limited to 'OpenKeychain')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/KeychainApplication.java8
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/ContactSyncAdapterService.java92
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java8
-rw-r--r--OpenKeychain/src/main/res/raw/help_changelog.html1
-rw-r--r--OpenKeychain/src/main/res/values/strings.xml2
5 files changed, 70 insertions, 41 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/KeychainApplication.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/KeychainApplication.java
index ead29e229..ca9af8a9d 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/KeychainApplication.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/KeychainApplication.java
@@ -20,11 +20,13 @@ package org.sufficientlysecure.keychain;
import android.accounts.Account;
import android.accounts.AccountManager;
import android.app.Application;
+import android.content.ContentResolver;
import android.content.Context;
import android.content.Intent;
import android.graphics.PorterDuff;
import android.graphics.drawable.Drawable;
import android.os.Environment;
+import android.provider.ContactsContract;
import org.spongycastle.jce.provider.BouncyCastleProvider;
import org.sufficientlysecure.keychain.helper.Preferences;
@@ -112,8 +114,10 @@ public class KeychainApplication extends Application {
AccountManager manager = AccountManager.get(context);
Account[] accounts = manager.getAccountsByType(Constants.PACKAGE_NAME);
if (accounts == null || accounts.length == 0) {
- Account dummy = new Account(context.getString(R.string.app_name), Constants.PACKAGE_NAME);
- manager.addAccountExplicitly(dummy, null, null);
+ Account account = new Account(context.getString(R.string.app_name), Constants.PACKAGE_NAME);
+ manager.addAccountExplicitly(account, null, null);
+ ContentResolver.setIsSyncable(account, ContactsContract.AUTHORITY, 1);
+ ContentResolver.setSyncAutomatically(account, ContactsContract.AUTHORITY, true);
}
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/ContactSyncAdapterService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/ContactSyncAdapterService.java
index 43ed2dad0..909c3031c 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/ContactSyncAdapterService.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/ContactSyncAdapterService.java
@@ -21,6 +21,8 @@ import android.accounts.Account;
import android.app.Service;
import android.content.AbstractThreadedSyncAdapter;
import android.content.ContentProviderClient;
+import android.content.ContentResolver;
+import android.content.Context;
import android.content.Intent;
import android.content.SyncResult;
import android.os.Bundle;
@@ -29,9 +31,11 @@ import android.os.IBinder;
import android.os.Looper;
import android.os.Message;
import android.os.Messenger;
+import android.provider.ContactsContract;
import org.sufficientlysecure.keychain.Constants;
import org.sufficientlysecure.keychain.KeychainApplication;
+import org.sufficientlysecure.keychain.R;
import org.sufficientlysecure.keychain.helper.ContactHelper;
import org.sufficientlysecure.keychain.helper.EmailKeyHelper;
import org.sufficientlysecure.keychain.util.Log;
@@ -42,7 +46,7 @@ public class ContactSyncAdapterService extends Service {
private class ContactSyncAdapter extends AbstractThreadedSyncAdapter {
- private final AtomicBoolean importDone = new AtomicBoolean(false);
+// private final AtomicBoolean importDone = new AtomicBoolean(false);
public ContactSyncAdapter() {
super(ContactSyncAdapterService.this, true);
@@ -51,47 +55,59 @@ public class ContactSyncAdapterService extends Service {
@Override
public void onPerformSync(Account account, Bundle extras, String authority, ContentProviderClient provider,
final SyncResult syncResult) {
- importDone.set(false);
- KeychainApplication.setupAccountAsNeeded(ContactSyncAdapterService.this);
- EmailKeyHelper.importContacts(getContext(), new Messenger(new Handler(Looper.getMainLooper(),
- new Handler.Callback() {
- @Override
- public boolean handleMessage(Message msg) {
- Bundle data = msg.getData();
- switch (msg.arg1) {
- case KeychainIntentServiceHandler.MESSAGE_OKAY:
- Log.d(Constants.TAG, "Syncing... Done.");
- synchronized (importDone) {
- importDone.set(true);
- importDone.notifyAll();
- }
- return true;
- case KeychainIntentServiceHandler.MESSAGE_UPDATE_PROGRESS:
- if (data.containsKey(KeychainIntentServiceHandler.DATA_PROGRESS) &&
- data.containsKey(KeychainIntentServiceHandler.DATA_PROGRESS_MAX)) {
- Log.d(Constants.TAG, "Syncing... Progress: " +
- data.getInt(KeychainIntentServiceHandler.DATA_PROGRESS) + "/" +
- data.getInt(KeychainIntentServiceHandler.DATA_PROGRESS_MAX));
- return false;
- }
- default:
- Log.d(Constants.TAG, "Syncing... " + msg.toString());
- return false;
- }
- }
- })));
- synchronized (importDone) {
- try {
- if (!importDone.get()) importDone.wait();
- } catch (InterruptedException e) {
- Log.w(Constants.TAG, e);
- return;
- }
- }
+ Log.d(Constants.TAG, "Performing a sync!");
+ // TODO: Import is currently disabled for 2.8, until we implement proper origin management
+// importDone.set(false);
+// KeychainApplication.setupAccountAsNeeded(ContactSyncAdapterService.this);
+// EmailKeyHelper.importContacts(getContext(), new Messenger(new Handler(Looper.getMainLooper(),
+// new Handler.Callback() {
+// @Override
+// public boolean handleMessage(Message msg) {
+// Bundle data = msg.getData();
+// switch (msg.arg1) {
+// case KeychainIntentServiceHandler.MESSAGE_OKAY:
+// Log.d(Constants.TAG, "Syncing... Done.");
+// synchronized (importDone) {
+// importDone.set(true);
+// importDone.notifyAll();
+// }
+// return true;
+// case KeychainIntentServiceHandler.MESSAGE_UPDATE_PROGRESS:
+// if (data.containsKey(KeychainIntentServiceHandler.DATA_PROGRESS) &&
+// data.containsKey(KeychainIntentServiceHandler.DATA_PROGRESS_MAX)) {
+// Log.d(Constants.TAG, "Syncing... Progress: " +
+// data.getInt(KeychainIntentServiceHandler.DATA_PROGRESS) + "/" +
+// data.getInt(KeychainIntentServiceHandler.DATA_PROGRESS_MAX));
+// return false;
+// }
+// default:
+// Log.d(Constants.TAG, "Syncing... " + msg.toString());
+// return false;
+// }
+// }
+// })));
+// synchronized (importDone) {
+// try {
+// if (!importDone.get()) importDone.wait();
+// } catch (InterruptedException e) {
+// Log.w(Constants.TAG, e);
+// return;
+// }
+// }
ContactHelper.writeKeysToContacts(ContactSyncAdapterService.this);
}
}
+ public static void requestSync(Context context) {
+ Bundle extras = new Bundle();
+ // no need to wait for internet connection!
+ extras.putBoolean(ContentResolver.SYNC_EXTRAS_MANUAL, true);
+ ContentResolver.requestSync(
+ new Account(context.getString(R.string.app_name), Constants.PACKAGE_NAME),
+ ContactsContract.AUTHORITY,
+ extras);
+ }
+
@Override
public IBinder onBind(Intent intent) {
return new ContactSyncAdapter().getSyncAdapterBinder();
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java
index b7596ea4b..246804383 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java
@@ -454,6 +454,9 @@ public class KeychainIntentService extends IntentService
setProgress(R.string.progress_done, 100, 100);
+ // make sure new data is synced into contacts
+ ContactSyncAdapterService.requestSync(this);
+
/* Output */
sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, saveResult);
} catch (Exception e) {
@@ -502,6 +505,8 @@ public class KeychainIntentService extends IntentService
if (result.mSecret > 0) {
providerHelper.consolidateDatabaseStep1(this);
}
+ // make sure new data is synced into contacts
+ ContactSyncAdapterService.requestSync(this);
sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result);
} catch (Exception e) {
@@ -709,6 +714,9 @@ public class KeychainIntentService extends IntentService
}
if (success) {
+ // make sure new data is synced into contacts
+ ContactSyncAdapterService.requestSync(this);
+
sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY);
}
diff --git a/OpenKeychain/src/main/res/raw/help_changelog.html b/OpenKeychain/src/main/res/raw/help_changelog.html
index 5f1798896..c8992ddab 100644
--- a/OpenKeychain/src/main/res/raw/help_changelog.html
+++ b/OpenKeychain/src/main/res/raw/help_changelog.html
@@ -16,6 +16,7 @@ And don't add newlines before or after p tags because of transifex -->
<li>New icons to show status of key (by Brennan Novak)</li>
<li>Important bug fix: Importing of large key collections from a file is now possible</li>
<li>Notification showing cached passphrases</li>
+<li>Keys are connected to Android's contacts</li>
</ul>
<p>This release wouldn't be possible without the work of Vincent Breitmoser (GSoC 2014), mar-v-in (GSoC 2014), Daniel Albert, Art O Cathain, Daniel Haß, Tim Bray, Thialfihar</p>
diff --git a/OpenKeychain/src/main/res/values/strings.xml b/OpenKeychain/src/main/res/values/strings.xml
index fede86b1c..2eb9f2b97 100644
--- a/OpenKeychain/src/main/res/values/strings.xml
+++ b/OpenKeychain/src/main/res/values/strings.xml
@@ -722,7 +722,7 @@
<string name="label_user_id">Identity</string>
<string name="unknown_uid">&lt;unknown&gt;</string>
<string name="empty_certs">No certificates for this key</string>
- <string name="certs_text">Only certificates created with your keys and self-certificates are displayed here.</string>
+ <string name="certs_text">Only self-certificates and certificates created with your keys are displayed here.</string>
<string name="section_uids_to_certify">Identities to certify</string>
<string name="label_revocation">Revocation Reason</string>
<string name="label_verify_status">Verification Status</string>