use loader in LinkedIdViewFragment

This commit is contained in:
Vincent Breitmoser
2015-03-09 16:30:13 +01:00
parent 99eb8725e9
commit 08fd2a2de3
9 changed files with 280 additions and 115 deletions

View File

@@ -266,6 +266,7 @@ public class KeychainContract {
public static Uri buildLinkedIdsUri(Uri uri) { public static Uri buildLinkedIdsUri(Uri uri) {
return CONTENT_URI.buildUpon().appendPath(uri.getPathSegments().get(1)).appendPath(PATH_LINKED_IDS).build(); return CONTENT_URI.buildUpon().appendPath(uri.getPathSegments().get(1)).appendPath(PATH_LINKED_IDS).build();
} }
} }
public static class ApiApps implements ApiAppsColumns, BaseColumns { public static class ApiApps implements ApiAppsColumns, BaseColumns {
@@ -354,7 +355,14 @@ public class KeychainContract {
} }
public static Uri buildCertsUri(Uri uri) { public static Uri buildCertsUri(Uri uri) {
return CONTENT_URI.buildUpon().appendPath(uri.getPathSegments().get(1)).appendPath(PATH_CERTS).build(); return CONTENT_URI.buildUpon().appendPath(uri.getPathSegments().get(1))
.appendPath(PATH_CERTS).build();
}
public static Uri buildLinkedIdCertsUri(long masterKeyId, int rank) {
return CONTENT_URI.buildUpon().appendPath(Long.toString(masterKeyId))
.appendPath(PATH_LINKED_IDS).appendPath(Integer.toString(rank))
.appendPath(PATH_CERTS).build();
} }
} }

View File

