mirror of
https://github.com/moparisthebest/k-9
synced 2024-11-12 04:25:08 -05:00
d1d8345278
r51837@31b (orig r127): ismarc31 | 2008-11-10 19:10:50 -0500 Experimental branch for Exchange WebDAV support r51838@31b (orig r128): ismarc31 | 2008-11-10 19:24:52 -0500 Initial proof-of-concept code for WebDav support r51839@31b (orig r129): ismarc31 | 2008-11-10 22:02:37 -0500 Fixed a couple of migration issues and enabled WebDav as a mail type r53269@31b (orig r132): ismarc31 | 2008-11-21 21:55:55 -0500 Mostly rewritten class and organization. Better implementation of message fetching. Consolidated response parsing. Removed a large number of redundant calls. There is still some unused functions needing cleaning up, and some unimplemented actions r53338@31b (orig r133): ismarc31 | 2008-11-22 16:50:02 -0500 Removed more redundant and unused calls. Implemented checking read status r53453@31b (orig r134): ismarc31 | 2008-11-24 20:13:24 -0500 Added support for marking messages as read. r53454@31b (orig r135): ismarc31 | 2008-11-24 22:04:04 -0500 Added support for deleting messages server side r53455@31b (orig r136): ismarc31 | 2008-11-25 01:32:19 -0500 Improved flag setting functionality, do bulk HTTP request instead of lots of little ones r53589@31b (orig r138): young.bradley | 2008-11-29 16:18:25 -0500 Missing some ports (webDavPorts); this causes an array index out of bounds exception when anything other than "None" or "SSL (Optional)" are selected. Adding the three additional ports solves this issue. r53590@31b (orig r139): young.bradley | 2008-11-30 00:47:42 -0500 Initial support for sending via WebDav r53591@31b (orig r140): ismarc31 | 2008-11-30 20:12:41 -0500 Fix for display names being URL Encoded for folders. Initial support of Uid Hashmaps instead of plain arrays. r53592@31b (orig r141): ismarc31 | 2008-11-30 21:46:06 -0500 Fix to constructor of HttpGeneric(final String uri). URLs returned from Exchange aren't always fully encoded, this fixes the encoding before creating the method. r53593@31b (orig r142): ismarc31 | 2008-12-01 02:22:16 -0500 Completed support for using hashmaps instead of arrays for indexing urls to emails and read status. Delete is safe again and read status is correct the first time through. r53594@31b (orig r143): ismarc31 | 2008-12-01 22:20:50 -0500 Fix for double-Inbox display issue. Removed volumous amounts of Log.d messages. r53644@31b (orig r157): young.bradley | 2008-12-04 15:14:28 -0500 Fix for wildcard certificates (e.g. issued to *.example.com). Only checking the trust of the certificate itself, since apparently the full chain causes it to not work. r53765@31b (orig r161): ismarc31 | 2008-12-06 18:55:08 -0500 Implemented new functionality for pulling message envelope. Uses a WebDAV call for all messages rather than parsing the stream. Message size is properly set now as well. r54055@31b (orig r163): jessev | 2008-12-06 19:28:24 -0500 * merge fixes
286 lines
10 KiB
Java
286 lines
10 KiB
Java
|
|
package com.fsck.k9.activity.setup;
|
|
|
|
import java.net.URI;
|
|
import java.net.URISyntaxException;
|
|
|
|
import android.app.Activity;
|
|
import android.content.Context;
|
|
import android.content.Intent;
|
|
import android.os.Bundle;
|
|
import android.text.Editable;
|
|
import android.text.TextWatcher;
|
|
import android.text.method.DigitsKeyListener;
|
|
import android.view.View;
|
|
import android.view.ViewGroup;
|
|
import android.view.View.OnClickListener;
|
|
import android.widget.AdapterView;
|
|
import android.widget.ArrayAdapter;
|
|
import android.widget.Button;
|
|
import android.widget.CheckBox;
|
|
import android.widget.CompoundButton;
|
|
import android.widget.EditText;
|
|
import android.widget.Spinner;
|
|
import android.widget.CompoundButton.OnCheckedChangeListener;
|
|
|
|
import com.fsck.k9.Account;
|
|
import com.fsck.k9.Preferences;
|
|
import com.fsck.k9.R;
|
|
import com.fsck.k9.Utility;
|
|
|
|
public class AccountSetupOutgoing extends Activity implements OnClickListener,
|
|
OnCheckedChangeListener {
|
|
private static final String EXTRA_ACCOUNT = "account";
|
|
|
|
private static final String EXTRA_MAKE_DEFAULT = "makeDefault";
|
|
|
|
private static final int smtpPorts[] = {
|
|
25, 465, 465, 25, 25
|
|
};
|
|
|
|
private static final String smtpSchemes[] = {
|
|
"smtp", "smtp+ssl", "smtp+ssl+", "smtp+tls", "smtp+tls+"
|
|
};
|
|
private static final int webdavPorts[] = {
|
|
80, 443, 443, 443, 443
|
|
};
|
|
private static final String webdavSchemes[] = {
|
|
"webdav", "webdav+ssl", "webdav+ssl+", "webdav+tls", "webdav+tls+"
|
|
};
|
|
|
|
private EditText mUsernameView;
|
|
private EditText mPasswordView;
|
|
private EditText mServerView;
|
|
private EditText mPortView;
|
|
private CheckBox mRequireLoginView;
|
|
private ViewGroup mRequireLoginSettingsView;
|
|
private Spinner mSecurityTypeView;
|
|
private Button mNextButton;
|
|
private Account mAccount;
|
|
private boolean mMakeDefault;
|
|
|
|
public static void actionOutgoingSettings(Context context, Account account, boolean makeDefault) {
|
|
Intent i = new Intent(context, AccountSetupOutgoing.class);
|
|
i.putExtra(EXTRA_ACCOUNT, account);
|
|
i.putExtra(EXTRA_MAKE_DEFAULT, makeDefault);
|
|
context.startActivity(i);
|
|
}
|
|
|
|
public static void actionEditOutgoingSettings(Context context, Account account) {
|
|
Intent i = new Intent(context, AccountSetupOutgoing.class);
|
|
i.setAction(Intent.ACTION_EDIT);
|
|
i.putExtra(EXTRA_ACCOUNT, account);
|
|
context.startActivity(i);
|
|
}
|
|
|
|
@Override
|
|
public void onCreate(Bundle savedInstanceState) {
|
|
super.onCreate(savedInstanceState);
|
|
setContentView(R.layout.account_setup_outgoing);
|
|
|
|
mAccount = (Account)getIntent().getSerializableExtra(EXTRA_ACCOUNT);
|
|
|
|
try {
|
|
if (new URI(mAccount.getStoreUri()).getScheme().startsWith("webdav")) {
|
|
mAccount.setTransportUri(mAccount.getStoreUri());
|
|
AccountSetupCheckSettings.actionCheckSettings(this, mAccount, false, true);
|
|
}
|
|
} catch (URISyntaxException e) {
|
|
// TODO Auto-generated catch block
|
|
e.printStackTrace();
|
|
}
|
|
|
|
|
|
mUsernameView = (EditText)findViewById(R.id.account_username);
|
|
mPasswordView = (EditText)findViewById(R.id.account_password);
|
|
mServerView = (EditText)findViewById(R.id.account_server);
|
|
mPortView = (EditText)findViewById(R.id.account_port);
|
|
mRequireLoginView = (CheckBox)findViewById(R.id.account_require_login);
|
|
mRequireLoginSettingsView = (ViewGroup)findViewById(R.id.account_require_login_settings);
|
|
mSecurityTypeView = (Spinner)findViewById(R.id.account_security_type);
|
|
mNextButton = (Button)findViewById(R.id.next);
|
|
|
|
mNextButton.setOnClickListener(this);
|
|
mRequireLoginView.setOnCheckedChangeListener(this);
|
|
|
|
SpinnerOption securityTypes[] = {
|
|
new SpinnerOption(0, getString(R.string.account_setup_incoming_security_none_label)),
|
|
new SpinnerOption(1,
|
|
getString(R.string.account_setup_incoming_security_ssl_optional_label)),
|
|
new SpinnerOption(2, getString(R.string.account_setup_incoming_security_ssl_label)),
|
|
new SpinnerOption(3,
|
|
getString(R.string.account_setup_incoming_security_tls_optional_label)),
|
|
new SpinnerOption(4, getString(R.string.account_setup_incoming_security_tls_label)),
|
|
};
|
|
|
|
ArrayAdapter<SpinnerOption> securityTypesAdapter = new ArrayAdapter<SpinnerOption>(this,
|
|
android.R.layout.simple_spinner_item, securityTypes);
|
|
securityTypesAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
|
|
mSecurityTypeView.setAdapter(securityTypesAdapter);
|
|
|
|
/*
|
|
* Updates the port when the user changes the security type. This allows
|
|
* us to show a reasonable default which the user can change.
|
|
*/
|
|
mSecurityTypeView.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
|
|
public void onItemSelected(AdapterView arg0, View arg1, int arg2, long arg3) {
|
|
updatePortFromSecurityType();
|
|
}
|
|
|
|
public void onNothingSelected(AdapterView<?> arg0) {
|
|
}
|
|
});
|
|
|
|
/*
|
|
* Calls validateFields() which enables or disables the Next button
|
|
* based on the fields' validity.
|
|
*/
|
|
TextWatcher validationTextWatcher = new TextWatcher() {
|
|
public void afterTextChanged(Editable s) {
|
|
validateFields();
|
|
}
|
|
|
|
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
|
|
}
|
|
|
|
public void onTextChanged(CharSequence s, int start, int before, int count) {
|
|
}
|
|
};
|
|
mUsernameView.addTextChangedListener(validationTextWatcher);
|
|
mPasswordView.addTextChangedListener(validationTextWatcher);
|
|
mServerView.addTextChangedListener(validationTextWatcher);
|
|
mPortView.addTextChangedListener(validationTextWatcher);
|
|
|
|
/*
|
|
* Only allow digits in the port field.
|
|
*/
|
|
mPortView.setKeyListener(DigitsKeyListener.getInstance("0123456789"));
|
|
|
|
mAccount = (Account)getIntent().getSerializableExtra(EXTRA_ACCOUNT);
|
|
mMakeDefault = (boolean)getIntent().getBooleanExtra(EXTRA_MAKE_DEFAULT, false);
|
|
|
|
/*
|
|
* If we're being reloaded we override the original account with the one
|
|
* we saved
|
|
*/
|
|
if (savedInstanceState != null && savedInstanceState.containsKey(EXTRA_ACCOUNT)) {
|
|
mAccount = (Account)savedInstanceState.getSerializable(EXTRA_ACCOUNT);
|
|
}
|
|
|
|
try {
|
|
URI uri = new URI(mAccount.getTransportUri());
|
|
String username = null;
|
|
String password = null;
|
|
if (uri.getUserInfo() != null) {
|
|
String[] userInfoParts = uri.getUserInfo().split(":", 2);
|
|
username = userInfoParts[0];
|
|
if (userInfoParts.length > 1) {
|
|
password = userInfoParts[1];
|
|
}
|
|
}
|
|
|
|
if (username != null) {
|
|
mUsernameView.setText(username);
|
|
mRequireLoginView.setChecked(true);
|
|
}
|
|
|
|
if (password != null) {
|
|
mPasswordView.setText(password);
|
|
}
|
|
|
|
for (int i = 0; i < smtpSchemes.length; i++) {
|
|
if (smtpSchemes[i].equals(uri.getScheme())) {
|
|
SpinnerOption.setSpinnerOptionValue(mSecurityTypeView, i);
|
|
}
|
|
}
|
|
|
|
if (uri.getHost() != null) {
|
|
mServerView.setText(uri.getHost());
|
|
}
|
|
|
|
if (uri.getPort() != -1) {
|
|
mPortView.setText(Integer.toString(uri.getPort()));
|
|
} else {
|
|
updatePortFromSecurityType();
|
|
}
|
|
} catch (URISyntaxException use) {
|
|
/*
|
|
* We should always be able to parse our own settings.
|
|
*/
|
|
throw new Error(use);
|
|
}
|
|
|
|
validateFields();
|
|
}
|
|
|
|
@Override
|
|
public void onSaveInstanceState(Bundle outState) {
|
|
super.onSaveInstanceState(outState);
|
|
outState.putSerializable(EXTRA_ACCOUNT, mAccount);
|
|
}
|
|
|
|
private void validateFields() {
|
|
mNextButton
|
|
.setEnabled(
|
|
Utility.requiredFieldValid(mServerView) &&
|
|
Utility.requiredFieldValid(mPortView) &&
|
|
(!mRequireLoginView.isChecked() ||
|
|
(Utility.requiredFieldValid(mUsernameView) &&
|
|
Utility.requiredFieldValid(mPasswordView))));
|
|
Utility.setCompoundDrawablesAlpha(mNextButton, mNextButton.isEnabled() ? 255 : 128);
|
|
}
|
|
|
|
private void updatePortFromSecurityType() {
|
|
int securityType = (Integer)((SpinnerOption)mSecurityTypeView.getSelectedItem()).value;
|
|
mPortView.setText(Integer.toString(smtpPorts[securityType]));
|
|
}
|
|
|
|
@Override
|
|
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
|
if (resultCode == RESULT_OK) {
|
|
if (Intent.ACTION_EDIT.equals(getIntent().getAction())) {
|
|
mAccount.save(Preferences.getPreferences(this));
|
|
finish();
|
|
} else {
|
|
AccountSetupOptions.actionOptions(this, mAccount, mMakeDefault);
|
|
finish();
|
|
}
|
|
}
|
|
}
|
|
|
|
private void onNext() {
|
|
int securityType = (Integer)((SpinnerOption)mSecurityTypeView.getSelectedItem()).value;
|
|
URI uri;
|
|
try {
|
|
String userInfo = null;
|
|
if (mRequireLoginView.isChecked()) {
|
|
userInfo = mUsernameView.getText().toString() + ":"
|
|
+ mPasswordView.getText().toString();
|
|
}
|
|
uri = new URI(smtpSchemes[securityType], userInfo, mServerView.getText().toString(),
|
|
Integer.parseInt(mPortView.getText().toString()), null, null, null);
|
|
mAccount.setTransportUri(uri.toString());
|
|
} catch (URISyntaxException use) {
|
|
/*
|
|
* It's unrecoverable if we cannot create a URI from components that
|
|
* we validated to be safe.
|
|
*/
|
|
throw new Error(use);
|
|
}
|
|
AccountSetupCheckSettings.actionCheckSettings(this, mAccount, false, true);
|
|
}
|
|
|
|
public void onClick(View v) {
|
|
switch (v.getId()) {
|
|
case R.id.next:
|
|
onNext();
|
|
break;
|
|
}
|
|
}
|
|
|
|
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
|
|
mRequireLoginSettingsView.setVisibility(isChecked ? View.VISIBLE : View.GONE);
|
|
validateFields();
|
|
}
|
|
}
|