mirror of
https://github.com/moparisthebest/open-keychain
synced 2025-01-11 21:48:17 -05:00
Merge branch 'master' of github.com:open-keychain/open-keychain
This commit is contained in:
commit
da66d1443f
@ -22,6 +22,8 @@ import android.content.Intent;
|
|||||||
import android.content.pm.ApplicationInfo;
|
import android.content.pm.ApplicationInfo;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
|
import android.database.MatrixCursor;
|
||||||
|
import android.database.MergeCursor;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v4.app.ListFragment;
|
import android.support.v4.app.ListFragment;
|
||||||
@ -98,9 +100,18 @@ public class AppsListFragment extends ListFragment implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void onLoadFinished(Loader<Cursor> loader, Cursor data) {
|
public void onLoadFinished(Loader<Cursor> loader, Cursor data) {
|
||||||
|
MatrixCursor matrixCursor = new MatrixCursor(
|
||||||
|
new String[]{ApiApps._ID, ApiApps.PACKAGE_NAME, ApiApps.PACKAGE_SIGNATURE}
|
||||||
|
);
|
||||||
|
matrixCursor.addRow(new Object[]{200, "com.fsck.k9", new byte[]{}});
|
||||||
|
|
||||||
|
MergeCursor mergeCursor = new MergeCursor(
|
||||||
|
new Cursor[]{matrixCursor, data}
|
||||||
|
);
|
||||||
|
|
||||||
// Swap the new cursor in. (The framework will take care of closing the
|
// Swap the new cursor in. (The framework will take care of closing the
|
||||||
// old cursor once we return.)
|
// old cursor once we return.)
|
||||||
mAdapter.swapCursor(data);
|
mAdapter.swapCursor(mergeCursor);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void onLoaderReset(Loader<Cursor> loader) {
|
public void onLoaderReset(Loader<Cursor> loader) {
|
||||||
|
@ -16,13 +16,14 @@ import android.nfc.tech.IsoDep;
|
|||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.support.v7.app.ActionBarActivity;
|
import android.support.v7.app.ActionBarActivity;
|
||||||
import android.util.Log;
|
|
||||||
import android.view.WindowManager;
|
import android.view.WindowManager;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import org.spongycastle.bcpg.HashAlgorithmTags;
|
import org.spongycastle.bcpg.HashAlgorithmTags;
|
||||||
import org.spongycastle.util.encoders.Hex;
|
import org.spongycastle.util.encoders.Hex;
|
||||||
|
import org.sufficientlysecure.keychain.Constants;
|
||||||
import org.sufficientlysecure.keychain.R;
|
import org.sufficientlysecure.keychain.R;
|
||||||
|
import org.sufficientlysecure.keychain.util.Log;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
@ -35,7 +36,6 @@ import java.util.Locale;
|
|||||||
*/
|
*/
|
||||||
@TargetApi(Build.VERSION_CODES.GINGERBREAD_MR1)
|
@TargetApi(Build.VERSION_CODES.GINGERBREAD_MR1)
|
||||||
public class NfcActivity extends ActionBarActivity {
|
public class NfcActivity extends ActionBarActivity {
|
||||||
private static final String TAG = "Keychain";
|
|
||||||
|
|
||||||
// actions
|
// actions
|
||||||
public static final String ACTION_SIGN_HASH = "sign_hash";
|
public static final String ACTION_SIGN_HASH = "sign_hash";
|
||||||
@ -73,7 +73,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
Log.d(TAG, "NfcActivity.onCreate");
|
Log.d(Constants.TAG, "NfcActivity.onCreate");
|
||||||
|
|
||||||
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
|
getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
|
||||||
|
|
||||||
@ -90,27 +90,27 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
mHashAlgo = data.getInt(EXTRA_NFC_HASH_ALGO);
|
mHashAlgo = data.getInt(EXTRA_NFC_HASH_ALGO);
|
||||||
mServiceIntent = data.getParcelable(EXTRA_DATA);
|
mServiceIntent = data.getParcelable(EXTRA_DATA);
|
||||||
|
|
||||||
Log.d(TAG, "NfcActivity mAction: " + mAction);
|
Log.d(Constants.TAG, "NfcActivity mAction: " + mAction);
|
||||||
Log.d(TAG, "NfcActivity mPin: " + mPin);
|
Log.d(Constants.TAG, "NfcActivity mPin: " + mPin);
|
||||||
Log.d(TAG, "NfcActivity mHashToSign as hex: " + getHex(mHashToSign));
|
Log.d(Constants.TAG, "NfcActivity mHashToSign as hex: " + getHex(mHashToSign));
|
||||||
Log.d(TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString());
|
Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString());
|
||||||
} else if (ACTION_DECRYPT_SESSION_KEY.equals(action)) {
|
} else if (ACTION_DECRYPT_SESSION_KEY.equals(action)) {
|
||||||
mAction = action;
|
mAction = action;
|
||||||
mPin = data.getString(EXTRA_PIN);
|
mPin = data.getString(EXTRA_PIN);
|
||||||
mEncryptedSessionKey = data.getByteArray(EXTRA_NFC_ENC_SESSION_KEY);
|
mEncryptedSessionKey = data.getByteArray(EXTRA_NFC_ENC_SESSION_KEY);
|
||||||
mServiceIntent = data.getParcelable(EXTRA_DATA);
|
mServiceIntent = data.getParcelable(EXTRA_DATA);
|
||||||
|
|
||||||
Log.d(TAG, "NfcActivity mAction: " + mAction);
|
Log.d(Constants.TAG, "NfcActivity mAction: " + mAction);
|
||||||
Log.d(TAG, "NfcActivity mPin: " + mPin);
|
Log.d(Constants.TAG, "NfcActivity mPin: " + mPin);
|
||||||
Log.d(TAG, "NfcActivity mEncryptedSessionKey as hex: " + getHex(mEncryptedSessionKey));
|
Log.d(Constants.TAG, "NfcActivity mEncryptedSessionKey as hex: " + getHex(mEncryptedSessionKey));
|
||||||
Log.d(TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString());
|
Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString());
|
||||||
} else if (NfcAdapter.ACTION_TAG_DISCOVERED.equals(action)) {
|
} else if (NfcAdapter.ACTION_TAG_DISCOVERED.equals(action)) {
|
||||||
Log.e(TAG, "This should not happen, but there is a bug in Android!");
|
Log.e(Constants.TAG, "This should not happen, but there is a bug in Android!");
|
||||||
|
|
||||||
toast("This should not happen, but there is a bug in Android! Clear all app tasks and start app from launcher again!");
|
toast("This should not happen, but there is a bug in Android! Clear all app tasks and start app from launcher again!");
|
||||||
finish();
|
finish();
|
||||||
} else {
|
} else {
|
||||||
Log.d(TAG, "Action not supported: " + action);
|
Log.d(Constants.TAG, "Action not supported: " + action);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -120,7 +120,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
*/
|
*/
|
||||||
public void onPause() {
|
public void onPause() {
|
||||||
super.onPause();
|
super.onPause();
|
||||||
Log.d(TAG, "NfcActivity.onPause");
|
Log.d(Constants.TAG, "NfcActivity.onPause");
|
||||||
|
|
||||||
disableNfcForegroundDispatch();
|
disableNfcForegroundDispatch();
|
||||||
}
|
}
|
||||||
@ -131,7 +131,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
*/
|
*/
|
||||||
public void onResume() {
|
public void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
Log.d(TAG, "NfcActivity.onResume");
|
Log.d(Constants.TAG, "NfcActivity.onResume");
|
||||||
|
|
||||||
enableNfcForegroundDispatch();
|
enableNfcForegroundDispatch();
|
||||||
}
|
}
|
||||||
@ -145,7 +145,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
try {
|
try {
|
||||||
handleNdefDiscoveredIntent(intent);
|
handleNdefDiscoveredIntent(intent);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.e(TAG, "Connection error!", e);
|
Log.e(Constants.TAG, "Connection error!", e);
|
||||||
toast("Connection Error: " + e.getMessage());
|
toast("Connection Error: " + e.getMessage());
|
||||||
setResult(RESULT_CANCELED, mServiceIntent);
|
setResult(RESULT_CANCELED, mServiceIntent);
|
||||||
finish();
|
finish();
|
||||||
@ -221,7 +221,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Log.d(TAG, "NfcActivity signedHash as hex: " + getHex(signedHash));
|
Log.d(Constants.TAG, "NfcActivity signedHash as hex: " + getHex(signedHash));
|
||||||
|
|
||||||
// give data through for new service call
|
// give data through for new service call
|
||||||
// OpenPgpApi.EXTRA_NFC_SIGNED_HASH
|
// OpenPgpApi.EXTRA_NFC_SIGNED_HASH
|
||||||
@ -260,7 +260,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
*/
|
*/
|
||||||
public long getKeyId() throws IOException {
|
public long getKeyId() throws IOException {
|
||||||
String keyId = getFingerprint().substring(24);
|
String keyId = getFingerprint().substring(24);
|
||||||
Log.d(TAG, "keyId: " + keyId);
|
Log.d(Constants.TAG, "keyId: " + keyId);
|
||||||
return Long.parseLong(keyId, 16);
|
return Long.parseLong(keyId, 16);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -276,7 +276,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
fingerprint = fingerprint.toLowerCase(Locale.ENGLISH); // better enforce lower case
|
fingerprint = fingerprint.toLowerCase(Locale.ENGLISH); // better enforce lower case
|
||||||
fingerprint = fingerprint.substring(fingerprint.indexOf("c5") + 4, fingerprint.indexOf("c5") + 44);
|
fingerprint = fingerprint.substring(fingerprint.indexOf("c5") + 4, fingerprint.indexOf("c5") + 44);
|
||||||
|
|
||||||
Log.d(TAG, "fingerprint: " + fingerprint);
|
Log.d(Constants.TAG, "fingerprint: " + fingerprint);
|
||||||
|
|
||||||
return fingerprint;
|
return fingerprint;
|
||||||
}
|
}
|
||||||
@ -293,7 +293,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
// dsi, including Lc
|
// dsi, including Lc
|
||||||
String dsi;
|
String dsi;
|
||||||
|
|
||||||
Log.i(TAG, "Hash: " + hashAlgo);
|
Log.i(Constants.TAG, "Hash: " + hashAlgo);
|
||||||
switch (hashAlgo) {
|
switch (hashAlgo) {
|
||||||
case HashAlgorithmTags.SHA1:
|
case HashAlgorithmTags.SHA1:
|
||||||
if (hash.length != 20) {
|
if (hash.length != 20) {
|
||||||
@ -354,14 +354,14 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
|
|
||||||
// while we are getting 0x61 status codes, retrieve more data
|
// while we are getting 0x61 status codes, retrieve more data
|
||||||
while (status.substring(0, 2).equals("61")) {
|
while (status.substring(0, 2).equals("61")) {
|
||||||
Log.d(TAG, "requesting more data, status " + status);
|
Log.d(Constants.TAG, "requesting more data, status " + status);
|
||||||
// Send GET RESPONSE command
|
// Send GET RESPONSE command
|
||||||
response = card("00C00000" + status.substring(2));
|
response = card("00C00000" + status.substring(2));
|
||||||
status = response.substring(response.length()-4);
|
status = response.substring(response.length()-4);
|
||||||
signature += response.substring(0, response.length()-4);
|
signature += response.substring(0, response.length()-4);
|
||||||
}
|
}
|
||||||
|
|
||||||
Log.d(TAG, "final response:" + status);
|
Log.d(Constants.TAG, "final response:" + status);
|
||||||
|
|
||||||
if ( ! status.equals("9000")) {
|
if ( ! status.equals("9000")) {
|
||||||
toast("Bad NFC response code: " + status);
|
toast("Bad NFC response code: " + status);
|
||||||
@ -404,7 +404,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
|
|
||||||
String decryptedSessionKey = getDataField(second);
|
String decryptedSessionKey = getDataField(second);
|
||||||
|
|
||||||
Log.d(TAG, "decryptedSessionKey: " + decryptedSessionKey);
|
Log.d(Constants.TAG, "decryptedSessionKey: " + decryptedSessionKey);
|
||||||
|
|
||||||
return Hex.decode(decryptedSessionKey);
|
return Hex.decode(decryptedSessionKey);
|
||||||
}
|
}
|
||||||
@ -436,9 +436,9 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
try {
|
try {
|
||||||
mNfcAdapter.enableForegroundDispatch(this, nfcPendingIntent, writeTagFilters, null);
|
mNfcAdapter.enableForegroundDispatch(this, nfcPendingIntent, writeTagFilters, null);
|
||||||
} catch (IllegalStateException e) {
|
} catch (IllegalStateException e) {
|
||||||
Log.i(TAG, "NfcForegroundDispatch Error!", e);
|
Log.i(Constants.TAG, "NfcForegroundDispatch Error!", e);
|
||||||
}
|
}
|
||||||
Log.d(TAG, "NfcForegroundDispatch has been enabled!");
|
Log.d(Constants.TAG, "NfcForegroundDispatch has been enabled!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -446,7 +446,7 @@ public class NfcActivity extends ActionBarActivity {
|
|||||||
*/
|
*/
|
||||||
public void disableNfcForegroundDispatch() {
|
public void disableNfcForegroundDispatch() {
|
||||||
mNfcAdapter.disableForegroundDispatch(this);
|
mNfcAdapter.disableForegroundDispatch(this);
|
||||||
Log.d(TAG, "NfcForegroundDispatch has been disabled!");
|
Log.d(Constants.TAG, "NfcForegroundDispatch has been disabled!");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
2
extern/safeslinger-exchange
vendored
2
extern/safeslinger-exchange
vendored
@ -1 +1 @@
|
|||||||
Subproject commit eb770ac3cb4fe49de0a87bda13f3a29b26e2901f
|
Subproject commit d584614921600fabe2043d16acfefd55d4c00c8a
|
Loading…
Reference in New Issue
Block a user