@@ -63,6 +63,7 @@ public class KeychainProvider extends ContentProvider {
private static final int KEY_RING_CERTS = 205; private static final int KEY_RING_CERTS = 205;
private static final int KEY_RING_CERTS_SPECIFIC = 206; private static final int KEY_RING_CERTS_SPECIFIC = 206;
private static final int KEY_RING_LINKED_IDS = 207; private static final int KEY_RING_LINKED_IDS = 207;
private static final int KEY_RING_LINKED_ID_CERTS = 208;
private static final int API_APPS = 301; private static final int API_APPS = 301;
private static final int API_APPS_BY_PACKAGE_NAME = 302; private static final int API_APPS_BY_PACKAGE_NAME = 302;
@@ -129,6 +130,8 @@ public class KeychainProvider extends ContentProvider {
* key_rings/_/keys * key_rings/_/keys
* key_rings/_/user_ids * key_rings/_/user_ids
* key_rings/_/linked_ids * key_rings/_/linked_ids
* key_rings/_/linked_ids/_
* key_rings/_/linked_ids/_/certs
* key_rings/_/public * key_rings/_/public
* key_rings/_/secret * key_rings/_/secret
* key_rings/_/certs * key_rings/_/certs
@@ -147,6 +150,10 @@ public class KeychainProvider extends ContentProvider {
matcher.addURI(authority, KeychainContract.BASE_KEY_RINGS + "/*/" matcher.addURI(authority, KeychainContract.BASE_KEY_RINGS + "/*/"
+ KeychainContract.PATH_LINKED_IDS, + KeychainContract.PATH_LINKED_IDS,
KEY_RING_LINKED_IDS); KEY_RING_LINKED_IDS);
matcher.addURI(authority, KeychainContract.BASE_KEY_RINGS + "/*/"
+ KeychainContract.PATH_LINKED_IDS + "/*/"
+ KeychainContract.PATH_CERTS,
KEY_RING_LINKED_ID_CERTS);
matcher.addURI(authority, KeychainContract.BASE_KEY_RINGS + "/*/" matcher.addURI(authority, KeychainContract.BASE_KEY_RINGS + "/*/"
+ KeychainContract.PATH_PUBLIC, + KeychainContract.PATH_PUBLIC,
KEY_RING_PUBLIC); KEY_RING_PUBLIC);

View File

@@ -839,7 +839,9 @@ public class ViewKeyActivity extends BaseActivity implements
mIsExpired = data.getInt(INDEX_IS_EXPIRED) != 0; mIsExpired = data.getInt(INDEX_IS_EXPIRED) != 0;
mIsVerified = data.getInt(INDEX_VERIFIED) > 0; mIsVerified = data.getInt(INDEX_VERIFIED) > 0;
startFragment(mIsSecret, fpData); if (oldFingerprint == null) {
startFragment(mIsSecret, fpData);
}
// get name, email, and comment from USER_ID // get name, email, and comment from USER_ID
String[] mainUserId = KeyRing.splitUserId(data.getString(INDEX_USER_ID)); String[] mainUserId = KeyRing.splitUserId(data.getString(INDEX_USER_ID));

View File

@@ -131,7 +131,7 @@ public class ViewKeyFragment extends LoaderFragment implements
private void showLinkedId(final int position) { private void showLinkedId(final int position) {
Fragment frag; Fragment frag;
try { try {
frag = mLinkedIdsAdapter.getLinkedIdFragment(position, mFingerprint); frag = mLinkedIdsAdapter.getLinkedIdFragment(mDataUri, position, mFingerprint);
} catch (IOException e) { } catch (IOException e) {
e.printStackTrace(); e.printStackTrace();
return; return;

View File

@@ -35,6 +35,7 @@ import org.sufficientlysecure.keychain.Constants;
import org.sufficientlysecure.keychain.R; import org.sufficientlysecure.keychain.R;
import org.sufficientlysecure.keychain.pgp.linked.LinkedIdentity; import org.sufficientlysecure.keychain.pgp.linked.LinkedIdentity;
import org.sufficientlysecure.keychain.pgp.linked.RawLinkedIdentity; import org.sufficientlysecure.keychain.pgp.linked.RawLinkedIdentity;
import org.sufficientlysecure.keychain.provider.KeychainContract;
import org.sufficientlysecure.keychain.provider.KeychainContract.Certs; import org.sufficientlysecure.keychain.provider.KeychainContract.Certs;
import org.sufficientlysecure.keychain.provider.KeychainContract.UserPackets; import org.sufficientlysecure.keychain.provider.KeychainContract.UserPackets;
import org.sufficientlysecure.keychain.ui.linked.LinkedIdViewFragment; import org.sufficientlysecure.keychain.ui.linked.LinkedIdViewFragment;
@@ -125,19 +126,15 @@ public class LinkedIdsAdapter extends UserAttributesAdapter {
UserIdsAdapter.USER_PACKETS_PROJECTION, LINKED_IDS_WHERE, null, null); UserIdsAdapter.USER_PACKETS_PROJECTION, LINKED_IDS_WHERE, null, null);
} }
public Fragment getLinkedIdFragment(int position, byte[] fingerprint) throws IOException { public Fragment getLinkedIdFragment(Uri baseUri,
RawLinkedIdentity id = getItem(position); int position, byte[] fingerprint) throws IOException {
Integer isVerified; Cursor c = getCursor();
if (mShowCertification) { c.moveToPosition(position);
Cursor cursor = getCursor(); int rank = c.getInt(UserIdsAdapter.INDEX_RANK);
cursor.moveToPosition(position);
isVerified = cursor.getInt(INDEX_VERIFIED);
} else {
isVerified = null;
}
return LinkedIdViewFragment.newInstance(id, isVerified, fingerprint); Uri dataUri = UserPackets.buildLinkedIdsUri(baseUri);
return LinkedIdViewFragment.newInstance(dataUri, rank, mShowCertification, fingerprint);
} }
public static class ViewHolder { public static class ViewHolder {

View File

@@ -0,0 +1,57 @@
package org.sufficientlysecure.keychain.ui.adapter;
import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.net.Uri;
import android.support.v4.content.CursorLoader;
import android.view.View;
import android.view.ViewGroup;
import android.widget.CursorAdapter;
import org.sufficientlysecure.keychain.provider.KeychainContract.UserPackets;
public class LinkedIdsCertAdapter extends CursorAdapter {
public static final String[] USER_CERTS_PROJECTION = new String[]{
UserPackets._ID,
UserPackets.TYPE,
UserPackets.USER_ID,
UserPackets.ATTRIBUTE_DATA,
UserPackets.RANK,
UserPackets.VERIFIED,
UserPackets.IS_PRIMARY,
UserPackets.IS_REVOKED
};
protected static final int INDEX_ID = 0;
protected static final int INDEX_TYPE = 1;
protected static final int INDEX_USER_ID = 2;
protected static final int INDEX_ATTRIBUTE_DATA = 3;
protected static final int INDEX_RANK = 4;
protected static final int INDEX_VERIFIED = 5;
protected static final int INDEX_IS_PRIMARY = 6;
protected static final int INDEX_IS_REVOKED = 7;
public LinkedIdsCertAdapter(Context context, Cursor c, int flags) {
super(context, c, flags);
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return null;
}
public static CursorLoader createLoader(Activity activity, Uri dataUri) {
Uri baseUri = UserPackets.buildLinkedIdsUri(dataUri);
return new CursorLoader(activity, baseUri,
UserIdsAdapter.USER_PACKETS_PROJECTION, null, null, null);
}
}

View File

@@ -18,14 +18,14 @@ public abstract class UserAttributesAdapter extends CursorAdapter {
UserPackets.IS_PRIMARY, UserPackets.IS_PRIMARY,
UserPackets.IS_REVOKED UserPackets.IS_REVOKED
}; };
protected static final int INDEX_ID = 0; public static final int INDEX_ID = 0;
protected static final int INDEX_TYPE = 1; public static final int INDEX_TYPE = 1;
protected static final int INDEX_USER_ID = 2; public static final int INDEX_USER_ID = 2;
protected static final int INDEX_ATTRIBUTE_DATA = 3; public static final int INDEX_ATTRIBUTE_DATA = 3;
protected static final int INDEX_RANK = 4; public static final int INDEX_RANK = 4;
protected static final int INDEX_VERIFIED = 5; public static final int INDEX_VERIFIED = 5;
protected static final int INDEX_IS_PRIMARY = 6; public static final int INDEX_IS_PRIMARY = 6;
protected static final int INDEX_IS_REVOKED = 7; public static final int INDEX_IS_REVOKED = 7;
public UserAttributesAdapter(Context context, Cursor c, int flags) { public UserAttributesAdapter(Context context, Cursor c, int flags) {
super(context, c, flags); super(context, c, flags);

View File

@@ -7,12 +7,16 @@ import android.app.Activity;
import android.app.ProgressDialog; import android.app.ProgressDialog;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.os.Bundle; import android.os.Bundle;
import android.os.Message; import android.os.Message;
import android.os.Messenger; import android.os.Messenger;
import android.support.v4.app.Fragment; import android.support.v4.app.Fragment;
import android.support.v7.widget.CardView; import android.support.v4.app.LoaderManager;
import android.support.v4.content.CursorLoader;
import android.support.v4.content.Loader;
import android.view.LayoutInflater; import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.View.OnClickListener; import android.view.View.OnClickListener;
@@ -22,93 +26,68 @@ import android.widget.LinearLayout;
import android.widget.TextView; import android.widget.TextView;
import android.widget.ViewAnimator; import android.widget.ViewAnimator;
import org.spongycastle.util.encoders.Hex;
import org.sufficientlysecure.keychain.Constants; import org.sufficientlysecure.keychain.Constants;
import org.sufficientlysecure.keychain.R; import org.sufficientlysecure.keychain.R;
import org.sufficientlysecure.keychain.operations.results.CertifyResult; import org.sufficientlysecure.keychain.operations.results.CertifyResult;
import org.sufficientlysecure.keychain.operations.results.LinkedVerifyResult; 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.LinkedCookieResource;
import org.sufficientlysecure.keychain.pgp.linked.LinkedIdentity; import org.sufficientlysecure.keychain.pgp.linked.LinkedIdentity;
import org.sufficientlysecure.keychain.pgp.linked.LinkedResource; import org.sufficientlysecure.keychain.pgp.linked.LinkedResource;
import org.sufficientlysecure.keychain.pgp.linked.RawLinkedIdentity; import org.sufficientlysecure.keychain.pgp.linked.RawLinkedIdentity;
import org.sufficientlysecure.keychain.provider.KeychainContract.Certs; import org.sufficientlysecure.keychain.provider.KeychainContract.Certs;
import org.sufficientlysecure.keychain.provider.KeychainContract.UserPackets;
import org.sufficientlysecure.keychain.provider.KeychainDatabase.Tables;
import org.sufficientlysecure.keychain.service.CertifyActionsParcel; import org.sufficientlysecure.keychain.service.CertifyActionsParcel;
import org.sufficientlysecure.keychain.service.CertifyActionsParcel.CertifyAction; import org.sufficientlysecure.keychain.service.CertifyActionsParcel.CertifyAction;
import org.sufficientlysecure.keychain.service.KeychainIntentService; import org.sufficientlysecure.keychain.service.KeychainIntentService;
import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler;
import org.sufficientlysecure.keychain.service.PassphraseCacheService; import org.sufficientlysecure.keychain.service.PassphraseCacheService;
import org.sufficientlysecure.keychain.ui.PassphraseDialogActivity; import org.sufficientlysecure.keychain.ui.PassphraseDialogActivity;
import org.sufficientlysecure.keychain.ui.adapter.LinkedIdsAdapter.ViewHolder; import org.sufficientlysecure.keychain.ui.adapter.LinkedIdsAdapter;
import org.sufficientlysecure.keychain.ui.adapter.LinkedIdsCertAdapter;
import org.sufficientlysecure.keychain.ui.adapter.UserIdsAdapter;
import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils; import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;
import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils.State; 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.ui.widget.CertifyKeySpinner;
import org.sufficientlysecure.keychain.util.Log; import org.sufficientlysecure.keychain.util.Log;
import org.sufficientlysecure.keychain.util.Preferences;
public class LinkedIdViewFragment extends Fragment { public class LinkedIdViewFragment extends Fragment implements
LoaderManager.LoaderCallbacks<Cursor> {
public static final int REQUEST_CODE_PASSPHRASE = 0x00008001; public static final int REQUEST_CODE_PASSPHRASE = 0x00008001;
private static final String ARG_ENCODED_LID = "encoded_lid"; private static final String ARG_DATA_URI = "data_uri";
private static final String ARG_VERIFIED = "verified"; private static final String ARG_LID_RANK = "rank";
private static final String ARG_SHOWCERT = "verified";
private static final String ARG_FINGERPRINT = "fingerprint"; private static final String ARG_FINGERPRINT = "fingerprint";
private static final int LOADER_ID_LINKED_CERTS = 1;
private static final int LOADER_ID_LINKED_ID = 2;
private RawLinkedIdentity mLinkedId; private RawLinkedIdentity mLinkedId;
private LinkedCookieResource mLinkedResource; private LinkedCookieResource mLinkedResource;
private Integer mVerified; private boolean mShowCert;
private CardView vLinkedIdsCard;
private Context mContext; private Context mContext;
private byte[] mFingerprint; private byte[] mFingerprint;
private LayoutInflater mInflater; private LayoutInflater mInflater;
private LinearLayout vLinkedCerts;
private View mCurrentCert;
private boolean mInProgress; private boolean mInProgress;
private ViewAnimator mButtonSwitcher;
private CertifyKeySpinner vKeySpinner;
@Override private LinkedIdsCertAdapter mCertAdapter;
public void onCreate(Bundle savedInstanceState) { private Uri mDataUri;
super.onCreate(savedInstanceState); private ViewHolder mViewHolder;
private View mCurrentCert;
private int mLidRank;
Bundle args = getArguments(); public static Fragment newInstance(Uri dataUri, int rank,
byte[] data = args.getByteArray(ARG_ENCODED_LID); boolean showCertified, byte[] fingerprint) throws IOException {
try {
mLinkedId = LinkedIdentity.fromAttributeData(data);
} catch (IOException e) {
// TODO um…
e.printStackTrace();
throw new AssertionError("reconstruction of user attribute must succeed!");
}
if (mLinkedId instanceof LinkedIdentity) {
LinkedResource res = ((LinkedIdentity) mLinkedId).mResource;
mLinkedResource = (LinkedCookieResource) res;
}
mVerified = args.containsKey(ARG_VERIFIED) ? args.getInt(ARG_VERIFIED) : null;
mFingerprint = args.getByteArray(ARG_FINGERPRINT);
mContext = getActivity();
mInflater = getLayoutInflater(savedInstanceState);
}
public static Fragment newInstance(RawLinkedIdentity id,
Integer isVerified, byte[] fingerprint) throws IOException {
LinkedIdViewFragment frag = new LinkedIdViewFragment(); LinkedIdViewFragment frag = new LinkedIdViewFragment();
Bundle args = new Bundle(); Bundle args = new Bundle();
args.putByteArray(ARG_ENCODED_LID, id.toUserAttribute().getEncoded()); args.putParcelable(ARG_DATA_URI, dataUri);
if (isVerified != null) { args.putInt(ARG_LID_RANK, rank);
args.putInt(ARG_VERIFIED, isVerified); args.putBoolean(ARG_SHOWCERT, showCertified);
}
args.putByteArray(ARG_FINGERPRINT, fingerprint); args.putByteArray(ARG_FINGERPRINT, fingerprint);
frag.setArguments(args); frag.setArguments(args);
@@ -116,57 +95,114 @@ public class LinkedIdViewFragment extends Fragment {
} }
@Override @Override
public View onCreateView(LayoutInflater inflater, ViewGroup superContainer, Bundle savedInstanceState) { public void onCreate(Bundle savedInstanceState) {
View root = inflater.inflate(R.layout.linked_id_view_fragment, null); super.onCreate(savedInstanceState);
vLinkedIdsCard = (CardView) root.findViewById(R.id.card_linked_ids); Bundle args = getArguments();
vLinkedCerts = (LinearLayout) root.findViewById(R.id.linked_id_certs); mDataUri = args.getParcelable(ARG_DATA_URI);
vKeySpinner = (CertifyKeySpinner) root.findViewById(R.id.cert_key_spinner); mLidRank = args.getInt(ARG_LID_RANK);
View back = root.findViewById(R.id.back_button); mShowCert = args.getBoolean(ARG_SHOWCERT);
back.setClickable(true); mFingerprint = args.getByteArray(ARG_FINGERPRINT);
back.findViewById(R.id.back_button).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
getFragmentManager().popBackStack();
}
});
ViewHolder holder = new ViewHolder(root); mContext = getActivity();
mInflater = getLayoutInflater(savedInstanceState);
if (mVerified != null) { mCertAdapter = new LinkedIdsCertAdapter(getActivity(), null, 0);
holder.vVerified.setVisibility(View.VISIBLE); // getLoaderManager().initLoader(LOADER_ID_LINKED_CERTS, null, this);
switch (mVerified) { getLoaderManager().initLoader(LOADER_ID_LINKED_ID, null, this);
}
@Override
public Loader<Cursor> onCreateLoader(int id, Bundle args) {
switch (id) {
case LOADER_ID_LINKED_ID:
return new CursorLoader(getActivity(), mDataUri,
UserIdsAdapter.USER_PACKETS_PROJECTION,
Tables.USER_PACKETS + "." + UserPackets.RANK
+ " = " + Integer.toString(mLidRank), null, null);
case LOADER_ID_LINKED_CERTS:
return LinkedIdsCertAdapter.createLoader(getActivity(), mDataUri);
default:
return null;
}
}
@Override
public void onLoadFinished(Loader<Cursor> loader, Cursor cursor) {
switch (loader.getId()) {
case LOADER_ID_LINKED_ID:
// TODO proper error reporting and null checks here!
if (!cursor.moveToFirst()) {
Log.e(Constants.TAG, "error");
break;
}
try {
int certStatus = cursor.getInt(UserIdsAdapter.INDEX_VERIFIED);
byte[] data = cursor.getBlob(UserIdsAdapter.INDEX_ATTRIBUTE_DATA);
RawLinkedIdentity linkedId = LinkedIdentity.fromAttributeData(data);
loadIdentity(linkedId, certStatus);
} catch (IOException e) {
e.printStackTrace();
throw new AssertionError("reconstruction of user attribute must succeed!");
}
break;
case LOADER_ID_LINKED_CERTS:
mCertAdapter.swapCursor(cursor);
break;
}
}
private void loadIdentity(RawLinkedIdentity linkedId, int certStatus) {
mLinkedId = linkedId;
if (mLinkedId instanceof LinkedIdentity) {
LinkedResource res = ((LinkedIdentity) mLinkedId).mResource;
mLinkedResource = (LinkedCookieResource) res;
}
if (mShowCert) {
mViewHolder.mLinkedIdHolder.vVerified.setVisibility(View.VISIBLE);
switch (certStatus) {
case Certs.VERIFIED_SECRET: case Certs.VERIFIED_SECRET:
KeyFormattingUtils.setStatusImage(mContext, holder.vVerified, KeyFormattingUtils.setStatusImage(mContext, mViewHolder.mLinkedIdHolder.vVerified,
null, State.VERIFIED, KeyFormattingUtils.DEFAULT_COLOR); null, State.VERIFIED, KeyFormattingUtils.DEFAULT_COLOR);
break; break;
case Certs.VERIFIED_SELF: case Certs.VERIFIED_SELF:
KeyFormattingUtils.setStatusImage(mContext, holder.vVerified, KeyFormattingUtils.setStatusImage(mContext, mViewHolder.mLinkedIdHolder.vVerified,
null, State.UNVERIFIED, KeyFormattingUtils.DEFAULT_COLOR); null, State.UNVERIFIED, KeyFormattingUtils.DEFAULT_COLOR);
break; break;
default: default:
KeyFormattingUtils.setStatusImage(mContext, holder.vVerified, KeyFormattingUtils.setStatusImage(mContext, mViewHolder.mLinkedIdHolder.vVerified,
null, State.INVALID, KeyFormattingUtils.DEFAULT_COLOR); null, State.INVALID, KeyFormattingUtils.DEFAULT_COLOR);
break; break;
} }
} else { } else {
holder.vVerified.setVisibility(View.GONE); mViewHolder.mLinkedIdHolder.vVerified.setVisibility(View.GONE);
} }
holder.setData(mContext, mLinkedId); mViewHolder.mLinkedIdHolder.setData(mContext, mLinkedId);
// no resource, nothing further we can do… // no resource, nothing further we can do…
if (mLinkedResource == null) { if (mLinkedResource == null) {
root.findViewById(R.id.button_view).setVisibility(View.GONE); mViewHolder.vButtonView.setVisibility(View.GONE);
root.findViewById(R.id.button_verify).setVisibility(View.GONE); mViewHolder.vButtonVerify.setVisibility(View.GONE);
return root; return;
} }
View button_view = root.findViewById(R.id.button_view);
if (mLinkedResource.isViewable()) { if (mLinkedResource.isViewable()) {
button_view.setVisibility(View.VISIBLE); mViewHolder.vButtonView.setVisibility(View.VISIBLE);
button_view.setOnClickListener(new OnClickListener() { mViewHolder.vButtonView.setOnClickListener(new OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
Intent intent = mLinkedResource.getViewIntent(); Intent intent = mLinkedResource.getViewIntent();
@@ -177,29 +213,79 @@ public class LinkedIdViewFragment extends Fragment {
} }
}); });
} else { } else {
button_view.setVisibility(View.GONE); mViewHolder.vButtonView.setVisibility(View.GONE);
} }
mButtonSwitcher = (ViewAnimator) root.findViewById(R.id.button_animator); }
View button_verify = root.findViewById(R.id.button_verify); @Override
button_verify.setOnClickListener(new OnClickListener() { public void onLoaderReset(Loader<Cursor> loader) {
switch (loader.getId()) {
case LOADER_ID_LINKED_CERTS:
mCertAdapter.swapCursor(null);
break;
}
}
static class ViewHolder {
private final View vButtonView;
LinkedIdsAdapter.ViewHolder mLinkedIdHolder;
private ViewAnimator mButtonSwitcher;
private LinearLayout vLinkedCerts;
private CertifyKeySpinner vKeySpinner;
private LinearLayout vLinkedVerify;
private final View vButtonVerify;
private final View vButtonRetry;
private final View vButtonConfirm;
private final View vButtonBack;
ViewHolder(View root) {
vLinkedCerts = (LinearLayout) root.findViewById(R.id.linked_id_certs);
vLinkedVerify = (LinearLayout) root.findViewById(R.id.linked_id_verify);
vKeySpinner = (CertifyKeySpinner) root.findViewById(R.id.cert_key_spinner);
mButtonSwitcher = (ViewAnimator) root.findViewById(R.id.button_animator);
mLinkedIdHolder = new LinkedIdsAdapter.ViewHolder(root);
vButtonBack = root.findViewById(R.id.back_button);
vButtonVerify = root.findViewById(R.id.button_verify);
vButtonRetry = root.findViewById(R.id.button_retry);
vButtonConfirm = root.findViewById(R.id.button_confirm);
vButtonView = root.findViewById(R.id.button_view);
}
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup superContainer, Bundle savedInstanceState) {
View root = inflater.inflate(R.layout.linked_id_view_fragment, null);
mViewHolder = new ViewHolder(root);
root.setTag(mViewHolder);
mViewHolder.vButtonBack.setClickable(true);
mViewHolder.vButtonBack.findViewById(R.id.back_button).setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
getFragmentManager().popBackStack();
}
});
mViewHolder.vButtonVerify.setOnClickListener(new OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
verifyResource(); verifyResource();
} }
}); });
mViewHolder.vButtonRetry.setOnClickListener(new OnClickListener() {
View button_retry = root.findViewById(R.id.button_retry);
button_retry.setOnClickListener(new OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
verifyResource(); verifyResource();
} }
}); });
mViewHolder.vButtonConfirm.setOnClickListener(new OnClickListener() {
View button_confirm = root.findViewById(R.id.button_confirm);
button_confirm.setOnClickListener(new OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
initiateCertifying(); initiateCertifying();
@@ -225,10 +311,10 @@ public class LinkedIdViewFragment extends Fragment {
} }
void showButton(int which) { void showButton(int which) {
if (mButtonSwitcher.getDisplayedChild() == which) { if (mViewHolder.mButtonSwitcher.getDisplayedChild() == which) {
return; return;
} }
mButtonSwitcher.setDisplayedChild(which); mViewHolder.mButtonSwitcher.setDisplayedChild(which);
} }
void verifyResource() { void verifyResource() {
@@ -247,12 +333,12 @@ public class LinkedIdViewFragment extends Fragment {
mCurrentCert = mInflater.inflate(R.layout.linked_id_cert, null); mCurrentCert = mInflater.inflate(R.layout.linked_id_cert, null);
holder = new ViewHolderCert(mCurrentCert); holder = new ViewHolderCert(mCurrentCert);
mCurrentCert.setTag(holder); mCurrentCert.setTag(holder);
vLinkedCerts.addView(mCurrentCert); mViewHolder.vLinkedVerify.addView(mCurrentCert);
} else { } else {
holder = (ViewHolderCert) mCurrentCert.getTag(); holder = (ViewHolderCert) mCurrentCert.getTag();
} }
vKeySpinner.setVisibility(View.GONE); mViewHolder.vKeySpinner.setVisibility(View.GONE);
holder.setShowProgress(true); holder.setShowProgress(true);
holder.vText.setText("Verifying…"); holder.vText.setText("Verifying…");
@@ -294,14 +380,14 @@ public class LinkedIdViewFragment extends Fragment {
// button is 'confirm' // button is 'confirm'
showButton(2); showButton(2);
vKeySpinner.setVisibility(View.VISIBLE); mViewHolder.vKeySpinner.setVisibility(View.VISIBLE);
} }
private void initiateCertifying() { private void initiateCertifying() {
// get the user's passphrase for this key (if required) // get the user's passphrase for this key (if required)
String passphrase; String passphrase;
long certifyKeyId = vKeySpinner.getSelectedItemId(); long certifyKeyId = mViewHolder.vKeySpinner.getSelectedItemId();
try { try {
passphrase = PassphraseCacheService.getCachedPassphrase( passphrase = PassphraseCacheService.getCachedPassphrase(
getActivity(), certifyKeyId, certifyKeyId); getActivity(), certifyKeyId, certifyKeyId);

View File

@@ -40,6 +40,14 @@
android:id="@+id/linked_id_certs"> android:id="@+id/linked_id_certs">
</LinearLayout> </LinearLayout>
<LinearLayout
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="vertical"
android:animateLayoutChanges="true"
android:id="@+id/linked_id_verify">
</LinearLayout>
<org.sufficientlysecure.keychain.ui.widget.CertifyKeySpinner <org.sufficientlysecure.keychain.ui.widget.CertifyKeySpinner
android:layout_marginLeft="14dp" android:layout_marginLeft="14dp"
android:layout_marginRight="14dp" android:layout_marginRight="14dp"