use loader in LinkedIdViewFragment
This commit is contained in:
@@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
@@ -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));
|
||||||
|
|||||||
@@ -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;
|
||||||
|
|||||||
@@ -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 {
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -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);
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
@@ -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"
|
||||||
|
|||||||
Reference in New Issue
Block a user