Clean up cert activity handling
Fix re-displaying the dialog on orientation change b/5622284 Add host/port when available b/4988512 Disambiguate intent between AOSP and EmailGoogle Change-Id: Ideeda20dfd9bd0070998ccf42d8042765866ca0e
This commit is contained in:
parent
9909fabcc6
commit
f765f9b976
@ -19,6 +19,7 @@ package com.android.emailcommon.utility;
|
|||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.security.KeyChain;
|
import android.security.KeyChain;
|
||||||
import android.security.KeyChainAliasCallback;
|
import android.security.KeyChainAliasCallback;
|
||||||
@ -28,14 +29,14 @@ import android.security.KeyChainAliasCallback;
|
|||||||
* a certificate to use for establishing secure connections in the Email app.
|
* a certificate to use for establishing secure connections in the Email app.
|
||||||
*/
|
*/
|
||||||
public class CertificateRequestor extends Activity implements KeyChainAliasCallback {
|
public class CertificateRequestor extends Activity implements KeyChainAliasCallback {
|
||||||
|
|
||||||
public static final String ACTION_REQUEST_CERT = "com.android.emailcommon.REQUEST_CERT";
|
|
||||||
|
|
||||||
public static final String EXTRA_HOST = "CertificateRequestor.host";
|
public static final String EXTRA_HOST = "CertificateRequestor.host";
|
||||||
public static final String EXTRA_PORT = "CertificateRequestor.port";
|
public static final String EXTRA_PORT = "CertificateRequestor.port";
|
||||||
|
|
||||||
public static final String RESULT_ALIAS = "CertificateRequestor.alias";
|
public static final String RESULT_ALIAS = "CertificateRequestor.alias";
|
||||||
|
|
||||||
|
public static final Uri CERTIFICATE_REQUEST_URI =
|
||||||
|
Uri.parse("eas://com.android.emailcommon/certrequest");
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
@ -44,12 +45,14 @@ public class CertificateRequestor extends Activity implements KeyChainAliasCallb
|
|||||||
String host = i.getStringExtra(EXTRA_HOST);
|
String host = i.getStringExtra(EXTRA_HOST);
|
||||||
int port = i.getIntExtra(EXTRA_PORT, -1);
|
int port = i.getIntExtra(EXTRA_PORT, -1);
|
||||||
|
|
||||||
|
if (savedInstanceState == null) {
|
||||||
KeyChain.choosePrivateKeyAlias(
|
KeyChain.choosePrivateKeyAlias(
|
||||||
this, this,
|
this, this,
|
||||||
null /* keytypes */, null /* issuers */,
|
null /* keytypes */, null /* issuers */,
|
||||||
host, port,
|
host, port,
|
||||||
null /* alias */);
|
null /* alias */);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Callback for the certificate request. Does not happen on the UI thread.
|
* Callback for the certificate request. Does not happen on the UI thread.
|
||||||
|
@ -839,6 +839,7 @@
|
|||||||
<string name="account_manager_type_imap" translatable="false">com.android.email</string>
|
<string name="account_manager_type_imap" translatable="false">com.android.email</string>
|
||||||
<string name="account_manager_type_legacy_imap" translatable="false">com.android.email</string>
|
<string name="account_manager_type_legacy_imap" translatable="false">com.android.email</string>
|
||||||
<string name="intent_exchange_action" translatable="false">com.android.email.EXCHANGE_INTENT</string>
|
<string name="intent_exchange_action" translatable="false">com.android.email.EXCHANGE_INTENT</string>
|
||||||
|
<string name="intent_exchange_cert_action" translatable="false">com.android.email.EXCHANGE_REQUEST_CERT</string>
|
||||||
<string name="intent_exchange_package" translatable="false">com.android.exchange</string>
|
<string name="intent_exchange_package" translatable="false">com.android.exchange</string>
|
||||||
<string name="intent_account_manager_entry" translatable="false">com.android.email.activity.setup.ACCOUNT_MANAGER_ENTRY</string>
|
<string name="intent_account_manager_entry" translatable="false">com.android.email.activity.setup.ACCOUNT_MANAGER_ENTRY</string>
|
||||||
<string name="intent_create_account" translatable="false">com.android.email.CREATE_ACCOUNT</string>
|
<string name="intent_create_account" translatable="false">com.android.email.CREATE_ACCOUNT</string>
|
||||||
|
@ -18,7 +18,6 @@ package com.android.email.activity.setup;
|
|||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.text.Editable;
|
import android.text.Editable;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
@ -354,8 +353,10 @@ public class AccountSetupCredentialsFragment extends AccountSetupFragment
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCertificateRequested() {
|
public void onCertificateRequested() {
|
||||||
final Intent intent = new Intent(CertificateRequestor.ACTION_REQUEST_CERT);
|
final Intent intent = new Intent(getString(R.string.intent_exchange_cert_action));
|
||||||
intent.setData(Uri.parse("eas://com.android.emailcommon/certrequest"));
|
intent.setData(CertificateRequestor.CERTIFICATE_REQUEST_URI);
|
||||||
|
// We don't set EXTRA_HOST or EXTRA_PORT here because we don't know the final host/port
|
||||||
|
// that we're connecting to yet, and autodiscover might point us somewhere else
|
||||||
startActivityForResult(intent, CERTIFICATE_REQUEST);
|
startActivityForResult(intent, CERTIFICATE_REQUEST);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,6 @@ import android.app.Activity;
|
|||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.Loader;
|
import android.content.Loader;
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Parcel;
|
import android.os.Parcel;
|
||||||
import android.text.Editable;
|
import android.text.Editable;
|
||||||
@ -611,8 +610,15 @@ public class AccountSetupIncomingFragment extends AccountServerBaseFragment
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCertificateRequested() {
|
public void onCertificateRequested() {
|
||||||
final Intent intent = new Intent(CertificateRequestor.ACTION_REQUEST_CERT);
|
final Intent intent = new Intent(getString(R.string.intent_exchange_cert_action));
|
||||||
intent.setData(Uri.parse("eas://com.android.emailcommon/certrequest"));
|
intent.setData(CertificateRequestor.CERTIFICATE_REQUEST_URI);
|
||||||
|
intent.putExtra(CertificateRequestor.EXTRA_HOST, mServerView.getText().toString().trim());
|
||||||
|
try {
|
||||||
|
intent.putExtra(CertificateRequestor.EXTRA_PORT,
|
||||||
|
Integer.parseInt(mPortView.getText().toString().trim()));
|
||||||
|
} catch (final NumberFormatException e) {
|
||||||
|
LogUtils.d(LogUtils.TAG, "Couldn't parse port %s", mPortView.getText());
|
||||||
|
}
|
||||||
startActivityForResult(intent, CERTIFICATE_REQUEST);
|
startActivityForResult(intent, CERTIFICATE_REQUEST);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user