aboutsummaryrefslogtreecommitdiffstats
path: root/OpenKeychain/src/main
diff options
context:
space:
mode:
authorVincent Breitmoser <valodim@mugenguild.com>2015-03-08 04:42:19 +0100
committerVincent Breitmoser <valodim@mugenguild.com>2015-03-08 04:42:19 +0100
commit99eb8725e92dde56511eafe2077e227cf9795f29 (patch)
tree1da245988716687ddacb65bc916eefdb402e6b36 /OpenKeychain/src/main
parentb57bcefe080a0070a65efb6e88d76af1eface52d (diff)
downloadopen-keychain-99eb8725e92dde56511eafe2077e227cf9795f29.tar.gz
open-keychain-99eb8725e92dde56511eafe2077e227cf9795f29.tar.bz2
open-keychain-99eb8725e92dde56511eafe2077e227cf9795f29.zip
successfully certify linked ids
Diffstat (limited to 'OpenKeychain/src/main')
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java25
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyFragment.java2
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/linked/LinkedIdViewFragment.java73
-rw-r--r--OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java1
-rw-r--r--OpenKeychain/src/main/res/layout/linked_id_view_fragment.xml1
5 files changed, 81 insertions, 21 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java
index c936fb6cc..cbb2737b6 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyActivity.java
@@ -41,6 +41,7 @@ import android.os.Messenger;
import android.provider.ContactsContract;
import android.provider.Settings;
import android.support.v4.app.ActivityCompat;
+import android.support.v4.app.FragmentManager;
import android.support.v4.app.LoaderManager;
import android.support.v4.content.CursorLoader;
import android.support.v4.content.Loader;
@@ -999,15 +1000,21 @@ public class ViewKeyActivity extends BaseActivity implements
private void startFragment(boolean isSecret, byte[] fingerprint) {
// Create an instance of the fragment
- ViewKeyFragment frag = ViewKeyFragment.newInstance(mDataUri, isSecret, fingerprint);
-
- // Add the fragment to the 'fragment_container' FrameLayout
- // NOTE: We use commitAllowingStateLoss() to prevent weird crashes!
- getSupportFragmentManager().beginTransaction()
- .replace(R.id.view_key_fragment, frag, "main")
- .commitAllowingStateLoss();
- // do it immediately!
- getSupportFragmentManager().executePendingTransactions();
+ final ViewKeyFragment frag = ViewKeyFragment.newInstance(mDataUri, isSecret, fingerprint);
+
+ new Handler().post(new Runnable() {
+ @Override
+ public void run() {
+
+ FragmentManager manager = getSupportFragmentManager();
+ manager.popBackStack("linked_id", FragmentManager.POP_BACK_STACK_INCLUSIVE);
+ // Add the fragment to the 'fragment_container' FrameLayout
+ // NOTE: We use commitAllowingStateLoss() to prevent weird crashes!
+ manager.beginTransaction()
+ .replace(R.id.view_key_fragment, frag, "main")
+ .commit();
+ }
+ });
}
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyFragment.java
index 240dd3547..c0d4a376b 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyFragment.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyFragment.java
@@ -148,7 +148,7 @@ public class ViewKeyFragment extends LoaderFragment implements
getFragmentManager().beginTransaction()
.replace(R.id.view_key_fragment, frag)
.addSharedElement(mLinkedIdsCard, "card_linked_ids")
- .addToBackStack(null)
+ .addToBackStack("linked_id")
.commit();
}
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/linked/LinkedIdViewFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/linked/LinkedIdViewFragment.java
index 7f8f4da04..6ad7fa443 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/linked/LinkedIdViewFragment.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/linked/LinkedIdViewFragment.java
@@ -1,6 +1,7 @@
package org.sufficientlysecure.keychain.ui.linked;
import java.io.IOException;
+import java.util.Arrays;
import android.app.Activity;
import android.app.ProgressDialog;
@@ -22,9 +23,11 @@ import android.widget.TextView;
import android.widget.ViewAnimator;
import org.spongycastle.util.encoders.Hex;
+import org.sufficientlysecure.keychain.Constants;
import org.sufficientlysecure.keychain.R;
import org.sufficientlysecure.keychain.operations.results.CertifyResult;
import org.sufficientlysecure.keychain.operations.results.LinkedVerifyResult;
+import org.sufficientlysecure.keychain.pgp.WrappedUserAttribute;
import org.sufficientlysecure.keychain.pgp.linked.LinkedCookieResource;
import org.sufficientlysecure.keychain.pgp.linked.LinkedIdentity;
import org.sufficientlysecure.keychain.pgp.linked.LinkedResource;
@@ -34,21 +37,25 @@ import org.sufficientlysecure.keychain.service.CertifyActionsParcel;
import org.sufficientlysecure.keychain.service.CertifyActionsParcel.CertifyAction;
import org.sufficientlysecure.keychain.service.KeychainIntentService;
import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler;
+import org.sufficientlysecure.keychain.service.PassphraseCacheService;
+import org.sufficientlysecure.keychain.ui.PassphraseDialogActivity;
import org.sufficientlysecure.keychain.ui.adapter.LinkedIdsAdapter.ViewHolder;
import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;
import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils.State;
import org.sufficientlysecure.keychain.ui.util.Notify;
import org.sufficientlysecure.keychain.ui.util.Notify.Style;
import org.sufficientlysecure.keychain.ui.widget.CertifyKeySpinner;
+import org.sufficientlysecure.keychain.util.Log;
import org.sufficientlysecure.keychain.util.Preferences;
public class LinkedIdViewFragment extends Fragment {
+ public static final int REQUEST_CODE_PASSPHRASE = 0x00008001;
+
private static final String ARG_ENCODED_LID = "encoded_lid";
private static final String ARG_VERIFIED = "verified";
private static final String ARG_FINGERPRINT = "fingerprint";
- private static final String ARG_MASTER_KEY_ID = "fingerprint";
private RawLinkedIdentity mLinkedId;
private LinkedCookieResource mLinkedResource;
@@ -195,7 +202,7 @@ public class LinkedIdViewFragment extends Fragment {
button_confirm.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
- certifyResource();
+ initiateCertifying();
}
});
@@ -291,15 +298,62 @@ public class LinkedIdViewFragment extends Fragment {
}
- private void certifyResource() {
+ private void initiateCertifying() {
+ // get the user's passphrase for this key (if required)
+ String passphrase;
+ long certifyKeyId = vKeySpinner.getSelectedItemId();
+ try {
+ passphrase = PassphraseCacheService.getCachedPassphrase(
+ getActivity(), certifyKeyId, certifyKeyId);
+ } catch (PassphraseCacheService.KeyNotFoundException e) {
+ Log.e(Constants.TAG, "Key not found!", e);
+ getActivity().finish();
+ return;
+ }
+ if (passphrase == null) {
+ Intent intent = new Intent(getActivity(), PassphraseDialogActivity.class);
+ intent.putExtra(PassphraseDialogActivity.EXTRA_SUBKEY_ID, certifyKeyId);
+ startActivityForResult(intent, REQUEST_CODE_PASSPHRASE);
+ // bail out; need to wait until the user has entered the passphrase before trying again
+ } else {
+ certifyResource(certifyKeyId, "");
+ }
+ }
+
+ @Override
+ public void onActivityResult(int requestCode, int resultCode, Intent data) {
+ switch (requestCode) {
+ case REQUEST_CODE_PASSPHRASE: {
+ if (resultCode == Activity.RESULT_OK && data != null) {
+ String passphrase = data.getStringExtra(
+ PassphraseDialogActivity.MESSAGE_DATA_PASSPHRASE);
+ long certifyKeyId = data.getLongExtra(PassphraseDialogActivity.EXTRA_KEY_ID, 0L);
+ if (certifyKeyId == 0L) {
+ throw new AssertionError("key id must not be 0");
+ }
+ certifyResource(certifyKeyId, passphrase);
+ }
+ return;
+ }
+
+ default: {
+ super.onActivityResult(requestCode, resultCode, data);
+ }
+ }
+ }
+
+ private void certifyResource(long certifyKeyId, String passphrase) {
Bundle data = new Bundle();
{
- CertifyAction action = new CertifyAction();
+
+ long masterKeyId = KeyFormattingUtils.convertFingerprintToKeyId(mFingerprint);
+ CertifyAction action = new CertifyAction(masterKeyId, null,
+ Arrays.asList(mLinkedId.toUserAttribute()));
// fill values for this action
- CertifyActionsParcel parcel = new CertifyActionsParcel(vKeySpinner.getSelectedKeyId());
- parcel.mCertifyActions.addAll(certifyActions);
+ CertifyActionsParcel parcel = new CertifyActionsParcel(certifyKeyId);
+ parcel.mCertifyActions.addAll(Arrays.asList(action));
data.putParcelable(KeychainIntentService.CERTIFY_PARCEL, parcel);
/* if (mUploadKeyCheckbox.isChecked()) {
@@ -315,7 +369,7 @@ public class LinkedIdViewFragment extends Fragment {
// Message is received after signing is done in KeychainIntentService
KeychainIntentServiceHandler saveHandler = new KeychainIntentServiceHandler(getActivity(),
- getString(R.string.progress_certifying), ProgressDialog.STYLE_SPINNER, true) {
+ getString(R.string.progress_certifying), ProgressDialog.STYLE_SPINNER, false) {
public void handleMessage(Message message) {
// handle messages by standard KeychainIntentServiceHandler first
super.handleMessage(message);
@@ -324,10 +378,7 @@ public class LinkedIdViewFragment extends Fragment {
Bundle data = message.getData();
CertifyResult result = data.getParcelable(CertifyResult.EXTRA_RESULT);
- Intent intent = new Intent();
- intent.putExtra(CertifyResult.EXTRA_RESULT, result);
- getActivity().setResult(Activity.RESULT_OK, intent);
- getActivity().finish();
+ result.createNotify(getActivity()).show();
}
}
};
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java
index b4890ac4e..364712a48 100644
--- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java
+++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/KeySpinner.java
@@ -269,6 +269,7 @@ public abstract class KeySpinner extends TintSpinner implements LoaderManager.Lo
}
return view;
}
+
}
boolean setStatus(Context context, Cursor cursor, ImageView statusView) {
diff --git a/OpenKeychain/src/main/res/layout/linked_id_view_fragment.xml b/OpenKeychain/src/main/res/layout/linked_id_view_fragment.xml
index f2580122a..ac48e8db3 100644
--- a/OpenKeychain/src/main/res/layout/linked_id_view_fragment.xml
+++ b/OpenKeychain/src/main/res/layout/linked_id_view_fragment.xml
@@ -36,6 +36,7 @@
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
+ android:animateLayoutChanges="true"
android:id="@+id/linked_id_certs">
</LinearLayout>