mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-08 04:08:15 -05:00
Added two new activities to allow for confirming/choosing the detected settings. Also connected them to the next button in the autoconfiguration activity.
This commit is contained in:
parent
2423c45ec2
commit
cba9ccd416
@ -108,6 +108,18 @@
|
||||
android:configChanges="keyboardHidden|orientation|locale"
|
||||
>
|
||||
</activity>
|
||||
<activity
|
||||
android:name="com.fsck.k9.activity.setup.AccountSetupConfirmIncoming"
|
||||
android:label="@string/account_setup_autoconfig_title"
|
||||
android:configChanges="keyboardHidden|orientation|locale"
|
||||
>
|
||||
</activity>
|
||||
<activity
|
||||
android:name="com.fsck.k9.activity.setup.AccountSetupConfirmOutgoing"
|
||||
android:label="@string/account_setup_autoconfig_title"
|
||||
android:configChanges="keyboardHidden|orientation|locale"
|
||||
>
|
||||
</activity>
|
||||
<activity
|
||||
android:name="com.fsck.k9.activity.setup.AccountSetupAccountType"
|
||||
android:label="@string/account_setup_account_type_title"
|
||||
|
24
res/layout/account_setup_confirm.xml
Normal file
24
res/layout/account_setup_confirm.xml
Normal file
@ -0,0 +1,24 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
|
||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="fill_parent">
|
||||
|
||||
<Spinner
|
||||
android:id="@+id/spinner_hostname"
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:drawSelectorOnTop="true"
|
||||
android:prompt="@string/account_setup_basics_email_hint"
|
||||
/>
|
||||
|
||||
<Spinner
|
||||
android:id="@+id/spinner_protocol"
|
||||
android:layout_width="fill_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:drawSelectorOnTop="true"
|
||||
android:prompt="@string/account_setup_basics_email_hint"
|
||||
android:layout_below="@id/spinner_hostname"
|
||||
/>
|
||||
|
||||
</RelativeLayout>
|
@ -369,6 +369,8 @@ http://k9mail.googlecode.com/
|
||||
<string name="account_setup_check_settings_canceling_msg">Canceling\u2026</string>
|
||||
|
||||
<string name="account_setup_autoconfig_title">Autoconfiguration attempt</string>
|
||||
<string name="account_setup_confirm_incoming_title">Confirm incoming server settings</string>
|
||||
<string name="account_setup_confirm_outgoing_title">Confirm outgoing server settings</string>
|
||||
<string name="account_setup_autoconfig_info">Attempting to configure your account...</string>
|
||||
<string name="account_setup_autoconfig_test_safe_serverside">Looking for safe server-side configuration files...</string>
|
||||
<string name="account_setup_autoconfig_test_unsafe_serverside">Looking for UNSAFE server-side configuration files...</string>
|
||||
|
@ -14,9 +14,11 @@ import android.widget.TextView;
|
||||
import com.fsck.k9.K9;
|
||||
import com.fsck.k9.R;
|
||||
import com.fsck.k9.activity.K9Activity;
|
||||
import com.fsck.k9.helper.configxmlparser.AutoconfigInfo;
|
||||
import com.fsck.k9.helper.configxmlparser.ConfigurationXMLHandler;
|
||||
import com.fsck.k9.mail.store.TrustManagerFactory;
|
||||
import org.xml.sax.InputSource;
|
||||
import org.xml.sax.Parser;
|
||||
import org.xml.sax.SAXException;
|
||||
import org.xml.sax.XMLReader;
|
||||
|
||||
@ -85,6 +87,7 @@ public class AccountSetupAutoConfiguration extends K9Activity implements View.On
|
||||
private String mEmailAddress;
|
||||
private String mPassword;
|
||||
private String mLastMessage;
|
||||
private AutoconfigInfo mAutoConfigInfo;
|
||||
private boolean bForceManual = false;
|
||||
private boolean bDoneSearching = false;
|
||||
private boolean bFound = false;
|
||||
@ -257,10 +260,12 @@ public class AccountSetupAutoConfiguration extends K9Activity implements View.On
|
||||
Start parsing the xml
|
||||
*/
|
||||
private void parse(String data) throws IOException, SAXException, ParserConfigurationException {
|
||||
ConfigurationXMLHandler parser = new ConfigurationXMLHandler();
|
||||
XMLReader xr = SAXParserFactory.newInstance().newSAXParser().getXMLReader();
|
||||
xr.setContentHandler(new ConfigurationXMLHandler());
|
||||
xr.setContentHandler(parser);
|
||||
// TODO: see if this has performance consequences, otherwise change all so we pass around InputSource not string
|
||||
xr.parse(new InputSource(new StringReader(data)));
|
||||
mAutoConfigInfo = parser.getAutoconfigInfo();
|
||||
}
|
||||
|
||||
/*
|
||||
@ -367,12 +372,6 @@ public class AccountSetupAutoConfiguration extends K9Activity implements View.On
|
||||
return retParts;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onActivityResult(int reqCode, int resCode, Intent data) {
|
||||
setResult(resCode);
|
||||
finish();
|
||||
}
|
||||
|
||||
public void onClick(View v) {
|
||||
switch (v.getId()) {
|
||||
case R.id.autoconfig_button_cancel:
|
||||
@ -384,7 +383,9 @@ public class AccountSetupAutoConfiguration extends K9Activity implements View.On
|
||||
|
||||
// launch confirm activities
|
||||
}else{
|
||||
|
||||
AccountSetupConfirmIncoming.actionConfirmIncoming
|
||||
(this, mEmailAddress, mPassword, mAutoConfigInfo);
|
||||
finish();
|
||||
}
|
||||
break;
|
||||
default: return;
|
||||
@ -394,6 +395,7 @@ public class AccountSetupAutoConfiguration extends K9Activity implements View.On
|
||||
/*
|
||||
Ask the user to accept ssl certificates if they are not trusted already.
|
||||
TODO: Rework this so it changes the url counter, not restart intent
|
||||
NOTE: It's called but doesn't work right now because for the connection the default sslfactory is yet used
|
||||
*/
|
||||
private void acceptKeyDialog(final int msgResId, final int urlNumber, final Object... args) {
|
||||
mHandler.post(new Runnable() {
|
||||
|
@ -0,0 +1,87 @@
|
||||
package com.fsck.k9.activity.setup;
|
||||
|
||||
/*
|
||||
After gathering the necessary information one way or another this activity displays it to the user, eventually warns
|
||||
him it could be false ( no https ), asks for confirmation, allows selection of protocol,... and then goes on to test
|
||||
the final settings.
|
||||
*/
|
||||
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.view.View;
|
||||
import android.widget.ArrayAdapter;
|
||||
import android.widget.Spinner;
|
||||
import com.fsck.k9.Account;
|
||||
import com.fsck.k9.Preferences;
|
||||
import com.fsck.k9.R;
|
||||
import com.fsck.k9.activity.K9Activity;
|
||||
import com.fsck.k9.helper.configxmlparser.AutoconfigInfo;
|
||||
import com.fsck.k9.helper.configxmlparser.AutoconfigInfo.ServerType;
|
||||
|
||||
public class AccountSetupConfirmIncoming extends K9Activity implements View.OnClickListener {
|
||||
|
||||
private static final String EXTRA_ACCOUNT = "account";
|
||||
private static final String EXTRA_CONFIG_INFO = "configInfo";
|
||||
private static final String EXTRA_EMAIL = "email";
|
||||
private static final String EXTRA_PASSWORD = "password";
|
||||
|
||||
|
||||
public static void actionConfirmIncoming(Context context, Account account, AutoconfigInfo info) {
|
||||
Intent i = new Intent(context, AccountSetupConfirmIncoming.class);
|
||||
i.putExtra(EXTRA_ACCOUNT, account.getUuid());
|
||||
i.putExtra(EXTRA_CONFIG_INFO, info);
|
||||
context.startActivity(i);
|
||||
}
|
||||
|
||||
public static void actionConfirmIncoming(Context context, String email, String password, AutoconfigInfo info){
|
||||
Intent i = new Intent(context, AccountSetupConfirmIncoming.class);
|
||||
i.putExtra(EXTRA_EMAIL, email);
|
||||
i.putExtra(EXTRA_PASSWORD, password);
|
||||
i.putExtra(EXTRA_CONFIG_INFO, info);
|
||||
context.startActivity(i);
|
||||
}
|
||||
|
||||
// data
|
||||
Account mAccount;
|
||||
AutoconfigInfo mConfigInfo;
|
||||
|
||||
// gui elements
|
||||
Spinner mProtocolSpinner;
|
||||
Spinner mHostnameSpinner;
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstance){
|
||||
super.onCreate(savedInstance);
|
||||
setContentView(R.layout.account_setup_confirm);
|
||||
|
||||
// initialise gui elements from inflated layout
|
||||
mHostnameSpinner = (Spinner) findViewById(R.id.spinner_hostname);
|
||||
mProtocolSpinner = (Spinner) findViewById(R.id.spinner_protocol);
|
||||
|
||||
// get the data out of our intent
|
||||
// if no blank account passed make one
|
||||
String accountUuid = getIntent().getStringExtra(EXTRA_ACCOUNT);
|
||||
if(accountUuid != null)
|
||||
mAccount = Preferences.getPreferences(this).getAccount(accountUuid);
|
||||
else mAccount = Account.getBlankAccount(this,
|
||||
getIntent().getStringExtra(EXTRA_EMAIL),
|
||||
getIntent().getStringExtra(EXTRA_PASSWORD));
|
||||
mConfigInfo = getIntent().getParcelableExtra(EXTRA_CONFIG_INFO);
|
||||
|
||||
// attach data to gui elements
|
||||
// TODO: could make it's own layout xml..
|
||||
ArrayAdapter<ServerType> protocolAdapter =
|
||||
new ArrayAdapter<ServerType>(this, R.layout.account_setup_index_list_item, mConfigInfo.getAvailableIncomingServerTypes());
|
||||
mHostnameSpinner.setAdapter(protocolAdapter);
|
||||
|
||||
// attach the listeners
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClick(View view) {
|
||||
//To change body of implemented methods use File | Settings | File Templates.
|
||||
}
|
||||
|
||||
}
|
@ -0,0 +1,72 @@
|
||||
package com.fsck.k9.activity.setup;
|
||||
|
||||
/*
|
||||
After gathering the necessary information one way or another this activity displays it to the user, eventually warns
|
||||
him it could be false ( no https ), asks for confirmation, allows selection of protocol,... and then goes on to test
|
||||
the final settings.
|
||||
*/
|
||||
|
||||
import android.app.Activity;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.view.View;
|
||||
import com.fsck.k9.Account;
|
||||
import com.fsck.k9.Preferences;
|
||||
import com.fsck.k9.R;
|
||||
import com.fsck.k9.activity.K9Activity;
|
||||
import com.fsck.k9.helper.configxmlparser.AutoconfigInfo;
|
||||
|
||||
public class AccountSetupConfirmOutgoing extends K9Activity implements View.OnClickListener{
|
||||
|
||||
private static final String EXTRA_ACCOUNT = "account";
|
||||
private static final String EXTRA_CONFIG_INFO = "configInfo";
|
||||
private static final String EXTRA_EMAIL = "email";
|
||||
private static final String EXTRA_PASSWORD = "password";
|
||||
|
||||
|
||||
public static void actionConfirmOutgoing(Context context, Account account, AutoconfigInfo info) {
|
||||
Intent i = new Intent(context, AccountSetupConfirmOutgoing.class);
|
||||
i.putExtra(EXTRA_ACCOUNT, account.getUuid());
|
||||
i.putExtra(EXTRA_CONFIG_INFO, info);
|
||||
context.startActivity(i);
|
||||
}
|
||||
|
||||
public static void actionConfirmOutgoing(Context context, String email, String password, AutoconfigInfo info){
|
||||
Intent i = new Intent(context, AccountSetupConfirmOutgoing.class);
|
||||
i.putExtra(EXTRA_EMAIL, email);
|
||||
i.putExtra(EXTRA_PASSWORD, password);
|
||||
i.putExtra(EXTRA_CONFIG_INFO, info);
|
||||
context.startActivity(i);
|
||||
}
|
||||
|
||||
// data
|
||||
Account mAccount;
|
||||
AutoconfigInfo mConfigInfo;
|
||||
|
||||
@Override
|
||||
public void onCreate(Bundle savedInstance){
|
||||
super.onCreate(savedInstance);
|
||||
setContentView(R.layout.account_setup_confirm);
|
||||
|
||||
// initialise gui elements from inflated layout
|
||||
|
||||
// get the data out of our intent
|
||||
// if no blank account passed make one
|
||||
String accountUuid = getIntent().getStringExtra(EXTRA_ACCOUNT);
|
||||
if(accountUuid != null)
|
||||
mAccount = Preferences.getPreferences(this).getAccount(accountUuid);
|
||||
else mAccount = Account.getBlankAccount(this,
|
||||
getIntent().getStringExtra(EXTRA_EMAIL),
|
||||
getIntent().getStringExtra(EXTRA_PASSWORD));
|
||||
mConfigInfo = getIntent().getParcelableExtra(EXTRA_CONFIG_INFO);
|
||||
|
||||
// attach the listeners
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onClick(View view) {
|
||||
//To change body of implemented methods use File | Settings | File Templates.
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user