moving from eu.alefzero.eu to com.owncloud.android
[pub/Android/ownCloud.git] / src / eu / alefzero / owncloud / ui / activity / AuthenticatorActivity.java
diff --git a/src/eu/alefzero/owncloud/ui/activity/AuthenticatorActivity.java b/src/eu/alefzero/owncloud/ui/activity/AuthenticatorActivity.java
deleted file mode 100644 (file)
index 545adef..0000000
+++ /dev/null
@@ -1,263 +0,0 @@
-/* ownCloud Android client application\r
- *   Copyright (C) 2011  Bartek Przybylski\r
- *\r
- *   This program is free software: you can redistribute it and/or modify\r
- *   it under the terms of the GNU General Public License as published by\r
- *   the Free Software Foundation, either version 3 of the License, or\r
- *   (at your option) any later version.\r
- *\r
- *   This program is distributed in the hope that it will be useful,\r
- *   but WITHOUT ANY WARRANTY; without even the implied warranty of\r
- *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
- *   GNU General Public License for more details.\r
- *\r
- *   You should have received a copy of the GNU General Public License\r
- *   along with this program.  If not, see <http://www.gnu.org/licenses/>.\r
- *\r
- */\r
-\r
-package eu.alefzero.owncloud.ui.activity;\r
-\r
-import java.net.MalformedURLException;\r
-import java.net.URL;\r
-\r
-import android.accounts.Account;\r
-import android.accounts.AccountAuthenticatorActivity;\r
-import android.accounts.AccountManager;\r
-import android.app.Dialog;\r
-import android.app.ProgressDialog;\r
-import android.content.ContentResolver;\r
-import android.content.DialogInterface;\r
-import android.content.Intent;\r
-import android.content.SharedPreferences;\r
-import android.graphics.Color;\r
-import android.os.Bundle;\r
-import android.os.Handler;\r
-import android.preference.PreferenceManager;\r
-import android.text.InputType;\r
-import android.util.Log;\r
-import android.view.View;\r
-import android.view.Window;\r
-import android.widget.TextView;\r
-import android.widget.Toast;\r
-import eu.alefzero.owncloud.AccountUtils;\r
-import eu.alefzero.owncloud.R;\r
-import eu.alefzero.owncloud.authenticator.AccountAuthenticator;\r
-import eu.alefzero.owncloud.authenticator.AuthenticationRunnable;\r
-import eu.alefzero.owncloud.authenticator.OnAuthenticationResultListener;\r
-import eu.alefzero.owncloud.db.ProviderMeta.ProviderTableMeta;\r
-\r
-/**\r
- * This Activity is used to add an ownCloud account to the App\r
- * \r
- * @author Bartek Przybylski\r
- * \r
- */\r
-public class AuthenticatorActivity extends AccountAuthenticatorActivity implements OnAuthenticationResultListener {\r
-  private static final int DIALOG_LOGIN_PROGRESS = 0;\r
-  private static final String TAG = "AuthActivity";\r
-\r
-  private Thread mAuthThread;\r
-  private AuthenticationRunnable mAuthRunnable;\r
-  private final Handler mHandler = new Handler();\r
-  private boolean mUseSSLConnection;\r
-\r
-  public static final String PARAM_USERNAME = "param_Username";\r
-  public static final String PARAM_HOSTNAME = "param_Hostname";\r
-\r
-  public AuthenticatorActivity() {\r
-    mUseSSLConnection = true;\r
-  }\r
-\r
-  @Override\r
-  protected void onCreate(Bundle savedInstanceState) {\r
-    super.onCreate(savedInstanceState);\r
-    getWindow().requestFeature(Window.FEATURE_NO_TITLE);\r
-    setContentView(R.layout.account_setup);\r
-    if (getIntent().hasExtra(PARAM_USERNAME)) {\r
-      String username = getIntent().getStringExtra(PARAM_HOSTNAME);\r
-      TextView host_text, user_text;\r
-      host_text = (TextView) findViewById(R.id.host_URL);\r
-      user_text = (TextView) findViewById(R.id.account_username);\r
-      host_text.setText(host_text.getText()\r
-          + username.substring(username.lastIndexOf('@')));\r
-      user_text.setText(user_text.getText()\r
-          + username.substring(0, username.lastIndexOf('@') - 1));\r
-    }\r
-  }\r
-\r
-  @Override\r
-  protected Dialog onCreateDialog(int id) {\r
-    Dialog dialog = null;\r
-    switch (id) {\r
-      case DIALOG_LOGIN_PROGRESS : {\r
-        ProgressDialog working_dialog = new ProgressDialog(this);\r
-        dialog = working_dialog;\r
-        working_dialog.setMessage(getResources().getString(R.string.auth_trying_to_login));\r
-        working_dialog.setIndeterminate(true);\r
-        working_dialog.setCancelable(true);\r
-        working_dialog.setOnCancelListener(new DialogInterface.OnCancelListener() {\r
-          @Override\r
-          public void onCancel(DialogInterface dialog) {\r
-            Log.i(getClass().getName(), "Login canceled");\r
-            if (mAuthThread != null) {\r
-              mAuthThread.interrupt();\r
-              finish();\r
-            }\r
-          }\r
-        });\r
-        break;\r
-      }\r
-      default :\r
-        Log.e(TAG, "Incorrect dialog called with id = " + id);\r
-    }\r
-    return dialog;\r
-  }\r
-\r
-  public void onAuthenticationResult(boolean success, String message) {\r
-    if (success) {\r
-      TextView username_text = (TextView) findViewById(R.id.account_username), password_text = (TextView) findViewById(R.id.account_password);\r
-\r
-      URL url;\r
-      try {\r
-        url = new URL(message);\r
-      } catch (MalformedURLException e) {\r
-        // should never happen\r
-        Log.e(getClass().getName(), "Malformed URL: " + message);\r
-        return;\r
-      }\r
-\r
-      String username = username_text.getText().toString().trim();\r
-      String accountName = username + "@" + url.getHost();\r
-      Account account = new Account(accountName,\r
-          AccountAuthenticator.ACCOUNT_TYPE);\r
-      AccountManager accManager = AccountManager.get(this);\r
-      accManager.addAccountExplicitly(account, password_text.getText()\r
-          .toString(), null);\r
-\r
-      // Add this account as default in the preferences, if there is none\r
-      // already\r
-      Account defaultAccount = AccountUtils.getCurrentOwnCloudAccount(this);\r
-      if (defaultAccount == null) {\r
-        SharedPreferences.Editor editor = PreferenceManager\r
-            .getDefaultSharedPreferences(this).edit();\r
-        editor.putString("select_oc_account", accountName);\r
-        editor.commit();\r
-      }\r
-\r
-      final Intent intent = new Intent();\r
-      intent.putExtra(AccountManager.KEY_ACCOUNT_TYPE,\r
-          AccountAuthenticator.ACCOUNT_TYPE);\r
-      intent.putExtra(AccountManager.KEY_ACCOUNT_NAME, account.name);\r
-      intent.putExtra(AccountManager.KEY_AUTHTOKEN,\r
-          AccountAuthenticator.ACCOUNT_TYPE);\r
-      accManager.setUserData(account, AccountAuthenticator.KEY_OC_URL,\r
-          url.toString());\r
-\r
-      // TODO prepare this URL using a central service\r
-      intent.putExtra(AccountManager.KEY_USERDATA, username);\r
-      accManager.setUserData(\r
-          account,\r
-          AccountAuthenticator.KEY_CONTACT_URL,\r
-          url.toString().replace(AccountUtils.WEBDAV_PATH_2_0,\r
-              AccountUtils.CARDDAV_PATH_2_0));\r
-\r
-      setAccountAuthenticatorResult(intent.getExtras());\r
-      setResult(RESULT_OK, intent);\r
-      Bundle bundle = new Bundle();\r
-      bundle.putBoolean(ContentResolver.SYNC_EXTRAS_MANUAL, true);\r
-      getContentResolver().startSync(ProviderTableMeta.CONTENT_URI, bundle);\r
-\r
-      dismissDialog(0);\r
-      finish();\r
-    } else {\r
-      Toast.makeText(this, message, Toast.LENGTH_LONG).show();\r
-      dismissDialog(0);\r
-    }\r
-  }\r
-\r
-  public void onOkClick(View view) {\r
-    TextView url_text = (TextView) findViewById(R.id.host_URL);\r
-    TextView username_text = (TextView) findViewById(R.id.account_username);\r
-    TextView password_text = (TextView) findViewById(R.id.account_password);\r
-    Log.i(getClass().getName(), "OK clicked");\r
-    boolean hasErrors = false;\r
-\r
-    URL uri = null;\r
-    if (url_text.getText().toString().trim().length() == 0) {\r
-      url_text.setTextColor(Color.RED);\r
-      hasErrors = true;\r
-    } else {\r
-      url_text.setTextColor(android.R.color.black);\r
-    }\r
-    try {\r
-      String url_str = url_text.getText().toString();\r
-      if (!url_str.startsWith("http://") && !url_str.startsWith("https://")) {\r
-        if (mUseSSLConnection)\r
-          url_str = "https://" + url_str;\r
-        else\r
-          url_str = "http://" + url_str;\r
-      }\r
-      uri = new URL(url_str);\r
-    } catch (MalformedURLException e) {\r
-      url_text.setTextColor(Color.RED);\r
-      e.printStackTrace();\r
-      hasErrors = true;\r
-    }\r
-\r
-    if (username_text.getText().toString().contains(" ")\r
-        || username_text.getText().toString().trim().length() == 0) {\r
-      username_text.setTextColor(Color.RED);\r
-      hasErrors = true;\r
-    } else {\r
-      username_text.setTextColor(android.R.color.black);\r
-    }\r
-\r
-    if (password_text.getText().toString().trim().length() == 0) {\r
-      password_text.setTextColor(Color.RED);\r
-      hasErrors = true;\r
-    } else {\r
-      password_text.setTextColor(android.R.color.black);\r
-    }\r
-    if (hasErrors) {\r
-      return;\r
-    }\r
-\r
-    int new_port = uri.getPort();\r
-    if (new_port == -1) {\r
-      if (mUseSSLConnection)\r
-        new_port = 443;\r
-      else\r
-        new_port = 80;\r
-    }\r
-\r
-    try {\r
-      uri = new URL(uri.getProtocol(), uri.getHost(), new_port, uri.getPath());\r
-    } catch (MalformedURLException e) {\r
-      e.printStackTrace(); // should not happend\r
-    }\r
-\r
-    showDialog(DIALOG_LOGIN_PROGRESS);\r
-    mAuthRunnable = new AuthenticationRunnable(\r
-        uri,\r
-        username_text.getText().toString(),\r
-        password_text.getText().toString());\r
-    mAuthRunnable.setOnAuthenticationResultListener(this, mHandler);\r
-    Log.e(TAG, uri.toString());\r
-    mAuthThread = new Thread(mAuthRunnable);\r
-    mAuthThread.start();\r
-  }\r
-\r
-  public void sslBadgeClick(View view, String val) {\r
-    mUseSSLConnection = ((TextView) view).getText().equals("SSL");\r
-  }\r
-\r
-  public void passwordBadgeClick(View view, String val) {\r
-    int input_type = InputType.TYPE_CLASS_TEXT;\r
-    input_type |= val.equals("Hide")\r
-                  ? InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD\r
-                  : InputType.TYPE_TEXT_VARIATION_PASSWORD;\r
-\r
-    ((TextView) view).setInputType(input_type);\r
-  }\r
-}\r