mirror of
https://github.com/moparisthebest/open-keychain
synced 2025-01-12 14:08:24 -05:00
Fix qr code finally
This commit is contained in:
parent
0d644e37b1
commit
a1525bffe2
@ -135,16 +135,21 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
|
|
||||||
if (Intent.ACTION_VIEW.equals(action)) {
|
if (Intent.ACTION_VIEW.equals(action)) {
|
||||||
// Android's Action when opening file associated to Keychain (see AndroidManifest.xml)
|
// Android's Action when opening file associated to Keychain (see AndroidManifest.xml)
|
||||||
// override action to delegate it to Keychain's ACTION_IMPORT_KEY
|
// delegate action to ACTION_IMPORT_KEY
|
||||||
action = ACTION_IMPORT_KEY;
|
action = ACTION_IMPORT_KEY;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scheme != null && scheme.toLowerCase(Locale.ENGLISH).equals(Constants.FINGERPRINT_SCHEME)) {
|
||||||
|
/* Scanning a fingerprint directly with Barcode Scanner */
|
||||||
|
// delegate action to ACTION_IMPORT_KEY_FROM_KEYSERVER
|
||||||
|
String fingerprint = getFingerprintFromUri(dataUri);
|
||||||
|
action = ACTION_IMPORT_KEY_FROM_KEYSERVER;
|
||||||
|
extras.putString(EXTRA_FINGERPRINT, fingerprint);
|
||||||
|
}
|
||||||
|
|
||||||
Bundle serverBundle = null;
|
Bundle serverBundle = null;
|
||||||
boolean serverOnly = false;
|
boolean serverOnly = false;
|
||||||
if (scheme != null && scheme.toLowerCase(Locale.ENGLISH).equals(Constants.FINGERPRINT_SCHEME)) {
|
if (ACTION_IMPORT_KEY.equals(action)) {
|
||||||
/* Scanning a fingerprint directly with Barcode Scanner */
|
|
||||||
loadFromFingerprintUri(savedInstanceState, dataUri);
|
|
||||||
} else if (ACTION_IMPORT_KEY.equals(action)) {
|
|
||||||
/* Keychain's own Actions */
|
/* Keychain's own Actions */
|
||||||
|
|
||||||
// display file fragment
|
// display file fragment
|
||||||
@ -154,7 +159,7 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
// action: directly load data
|
// action: directly load data
|
||||||
startListFragment(savedInstanceState, null, dataUri, null);
|
startListFragment(savedInstanceState, null, dataUri, null);
|
||||||
} else if (extras.containsKey(EXTRA_KEY_BYTES)) {
|
} else if (extras.containsKey(EXTRA_KEY_BYTES)) {
|
||||||
byte[] importData = intent.getByteArrayExtra(EXTRA_KEY_BYTES);
|
byte[] importData = extras.getByteArray(EXTRA_KEY_BYTES);
|
||||||
|
|
||||||
// action: directly load data
|
// action: directly load data
|
||||||
startListFragment(savedInstanceState, importData, null, null);
|
startListFragment(savedInstanceState, importData, null, null);
|
||||||
@ -173,7 +178,7 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
if (extras.containsKey(EXTRA_QUERY)) {
|
if (extras.containsKey(EXTRA_QUERY)) {
|
||||||
query = extras.getString(EXTRA_QUERY);
|
query = extras.getString(EXTRA_QUERY);
|
||||||
} else if (extras.containsKey(EXTRA_KEY_ID)) {
|
} else if (extras.containsKey(EXTRA_KEY_ID)) {
|
||||||
long keyId = intent.getLongExtra(EXTRA_KEY_ID, 0);
|
long keyId = extras.getLong(EXTRA_KEY_ID, 0);
|
||||||
if (keyId != 0) {
|
if (keyId != 0) {
|
||||||
query = PgpKeyHelper.convertKeyIdToHex(keyId);
|
query = PgpKeyHelper.convertKeyIdToHex(keyId);
|
||||||
}
|
}
|
||||||
@ -197,7 +202,7 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
* if the right key has been downloaded
|
* if the right key has been downloaded
|
||||||
*/
|
*/
|
||||||
|
|
||||||
String fingerprint = intent.getStringExtra(EXTRA_FINGERPRINT);
|
String fingerprint = extras.getString(EXTRA_FINGERPRINT);
|
||||||
if (isFingerprintValid(fingerprint)) {
|
if (isFingerprintValid(fingerprint)) {
|
||||||
String query = "0x" + fingerprint;
|
String query = "0x" + fingerprint;
|
||||||
|
|
||||||
@ -325,18 +330,23 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
return OtherHelper.pxToDp(this, params.height);
|
return OtherHelper.pxToDp(this, params.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadFromFingerprintUri(Bundle savedInstanceState, Uri dataUri) {
|
private String getFingerprintFromUri(Uri dataUri) {
|
||||||
String fingerprint = dataUri.toString().split(":")[1].toLowerCase(Locale.ENGLISH);
|
String fingerprint = dataUri.toString().split(":")[1].toLowerCase(Locale.ENGLISH);
|
||||||
|
|
||||||
Log.d(Constants.TAG, "fingerprint: " + fingerprint);
|
Log.d(Constants.TAG, "fingerprint: " + fingerprint);
|
||||||
|
return fingerprint;
|
||||||
|
}
|
||||||
|
|
||||||
final String query = "0x" + fingerprint;
|
public void loadFromFingerprintUri(Uri dataUri) {
|
||||||
|
String query = "0x" + getFingerprintFromUri(dataUri);
|
||||||
|
|
||||||
|
// setCurrentItem does not work directly after onResume (from qr code scanner)
|
||||||
|
// see http://stackoverflow.com/q/19316729
|
||||||
|
// so, reset adapter completely!
|
||||||
|
if (mViewPager.getAdapter() != null)
|
||||||
|
mViewPager.setAdapter(null);
|
||||||
|
mViewPager.setAdapter(mTabsAdapter);
|
||||||
mViewPager.setCurrentItem(TAB_KEYSERVER);
|
mViewPager.setCurrentItem(TAB_KEYSERVER);
|
||||||
|
|
||||||
// update layout after operations
|
|
||||||
mSlidingTabLayout.setViewPager(mViewPager);
|
|
||||||
|
|
||||||
ImportKeysServerFragment f = (ImportKeysServerFragment)
|
ImportKeysServerFragment f = (ImportKeysServerFragment)
|
||||||
getActiveFragment(mViewPager, TAB_KEYSERVER);
|
getActiveFragment(mViewPager, TAB_KEYSERVER);
|
||||||
|
|
||||||
@ -344,7 +354,10 @@ public class ImportKeysActivity extends ActionBarActivity {
|
|||||||
String keyserver = Preferences.getPreferences(ImportKeysActivity.this)
|
String keyserver = Preferences.getPreferences(ImportKeysActivity.this)
|
||||||
.getKeyServers()[0];
|
.getKeyServers()[0];
|
||||||
|
|
||||||
f.searchCallback(query, keyserver);
|
// set fields of ImportKeysServerFragment
|
||||||
|
f.setQueryAndKeyserver(query, keyserver);
|
||||||
|
// search directly
|
||||||
|
loadCallback(new ImportKeysListFragment.KeyserverLoaderState(query, keyserver));
|
||||||
}
|
}
|
||||||
|
|
||||||
// http://stackoverflow.com/a/9293207
|
// http://stackoverflow.com/a/9293207
|
||||||
|
@ -81,7 +81,7 @@ public class ImportKeysFileFragment extends Fragment {
|
|||||||
if (clipboardText != null) {
|
if (clipboardText != null) {
|
||||||
sendText = clipboardText.toString();
|
sendText = clipboardText.toString();
|
||||||
if (sendText.toLowerCase(Locale.ENGLISH).startsWith(Constants.FINGERPRINT_SCHEME)) {
|
if (sendText.toLowerCase(Locale.ENGLISH).startsWith(Constants.FINGERPRINT_SCHEME)) {
|
||||||
mImportActivity.loadFromFingerprintUri(null, Uri.parse(sendText));
|
mImportActivity.loadFromFingerprintUri(Uri.parse(sendText));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -132,7 +132,7 @@ public class ImportKeysQrCodeFragment extends Fragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void importFingerprint(Uri dataUri) {
|
public void importFingerprint(Uri dataUri) {
|
||||||
mImportActivity.loadFromFingerprintUri(null, dataUri);
|
mImportActivity.loadFromFingerprintUri(dataUri);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -174,11 +174,10 @@ public class ImportKeysServerFragment extends Fragment {
|
|||||||
mImportActivity.loadCallback(new ImportKeysListFragment.KeyserverLoaderState(query, keyserver));
|
mImportActivity.loadCallback(new ImportKeysListFragment.KeyserverLoaderState(query, keyserver));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void searchCallback(String query, String keyserver) {
|
public void setQueryAndKeyserver(String query, String keyserver) {
|
||||||
mQueryEditText.setText(query, TextView.BufferType.EDITABLE);
|
mQueryEditText.setText(query, TextView.BufferType.EDITABLE);
|
||||||
int keyServerPos = mServerAdapter.getPosition(keyserver);
|
int keyServerPos = mServerAdapter.getPosition(keyserver);
|
||||||
mServerSpinner.setSelection(keyServerPos);
|
mServerSpinner.setSelection(keyServerPos);
|
||||||
search(query, keyserver);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user