From 01268f3f82232e3328ae62af7396f4d47eec70c7 Mon Sep 17 00:00:00 2001 From: 6543 <6543@obermui.de> Date: Sat, 9 May 2020 01:03:46 +0200 Subject: [PATCH] Reformat LoginActivity.java --- .../mian/gitnex/activities/LoginActivity.java | 1162 ++++++++--------- 1 file changed, 561 insertions(+), 601 deletions(-) diff --git a/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java b/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java index c6866ee5..b0d692a0 100644 --- a/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java +++ b/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java @@ -46,850 +46,810 @@ import retrofit2.Callback; public class LoginActivity extends BaseActivity implements View.OnClickListener { - private Button loginButton; - private EditText instanceUrlET, loginUidET, loginPassword, otpCode, loginTokenCode; - private Spinner protocolSpinner; - private TextView otpInfo; - private RadioGroup loginMethod; - final Context ctx = this; - private Context appCtx; - private String device_id = "token"; - private ScrollView layoutView; + private Button loginButton; + private EditText instanceUrlET, loginUidET, loginPassword, otpCode, loginTokenCode; + private Spinner protocolSpinner; + private TextView otpInfo; + private RadioGroup loginMethod; + final Context ctx = this; + private Context appCtx; + private String device_id = "token"; + private ScrollView layoutView; - @Override - protected int getLayoutResourceId(){ - return R.layout.activity_login; - } + @Override + protected int getLayoutResourceId() { - @Override - public void onCreate(Bundle savedInstanceState) { + return R.layout.activity_login; + } - super.onCreate(savedInstanceState); - appCtx = getApplicationContext(); + @Override + public void onCreate(Bundle savedInstanceState) { - TinyDB tinyDb = new TinyDB(appCtx); - NetworkObserver networkMonitor = new NetworkObserver(this); + super.onCreate(savedInstanceState); + appCtx = getApplicationContext(); - loginButton = findViewById(R.id.login_button); - instanceUrlET = findViewById(R.id.instance_url); - loginUidET = findViewById(R.id.login_uid); - loginPassword = findViewById(R.id.login_passwd); - otpCode = findViewById(R.id.otpCode); - otpInfo = findViewById(R.id.otpInfo); - ImageView info_button = findViewById(R.id.info); - final TextView viewTextAppVersion = findViewById(R.id.appVersion); - protocolSpinner = findViewById(R.id.httpsSpinner); - loginMethod = findViewById(R.id.loginMethod); - loginTokenCode = findViewById(R.id.loginTokenCode); - layoutView = findViewById(R.id.loginForm); + TinyDB tinyDb = new TinyDB(appCtx); + NetworkObserver networkMonitor = new NetworkObserver(this); - viewTextAppVersion.setText(AppUtil.getAppVersion(appCtx)); + loginButton = findViewById(R.id.login_button); + instanceUrlET = findViewById(R.id.instance_url); + loginUidET = findViewById(R.id.login_uid); + loginPassword = findViewById(R.id.login_passwd); + otpCode = findViewById(R.id.otpCode); + otpInfo = findViewById(R.id.otpInfo); + ImageView info_button = findViewById(R.id.info); + final TextView viewTextAppVersion = findViewById(R.id.appVersion); + protocolSpinner = findViewById(R.id.httpsSpinner); + loginMethod = findViewById(R.id.loginMethod); + loginTokenCode = findViewById(R.id.loginTokenCode); + layoutView = findViewById(R.id.loginForm); - Resources res = getResources(); - String[] allProtocols = res.getStringArray(R.array.protocolValues); + viewTextAppVersion.setText(AppUtil.getAppVersion(appCtx)); - final ArrayAdapter adapterProtocols = new ArrayAdapter(LoginActivity.this, - R.layout.spinner_item, allProtocols); + Resources res = getResources(); + String[] allProtocols = res.getStringArray(R.array.protocolValues); - adapterProtocols.setDropDownViewResource(R.layout.spinner_dropdown_item); - protocolSpinner.setAdapter(adapterProtocols); + final ArrayAdapter adapterProtocols = new ArrayAdapter(LoginActivity.this, R.layout.spinner_item, allProtocols); - protocolSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { + adapterProtocols.setDropDownViewResource(R.layout.spinner_dropdown_item); + protocolSpinner.setAdapter(adapterProtocols); - public void onItemSelected(AdapterView parent, View view, int pos, long id) { + protocolSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { - String value = getResources().getStringArray(R.array.protocolValues)[pos]; - if(value.toLowerCase().equals("http")) { - SnackBar.warning(ctx, layoutView,getResources().getString(R.string.protocolError)); - } + public void onItemSelected(AdapterView parent, View view, int pos, long id) { - } + String value = getResources().getStringArray(R.array.protocolValues)[pos]; + if(value.toLowerCase().equals("http")) { + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.protocolError)); + } - public void onNothingSelected(AdapterView parent) { - } + } - }); + public void onNothingSelected(AdapterView parent) { - info_button.setOnClickListener(infoListener); + } - if(tinyDb.getString("loginType").equals("basic")) { // username/password + }); - loginMethod.check(R.id.loginUsernamePassword); + info_button.setOnClickListener(infoListener); - loginUidET.setVisibility(View.VISIBLE); - loginPassword.setVisibility(View.VISIBLE); - otpCode.setVisibility(View.VISIBLE); - otpInfo.setVisibility(View.VISIBLE); - loginTokenCode.setVisibility(View.GONE); + if(tinyDb.getString("loginType").equals("basic")) { // username/password - } - else { + loginMethod.check(R.id.loginUsernamePassword); - loginMethod.check(R.id.loginToken); + loginUidET.setVisibility(View.VISIBLE); + loginPassword.setVisibility(View.VISIBLE); + otpCode.setVisibility(View.VISIBLE); + otpInfo.setVisibility(View.VISIBLE); + loginTokenCode.setVisibility(View.GONE); - loginUidET.setVisibility(View.GONE); - loginPassword.setVisibility(View.GONE); - otpCode.setVisibility(View.GONE); - otpInfo.setVisibility(View.GONE); - loginTokenCode.setVisibility(View.VISIBLE); + } + else { - } + loginMethod.check(R.id.loginToken); - loginMethod.setOnCheckedChangeListener((group, checkedId) -> { + loginUidET.setVisibility(View.GONE); + loginPassword.setVisibility(View.GONE); + otpCode.setVisibility(View.GONE); + otpInfo.setVisibility(View.GONE); + loginTokenCode.setVisibility(View.VISIBLE); - if(checkedId == R.id.loginToken) { + } - loginUidET.setVisibility(View.GONE); - loginPassword.setVisibility(View.GONE); - otpCode.setVisibility(View.GONE); - otpInfo.setVisibility(View.GONE); - loginTokenCode.setVisibility(View.VISIBLE); + loginMethod.setOnCheckedChangeListener((group, checkedId) -> { - } - else { + if(checkedId == R.id.loginToken) { - loginUidET.setVisibility(View.VISIBLE); - loginPassword.setVisibility(View.VISIBLE); - otpCode.setVisibility(View.VISIBLE); - otpInfo.setVisibility(View.VISIBLE); - loginTokenCode.setVisibility(View.GONE); + loginUidET.setVisibility(View.GONE); + loginPassword.setVisibility(View.GONE); + otpCode.setVisibility(View.GONE); + otpInfo.setVisibility(View.GONE); + loginTokenCode.setVisibility(View.VISIBLE); - } + } + else { - }); + loginUidET.setVisibility(View.VISIBLE); + loginPassword.setVisibility(View.VISIBLE); + otpCode.setVisibility(View.VISIBLE); + otpInfo.setVisibility(View.VISIBLE); + loginTokenCode.setVisibility(View.GONE); - networkMonitor.onInternetStateListener(isAvailable -> { + } - if(isAvailable) { - enableProcessButton(); - SnackBar.success(ctx, layoutView, getResources().getString(R.string.netConnectionIsBack)); - } - else { - disableProcessButton(); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); - } + }); - }); + networkMonitor.onInternetStateListener(isAvailable -> { - //login_button.setOnClickListener(this); - if(!tinyDb.getString("instanceUrlRaw").isEmpty()) { - instanceUrlET.setText(tinyDb.getString("instanceUrlRaw")); - } - if(!tinyDb.getString("loginUid").isEmpty()) { - loginUidET.setText(tinyDb.getString("loginUid")); - } + if(isAvailable) { + enableProcessButton(); + SnackBar.success(ctx, layoutView, getResources().getString(R.string.netConnectionIsBack)); + } + else { + disableProcessButton(); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); + } - if(tinyDb.getBoolean("loggedInMode")) { + }); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + //login_button.setOnClickListener(this); + if(!tinyDb.getString("instanceUrlRaw").isEmpty()) { + instanceUrlET.setText(tinyDb.getString("instanceUrlRaw")); + } + if(!tinyDb.getString("loginUid").isEmpty()) { + loginUidET.setText(tinyDb.getString("loginUid")); + } - } + if(tinyDb.getBoolean("loggedInMode")) { - loginButton.setOnClickListener(loginListener); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - if(!tinyDb.getString("uniqueAppId").isEmpty()) { - device_id = tinyDb.getString("uniqueAppId"); - } - else { - device_id = UUID.randomUUID().toString(); - tinyDb.putString("uniqueAppId", device_id); - } + } - } + loginButton.setOnClickListener(loginListener); - @Override - public void onClick(View v) { + if(!tinyDb.getString("uniqueAppId").isEmpty()) { + device_id = tinyDb.getString("uniqueAppId"); + } + else { + device_id = UUID.randomUUID().toString(); + tinyDb.putString("uniqueAppId", device_id); + } - if (v.getId() == R.id.login_button) { - login(); - } + } - } + @Override + public void onClick(View v) { - private View.OnClickListener loginListener = new View.OnClickListener() { - public void onClick(View v) { + if(v.getId() == R.id.login_button) { + login(); + } - disableProcessButton(); - loginButton.setText(R.string.processingText); - login(); + } - } - }; + private View.OnClickListener loginListener = new View.OnClickListener() { - private View.OnClickListener infoListener = v -> new Tooltip.Builder(v) - .setText(R.string.urlInfoTooltip) - .setTextColor(getResources().getColor(R.color.white)) - .setBackgroundColor(getResources().getColor(R.color.tooltipBackground)) - .setCancelable(true) - .setDismissOnClick(true) - .setPadding(30) - .setCornerRadius(R.dimen.tooltipCornor) - .setGravity(Gravity.BOTTOM) - .show(); + public void onClick(View v) { - @SuppressLint("ResourceAsColor") - private void login() { + disableProcessButton(); + loginButton.setText(R.string.processingText); + login(); - TinyDB tinyDb = new TinyDB(appCtx); - AppUtil appUtil = new AppUtil(); - boolean connToInternet = AppUtil.haveNetworkConnection(LoginActivity.this); + } + }; - String instanceUrl = instanceUrlET.getText().toString().trim(); - String loginUid = loginUidET.getText().toString(); - String loginPass = loginPassword.getText().toString(); - String protocol = protocolSpinner.getSelectedItem().toString(); - String loginOTP_ = otpCode.getText().toString().trim(); - int loginMethodType = loginMethod.getCheckedRadioButtonId(); - String loginToken_ = loginTokenCode.getText().toString().trim(); + private View.OnClickListener infoListener = v -> new Tooltip.Builder(v).setText(R.string.urlInfoTooltip).setTextColor(getResources().getColor(R.color.white)).setBackgroundColor(getResources().getColor(R.color.tooltipBackground)).setCancelable(true).setDismissOnClick(true).setPadding(30).setCornerRadius(R.dimen.tooltipCornor).setGravity(Gravity.BOTTOM).show(); - if(loginMethodType == R.id.loginUsernamePassword) { + @SuppressLint("ResourceAsColor") + private void login() { - tinyDb.putString("loginType", "basic"); + TinyDB tinyDb = new TinyDB(appCtx); + AppUtil appUtil = new AppUtil(); + boolean connToInternet = AppUtil.haveNetworkConnection(LoginActivity.this); - if(instanceUrl.contains("@")) { + String instanceUrl = instanceUrlET.getText().toString().trim(); + String loginUid = loginUidET.getText().toString(); + String loginPass = loginPassword.getText().toString(); + String protocol = protocolSpinner.getSelectedItem().toString(); + String loginOTP_ = otpCode.getText().toString().trim(); + int loginMethodType = loginMethod.getCheckedRadioButtonId(); + String loginToken_ = loginTokenCode.getText().toString().trim(); - String[] urlForHttpAuth = instanceUrl.split("@"); + if(loginMethodType == R.id.loginUsernamePassword) { - tinyDb.putString("basicAuthPassword", loginPass); - tinyDb.putBoolean("basicAuthFlag", true); + tinyDb.putString("loginType", "basic"); - instanceUrl = urlForHttpAuth[1]; - loginUid = urlForHttpAuth[0]; + if(instanceUrl.contains("@")) { - } + String[] urlForHttpAuth = instanceUrl.split("@"); - String instanceHost; - if(AppUtil.httpCheck(instanceUrl)) { + tinyDb.putString("basicAuthPassword", loginPass); + tinyDb.putBoolean("basicAuthFlag", true); - URI uri = null; - try { - uri = new URI(instanceUrl); - } catch (URISyntaxException e) { - e.printStackTrace(); - } - assert uri != null; - instanceHost = uri.getHost(); + instanceUrl = urlForHttpAuth[1]; + loginUid = urlForHttpAuth[0]; - } - else { - instanceHost = instanceUrl; - } + } - String instanceUrlWithProtocol; - if(protocol.toLowerCase().equals("https")) { - instanceUrl = "https://" + instanceHost + "/api/v1/"; - instanceUrlWithProtocol = "https://" + instanceHost; - } - else { - instanceUrl = "http://" + instanceHost + "/api/v1/"; - instanceUrlWithProtocol = "http://" + instanceHost; - } + String instanceHost; + if(AppUtil.httpCheck(instanceUrl)) { - tinyDb.putString("instanceUrlRaw", instanceHost); - tinyDb.putString("loginUid", loginUid); - tinyDb.putString("instanceUrl", instanceUrl); - tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); + URI uri = null; + try { + uri = new URI(instanceUrl); + } + catch(URISyntaxException e) { + e.printStackTrace(); + } + assert uri != null; + instanceHost = uri.getHost(); - if(connToInternet) { + } + else { + instanceHost = instanceUrl; + } - if(instanceUrlET.getText().toString().equals("")) { + String instanceUrlWithProtocol; + if(protocol.toLowerCase().equals("https")) { + instanceUrl = "https://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "https://" + instanceHost; + } + else { + instanceUrl = "http://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "http://" + instanceHost; + } - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldURL)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + tinyDb.putString("instanceUrlRaw", instanceHost); + tinyDb.putString("loginUid", loginUid); + tinyDb.putString("instanceUrl", instanceUrl); + tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); - } - if(loginUid.equals("")) { + if(connToInternet) { - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldUsername)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + if(instanceUrlET.getText().toString().equals("")) { - } - if(loginPassword.getText().toString().equals("")) { + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldURL)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldPassword)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + } + if(loginUid.equals("")) { - } + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldUsername)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - int loginOTP = 0; - if(loginOTP_.length() == 6) { + } + if(loginPassword.getText().toString().equals("")) { - if(appUtil.checkIntegers(loginOTP_)) { + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldPassword)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - loginOTP = Integer.parseInt(loginOTP_); - } - else { + } - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.loginOTPTypeError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + int loginOTP = 0; + if(loginOTP_.length() == 6) { - } + if(appUtil.checkIntegers(loginOTP_)) { - } + loginOTP = Integer.parseInt(loginOTP_); + } + else { - versionCheck(instanceUrl, loginUid, loginPass, loginOTP, loginToken_, 1); + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.loginOTPTypeError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - } - else { + } - SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); + } - } + versionCheck(instanceUrl, loginUid, loginPass, loginOTP, loginToken_, 1); - } - else { + } + else { - tinyDb.putString("loginType", "token"); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); - String instanceHost; - if(AppUtil.httpCheck(instanceUrl)) { + } - URI uri = null; - try { - uri = new URI(instanceUrl); - } catch (URISyntaxException e) { - e.printStackTrace(); - } - assert uri != null; - instanceHost = uri.getHost(); + } + else { - } - else { - instanceHost = instanceUrl; - } - - String instanceUrlWithProtocol; - if(protocol.toLowerCase().equals("https")) { - instanceUrl = "https://" + instanceHost + "/api/v1/"; - instanceUrlWithProtocol = "https://" + instanceHost; - } - else { - instanceUrl = "http://" + instanceHost + "/api/v1/"; - instanceUrlWithProtocol = "http://" + instanceHost; - } + tinyDb.putString("loginType", "token"); - tinyDb.putString("instanceUrlRaw", instanceHost); - tinyDb.putString("instanceUrl", instanceUrl); - tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); + String instanceHost; + if(AppUtil.httpCheck(instanceUrl)) { - if(connToInternet) { + URI uri = null; + try { + uri = new URI(instanceUrl); + } + catch(URISyntaxException e) { + e.printStackTrace(); + } + assert uri != null; + instanceHost = uri.getHost(); - if (instanceUrlET.getText().toString().equals("")) { + } + else { + instanceHost = instanceUrl; + } - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldURL)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + String instanceUrlWithProtocol; + if(protocol.toLowerCase().equals("https")) { + instanceUrl = "https://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "https://" + instanceHost; + } + else { + instanceUrl = "http://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "http://" + instanceHost; + } - } - if (loginToken_.equals("")) { + tinyDb.putString("instanceUrlRaw", instanceHost); + tinyDb.putString("instanceUrl", instanceUrl); + tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); - SnackBar.warning(ctx, layoutView, getResources().getString(R.string.loginTokenError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + if(connToInternet) { - } + if(instanceUrlET.getText().toString().equals("")) { - versionCheck(instanceUrl, loginUid, loginPass, 123, loginToken_, 2); - } - else { + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.emptyFieldURL)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); + } + if(loginToken_.equals("")) { - } + SnackBar.warning(ctx, layoutView, getResources().getString(R.string.loginTokenError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - } + } - } + versionCheck(instanceUrl, loginUid, loginPass, 123, loginToken_, 2); + } + else { - private void versionCheck(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP, final String loginToken_, final int loginType) { + SnackBar.error(ctx, layoutView, getResources().getString(R.string.checkNetConnection)); - Call callVersion; - if (!loginToken_.isEmpty()) { - callVersion = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getGiteaVersionWithToken(loginToken_); - } - else { - final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); - if (loginOTP != 0) { - callVersion = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getGiteaVersionWithOTP(credential,loginOTP); - } - else { - callVersion = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getGiteaVersionWithBasic(credential); - } - } + } - callVersion.enqueue(new Callback() { + } - @Override - public void onResponse(@NonNull final Call callVersion, @NonNull retrofit2.Response responseVersion) { + } - if (responseVersion.code() == 200) { + private void versionCheck(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP, final String loginToken_, final int loginType) { - GiteaVersion version = responseVersion.body(); - assert version != null; + Call callVersion; + if(!loginToken_.isEmpty()) { + callVersion = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getGiteaVersionWithToken(loginToken_); + } + else { + final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); + if(loginOTP != 0) { + callVersion = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getGiteaVersionWithOTP(credential, loginOTP); + } + else { + callVersion = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getGiteaVersionWithBasic(credential); + } + } - // init - Version gitea_version = new Version(getString(R.string.versionLow)); - try { - gitea_version = new Version(version.getVersion()); - } catch(Error e) { - SnackBar.error(ctx, layoutView, getResources().getString(R.string.versionUnknow)); - enableProcessButton(); - } - //(getString(R.string.versionLow), getString(), version.getVersion()); + callVersion.enqueue(new Callback() { - // UNSUPPORTED_OLD - if (gitea_version.less(getString(R.string.versionLow))) { + @Override + public void onResponse(@NonNull final Call callVersion, @NonNull retrofit2.Response responseVersion) { - AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(ctx); + if(responseVersion.code() == 200) { - alertDialogBuilder - .setTitle(getString(R.string.versionAlertDialogHeader)) - .setMessage(getResources().getString(R.string.versionUnsupportedOld, version.getVersion())) - .setCancelable(true) - .setIcon(R.drawable.ic_warning) - .setNegativeButton(getString(R.string.cancelButton), (dialog, which) -> { + GiteaVersion version = responseVersion.body(); + assert version != null; - dialog.dismiss(); - enableProcessButton(); + // init + Version gitea_version = new Version(getString(R.string.versionLow)); + try { + gitea_version = new Version(version.getVersion()); + } + catch(Error e) { + SnackBar.error(ctx, layoutView, getResources().getString(R.string.versionUnknow)); + enableProcessButton(); + } + //(getString(R.string.versionLow), getString(), version.getVersion()); - }) - .setPositiveButton(getString(R.string.textContinue), (dialog, which) -> { + // UNSUPPORTED_OLD + if(gitea_version.less(getString(R.string.versionLow))) { - dialog.dismiss(); - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(ctx); - }); + alertDialogBuilder.setTitle(getString(R.string.versionAlertDialogHeader)).setMessage(getResources().getString(R.string.versionUnsupportedOld, version.getVersion())).setCancelable(true).setIcon(R.drawable.ic_warning).setNegativeButton(getString(R.string.cancelButton), (dialog, which) -> { - AlertDialog alertDialog = alertDialogBuilder.create(); + dialog.dismiss(); + enableProcessButton(); - alertDialog.show(); - return; + }).setPositiveButton(getString(R.string.textContinue), (dialog, which) -> { - } - // SUPPORTED - else if (gitea_version.lessOrEqual(getString(R.string.versionHigh))) { - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - return; - } - // UNSUPPORTED_NEW - else { - SnackBar.info(ctx, layoutView, getResources().getString(R.string.versionUnsupportedNew)); - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - return; - } + dialog.dismiss(); + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - } - else if (responseVersion.code() == 403) { + }); - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + AlertDialog alertDialog = alertDialogBuilder.create(); - } - } + alertDialog.show(); + return; - private void login(int loginType, String instanceUrl, String loginUid, String loginPass, int loginOTP, String loginToken_) { + } + // SUPPORTED + else if(gitea_version.lessOrEqual(getString(R.string.versionHigh))) { + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + return; + } + // UNSUPPORTED_NEW + else { + SnackBar.info(ctx, layoutView, getResources().getString(R.string.versionUnsupportedNew)); + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + return; + } - if (loginType == 1) { - letTheUserIn(instanceUrl, loginUid, loginPass, loginOTP); - } - else if (loginType == 2) { // token - letTheUserInViaToken(instanceUrl, loginToken_); - } + } + else if(responseVersion.code() == 403) { - } + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - @Override - public void onFailure(@NonNull Call callVersion, Throwable t) { + } + } - Log.e("onFailure-version", t.toString()); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.errorOnLogin)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + private void login(int loginType, String instanceUrl, String loginUid, String loginPass, int loginOTP, String loginToken_) { - } + if(loginType == 1) { + letTheUserIn(instanceUrl, loginUid, loginPass, loginOTP); + } + else if(loginType == 2) { // token + letTheUserInViaToken(instanceUrl, loginToken_); + } - }); + } - } + @Override + public void onFailure(@NonNull Call callVersion, Throwable t) { - private void letTheUserInViaToken(String instanceUrl, final String loginToken_) { + Log.e("onFailure-version", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.errorOnLogin)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - final TinyDB tinyDb = new TinyDB(appCtx); + } - Call call = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getUserInfo("token " + loginToken_); + }); - call.enqueue(new Callback() { + } - @Override - public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { + private void letTheUserInViaToken(String instanceUrl, final String loginToken_) { - UserInfo userDetails = response.body(); + final TinyDB tinyDb = new TinyDB(appCtx); - if (response.isSuccessful()) { + Call call = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getUserInfo("token " + loginToken_); - if (response.code() == 200) { + call.enqueue(new Callback() { - tinyDb.putBoolean("loggedInMode", true); - assert userDetails != null; - tinyDb.putString(userDetails.getLogin() + "-token", loginToken_); - tinyDb.putString("loginUid", userDetails.getLogin()); - tinyDb.putString("userLogin", userDetails.getUsername()); + @Override + public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + UserInfo userDetails = response.body(); - } + if(response.isSuccessful()) { - } - else if(response.code() == 401) { + if(response.code() == 200) { - SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + tinyDb.putBoolean("loggedInMode", true); + assert userDetails != null; + tinyDb.putString(userDetails.getLogin() + "-token", loginToken_); + tinyDb.putString("loginUid", userDetails.getLogin()); + tinyDb.putString("userLogin", userDetails.getUsername()); - } - else { + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } - } + } + else if(response.code() == 401) { - } + SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { + } + else { - Log.e("onFailure", t.toString()); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } - }); + } - } + } - private void letTheUserIn(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP) { + @Override + public void onFailure(@NonNull Call call, @NonNull Throwable t) { - final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); + Log.e("onFailure", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - Call> call; - if(loginOTP != 0) { + } + }); - call = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getUserTokensWithOTP(credential, loginOTP, loginUid); + } - } - else { + private void letTheUserIn(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP) { - call = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getUserTokens(credential, loginUid); + final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); - } + Call> call; + if(loginOTP != 0) { - call.enqueue(new Callback>() { + call = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getUserTokensWithOTP(credential, loginOTP, loginUid); - @Override - public void onResponse(@NonNull Call> call, @NonNull retrofit2.Response> response) { + } + else { - List userTokens = response.body(); - final TinyDB tinyDb = new TinyDB(appCtx); - final AppUtil appUtil = new AppUtil(); - //Headers responseHeaders = response.headers(); + call = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getUserTokens(credential, loginUid); - if (response.isSuccessful()) { + } - if (response.code() == 200) { + call.enqueue(new Callback>() { - boolean setTokenFlag = false; + @Override + public void onResponse(@NonNull Call> call, @NonNull retrofit2.Response> response) { - assert userTokens != null; - if (userTokens.size() > 0) { + List userTokens = response.body(); + final TinyDB tinyDb = new TinyDB(appCtx); + final AppUtil appUtil = new AppUtil(); + //Headers responseHeaders = response.headers(); - if(userTokens.get(0).getToken_last_eight() != null) { + if(response.isSuccessful()) { - for (int i = 0; i < userTokens.size(); i++) { - if (userTokens.get(i).getToken_last_eight().equals(tinyDb.getString(loginUid + "-token-last-eight"))) { - setTokenFlag = true; - break; - } - //Log.i("Tokens: ", userTokens.get(i).getToken_last_eight()); - } + if(response.code() == 200) { - } - else { + boolean setTokenFlag = false; - for (int i = 0; i < userTokens.size(); i++) { - if (userTokens.get(i).getSha1().equals(tinyDb.getString(loginUid + "-token"))) { - setTokenFlag = true; - break; - } - //Log.i("Tokens: ", userTokens.get(i).getSha1()); - } + assert userTokens != null; + if(userTokens.size() > 0) { - } + if(userTokens.get(0).getToken_last_eight() != null) { - } + for(int i = 0; i < userTokens.size(); i++) { + if(userTokens.get(i).getToken_last_eight().equals(tinyDb.getString(loginUid + "-token-last-eight"))) { + setTokenFlag = true; + break; + } + //Log.i("Tokens: ", userTokens.get(i).getToken_last_eight()); + } - if(tinyDb.getString(loginUid + "-token").isEmpty() || !setTokenFlag) { + } + else { - UserTokens createUserToken = new UserTokens("gitnex-app-" + device_id); + for(int i = 0; i < userTokens.size(); i++) { + if(userTokens.get(i).getSha1().equals(tinyDb.getString(loginUid + "-token"))) { + setTokenFlag = true; + break; + } + //Log.i("Tokens: ", userTokens.get(i).getSha1()); + } - Call callCreateToken; - if(loginOTP != 0) { + } - callCreateToken = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .createNewTokenWithOTP(credential, loginOTP, loginUid, createUserToken); + } - } - else { + if(tinyDb.getString(loginUid + "-token").isEmpty() || !setTokenFlag) { - callCreateToken = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .createNewToken(credential, loginUid, createUserToken); + UserTokens createUserToken = new UserTokens("gitnex-app-" + device_id); - } + Call callCreateToken; + if(loginOTP != 0) { - callCreateToken.enqueue(new Callback() { + callCreateToken = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().createNewTokenWithOTP(credential, loginOTP, loginUid, createUserToken); - @Override - public void onResponse(@NonNull Call callCreateToken, @NonNull retrofit2.Response responseCreate) { + } + else { - if(responseCreate.isSuccessful()) { + callCreateToken = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().createNewToken(credential, loginUid, createUserToken); - if(responseCreate.code() == 201) { + } - UserTokens newToken = responseCreate.body(); - assert newToken != null; - //Log.i("Tokens-NEW", "new:" + newToken.getSha1()); + callCreateToken.enqueue(new Callback() { - if (!newToken.getSha1().equals("")) { + @Override + public void onResponse(@NonNull Call callCreateToken, @NonNull retrofit2.Response responseCreate) { - Call call = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getUserInfo("token " + newToken.getSha1()); + if(responseCreate.isSuccessful()) { - call.enqueue(new Callback() { + if(responseCreate.code() == 201) { - @Override - public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { + UserTokens newToken = responseCreate.body(); + assert newToken != null; + //Log.i("Tokens-NEW", "new:" + newToken.getSha1()); - UserInfo userDetails = response.body(); + if(!newToken.getSha1().equals("")) { - if (response.isSuccessful()) { + Call call = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getUserInfo("token " + newToken.getSha1()); - if (response.code() == 200) { + call.enqueue(new Callback() { - tinyDb.remove("loginPass"); - tinyDb.putBoolean("loggedInMode", true); - assert userDetails != null; - tinyDb.putString("userLogin", userDetails.getUsername()); - tinyDb.putString(loginUid + "-token", newToken.getSha1()); - tinyDb.putString(loginUid + "-token-last-eight", appUtil.getLastCharactersOfWord(newToken.getSha1(), 8)); + @Override + public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + UserInfo userDetails = response.body(); - } + if(response.isSuccessful()) { - } - else if(response.code() == 401) { + if(response.code() == 200) { - SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + tinyDb.remove("loginPass"); + tinyDb.putBoolean("loggedInMode", true); + assert userDetails != null; + tinyDb.putString("userLogin", userDetails.getUsername()); + tinyDb.putString(loginUid + "-token", newToken.getSha1()); + tinyDb.putString(loginUid + "-token-last-eight", appUtil.getLastCharactersOfWord(newToken.getSha1(), 8)); - } - else { + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } - } + } + else if(response.code() == 401) { - } + SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { + } + else { - Log.e("onFailure", t.toString()); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } - }); + } - } + } - } + @Override + public void onFailure(@NonNull Call call, @NonNull Throwable t) { - } - else if(responseCreate.code() == 500) { + Log.e("onFailure", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - SnackBar.error(ctx, layoutView,getResources().getString(R.string.genericApiStatusError) + responseCreate.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } + }); - } + } - } + } - @Override - public void onFailure(@NonNull Call createUserToken, @NonNull Throwable t) { + } + else if(responseCreate.code() == 500) { - Log.e("onFailure-token", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + responseCreate.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } + } - }); - } - else { + } - String instanceToken = "token " + tinyDb.getString(loginUid + "-token"); + @Override + public void onFailure(@NonNull Call createUserToken, @NonNull Throwable t) { - Call callGetUsername = RetrofitClient - .getInstance(instanceUrl, ctx) - .getApiInterface() - .getUserInfo(instanceToken); + Log.e("onFailure-token", t.toString()); - callGetUsername.enqueue(new Callback() { + } - @Override - public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { + }); + } + else { - UserInfo userDetails = response.body(); + String instanceToken = "token " + tinyDb.getString(loginUid + "-token"); - if (response.isSuccessful()) { + Call callGetUsername = RetrofitClient.getInstance(instanceUrl, ctx).getApiInterface().getUserInfo(instanceToken); - if (response.code() == 200) { + callGetUsername.enqueue(new Callback() { - assert userDetails != null; - tinyDb.putString("userLogin", userDetails.getUsername()); + @Override + public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { - tinyDb.putBoolean("loggedInMode", true); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + UserInfo userDetails = response.body(); - } + if(response.isSuccessful()) { - } - else if(response.code() == 401) { + if(response.code() == 200) { - SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + assert userDetails != null; + tinyDb.putString("userLogin", userDetails.getUsername()); - } - else { + tinyDb.putBoolean("loggedInMode", true); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } - } + } + else if(response.code() == 401) { - } + SnackBar.error(ctx, layoutView, getResources().getString(R.string.unauthorizedApiError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { + } + else { - Log.e("onFailure", t.toString()); - SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } - }); + } - } + } - } + @Override + public void onFailure(@NonNull Call call, @NonNull Throwable t) { - } - else if(response.code() == 500) { + Log.e("onFailure", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - SnackBar.error(ctx, layoutView,getResources().getString(R.string.genericApiStatusError) + response.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } + }); - } - else { + } - SnackBar.error(ctx, layoutView,getResources().getString(R.string.genericApiStatusError) + response.code()); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } - } + } + else if(response.code() == 500) { - } + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - @Override - public void onFailure(@NonNull Call> call, @NonNull Throwable t) { + } + else { - Log.e("onFailure-login", t.toString()); - SnackBar.error(ctx, layoutView,getResources().getString(R.string.malformedJson)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.genericApiStatusError) + response.code()); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } - }); + } - } + } - private void disableProcessButton() { + @Override + public void onFailure(@NonNull Call> call, @NonNull Throwable t) { - loginButton.setEnabled(false); - GradientDrawable shape = new GradientDrawable(); - shape.setCornerRadius( 8 ); - shape.setColor(getResources().getColor(R.color.hintColor)); - loginButton.setBackground(shape); + Log.e("onFailure-login", t.toString()); + SnackBar.error(ctx, layoutView, getResources().getString(R.string.malformedJson)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } + } + }); - private void enableProcessButton() { + } - loginButton.setEnabled(true); - GradientDrawable shape = new GradientDrawable(); - shape.setCornerRadius( 8 ); - shape.setColor(getResources().getColor(R.color.btnBackground)); - loginButton.setBackground(shape); + private void disableProcessButton() { - } + loginButton.setEnabled(false); + GradientDrawable shape = new GradientDrawable(); + shape.setCornerRadius(8); + shape.setColor(getResources().getColor(R.color.hintColor)); + loginButton.setBackground(shape); + + } + + private void enableProcessButton() { + + loginButton.setEnabled(true); + GradientDrawable shape = new GradientDrawable(); + shape.setCornerRadius(8); + shape.setColor(getResources().getColor(R.color.btnBackground)); + loginButton.setBackground(shape); + + } }