diff options
Diffstat (limited to 'OpenKeychain/src')
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"><unknown></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> | 
