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 337ac401..71f44827 100644 --- a/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java +++ b/app/src/main/java/org/mian/gitnex/activities/LoginActivity.java @@ -48,698 +48,678 @@ 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 String device_id = "token"; + private Button loginButton; + private EditText instanceUrlET, loginUidET, loginPassword, otpCode, loginTokenCode; + private Spinner protocolSpinner; + private TextView otpInfo; + private RadioGroup loginMethod; + final Context ctx = this; + private String device_id = "token"; - @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); + @Override + public void onCreate(Bundle savedInstanceState) { - TinyDB tinyDb = new TinyDB(getApplicationContext()); - NetworkObserver networkMonitor = new NetworkObserver(this); + super.onCreate(savedInstanceState); - 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); + TinyDB tinyDb = new TinyDB(getApplicationContext()); + NetworkObserver networkMonitor = new NetworkObserver(this); - viewTextAppVersion.setText(AppUtil.getAppVersion(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); - Resources res = getResources(); - String[] allProtocols = res.getStringArray(R.array.protocolValues); + viewTextAppVersion.setText(AppUtil.getAppVersion(getApplicationContext())); - final ArrayAdapter adapterProtocols = new ArrayAdapter(Objects.requireNonNull(getApplicationContext()), - 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(Objects.requireNonNull(getApplicationContext()), R.layout.spinner_item, allProtocols); - protocolSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { - public void onItemSelected(AdapterView parent, View view, int pos, long id) { + adapterProtocols.setDropDownViewResource(R.layout.spinner_dropdown_item); + protocolSpinner.setAdapter(adapterProtocols); - String value = getResources().getStringArray(R.array.protocolValues)[pos]; - if(value.toLowerCase().equals("http")) { - Toasty.info(getApplicationContext(), getResources().getString(R.string.protocolError)); - } - - } - public void onNothingSelected(AdapterView parent) { - } - }); - - info_button.setOnClickListener(infoListener); + protocolSpinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() { - loginMethod.setOnCheckedChangeListener((group, checkedId) -> { - - if(checkedId == R.id.loginToken) { + public void onItemSelected(AdapterView parent, View view, int pos, long id) { - 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); + String value = getResources().getStringArray(R.array.protocolValues)[pos]; + if(value.toLowerCase().equals("http")) { + Toasty.info(getApplicationContext(), getResources().getString(R.string.protocolError)); + } - } + } - }); + public void onNothingSelected(AdapterView parent) { - networkMonitor.onInternetStateListener(isAvailable -> { + } + }); - if(isAvailable) { - enableProcessButton(); - } - else { - disableProcessButton(); - Toasty.info(getApplicationContext(), getResources().getString(R.string.checkNetConnection)); - } + info_button.setOnClickListener(infoListener); - }); + loginMethod.setOnCheckedChangeListener((group, checkedId) -> { - //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(checkedId == R.id.loginToken) { - if(tinyDb.getBoolean("loggedInMode")) { + loginUidET.setVisibility(View.GONE); + loginPassword.setVisibility(View.GONE); + otpCode.setVisibility(View.GONE); + otpInfo.setVisibility(View.GONE); + loginTokenCode.setVisibility(View.VISIBLE); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + } + else { - } - - loginButton.setOnClickListener(loginListener); + loginUidET.setVisibility(View.VISIBLE); + loginPassword.setVisibility(View.VISIBLE); + otpCode.setVisibility(View.VISIBLE); + otpInfo.setVisibility(View.VISIBLE); + loginTokenCode.setVisibility(View.GONE); - if(!tinyDb.getString("uniqueAppId").isEmpty()) { - device_id = tinyDb.getString("uniqueAppId"); - } - else { - device_id = UUID.randomUUID().toString(); - tinyDb.putString("uniqueAppId", device_id); - } - - } + } - @Override - public void onClick(View v) { - - if (v.getId() == R.id.login_button) { - login(); - } + }); - } + networkMonitor.onInternetStateListener(isAvailable -> { - private View.OnClickListener loginListener = new View.OnClickListener() { - public void onClick(View v) { + if(isAvailable) { + enableProcessButton(); + } + else { + disableProcessButton(); + Toasty.info(getApplicationContext(), getResources().getString(R.string.checkNetConnection)); + } - disableProcessButton(); - loginButton.setText(R.string.processingText); - login(); + }); - } - }; + //login_button.setOnClickListener(this); + if(!tinyDb.getString("instanceUrlRaw").isEmpty()) { + instanceUrlET.setText(tinyDb.getString("instanceUrlRaw")); + } + if(!tinyDb.getString("loginUid").isEmpty()) { + loginUidET.setText(tinyDb.getString("loginUid")); + } - private View.OnClickListener infoListener = new View.OnClickListener() { - public void onClick(View 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(tinyDb.getBoolean("loggedInMode")) { - @SuppressLint("ResourceAsColor") - private void login() { + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - TinyDB tinyDb = new TinyDB(getApplicationContext()); - 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(); + loginButton.setOnClickListener(loginListener); - if(loginMethodType == R.id.loginUsernamePassword) { + if(!tinyDb.getString("uniqueAppId").isEmpty()) { + device_id = tinyDb.getString("uniqueAppId"); + } + else { + device_id = UUID.randomUUID().toString(); + tinyDb.putString("uniqueAppId", device_id); + } - if(instanceUrl.contains("@")) { + } - String[] urlForHttpAuth = instanceUrl.split("@"); + @Override + public void onClick(View v) { - tinyDb.putString("basicAuthPassword", loginPass); - tinyDb.putBoolean("basicAuthFlag", true); + if(v.getId() == R.id.login_button) { + login(); + } - instanceUrl = urlForHttpAuth[1]; - loginUid = urlForHttpAuth[0]; + } - } + private View.OnClickListener loginListener = new View.OnClickListener() { - String instanceHost; - if(AppUtil.httpCheck(instanceUrl)) { + public void onClick(View v) { - URI uri = null; - try { - uri = new URI(instanceUrl); - } catch (URISyntaxException e) { - e.printStackTrace(); - } - assert uri != null; - instanceHost = uri.getHost(); + disableProcessButton(); + loginButton.setText(R.string.processingText); + login(); - } - 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; - } + private View.OnClickListener infoListener = new View.OnClickListener() { - tinyDb.putString("instanceUrlRaw", instanceHost); - tinyDb.putString("loginUid", loginUid); - tinyDb.putString("instanceUrl", instanceUrl); - tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); + public void onClick(View v) { - if(connToInternet) { + 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(instanceUrlET.getText().toString().equals("")) { + @SuppressLint("ResourceAsColor") + private void login() { - Toasty.info(getApplicationContext(), getString(R.string.emptyFieldURL)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + TinyDB tinyDb = new TinyDB(getApplicationContext()); + AppUtil appUtil = new AppUtil(); + boolean connToInternet = AppUtil.haveNetworkConnection(LoginActivity.this); - } - if(loginUid.equals("")) { + 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(); - Toasty.info(getApplicationContext(), getString(R.string.emptyFieldUsername)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + if(loginMethodType == R.id.loginUsernamePassword) { - } - if(loginPassword.getText().toString().equals("")) { + if(instanceUrl.contains("@")) { - Toasty.info(getApplicationContext(), getString(R.string.emptyFieldPassword)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + String[] urlForHttpAuth = instanceUrl.split("@"); - } + tinyDb.putString("basicAuthPassword", loginPass); + tinyDb.putBoolean("basicAuthFlag", true); - int loginOTP = 0; - if(loginOTP_.length() == 6) { + instanceUrl = urlForHttpAuth[1]; + loginUid = urlForHttpAuth[0]; - if(appUtil.checkIntegers(loginOTP_)) { + } - loginOTP = Integer.parseInt(loginOTP_); - } - else { + String instanceHost; + if(AppUtil.httpCheck(instanceUrl)) { - Toasty.info(getApplicationContext(), getString(R.string.loginOTPTypeError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + URI uri = null; + try { + uri = new URI(instanceUrl); + } + catch(URISyntaxException e) { + e.printStackTrace(); + } + assert uri != null; + instanceHost = uri.getHost(); - } + } + 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; + } - versionCheck(instanceUrl, loginUid, loginPass, loginOTP, loginToken_, 1); + tinyDb.putString("instanceUrlRaw", instanceHost); + tinyDb.putString("loginUid", loginUid); + tinyDb.putString("instanceUrl", instanceUrl); + tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); - } - else { + if(connToInternet) { - Toasty.info(getApplicationContext(), getString(R.string.checkNetConnection)); + if(instanceUrlET.getText().toString().equals("")) { - } + Toasty.info(getApplicationContext(), getString(R.string.emptyFieldURL)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - } - else { + } + if(loginUid.equals("")) { - String instanceHost; - if(AppUtil.httpCheck(instanceUrl)) { + Toasty.info(getApplicationContext(), getString(R.string.emptyFieldUsername)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - URI uri = null; - try { - uri = new URI(instanceUrl); - } catch (URISyntaxException e) { - e.printStackTrace(); - } - assert uri != null; - instanceHost = uri.getHost(); + } + if(loginPassword.getText().toString().equals("")) { - } - else { - instanceHost = instanceUrl; - } + Toasty.info(getApplicationContext(), getString(R.string.emptyFieldPassword)); + 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; - } + } - tinyDb.putString("instanceUrlRaw", instanceHost); - //tinyDb.putString("loginUid", loginUid); - tinyDb.putString("instanceUrl", instanceUrl); - tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); + int loginOTP = 0; + if(loginOTP_.length() == 6) { - if(connToInternet) { + if(appUtil.checkIntegers(loginOTP_)) { - if (instanceUrlET.getText().toString().equals("")) { + loginOTP = Integer.parseInt(loginOTP_); + } + else { - Toasty.info(getApplicationContext(), getString(R.string.emptyFieldURL)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + Toasty.info(getApplicationContext(), getString(R.string.loginOTPTypeError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - } - if (loginToken_.equals("")) { + } - Toasty.info(getApplicationContext(), getString(R.string.loginTokenError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - return; + } - } + versionCheck(instanceUrl, loginUid, loginPass, loginOTP, loginToken_, 1); - versionCheck(instanceUrl, loginUid, loginPass, 123, loginToken_, 2); - } - else { + } + else { - Toasty.info(getApplicationContext(), getString(R.string.checkNetConnection)); + Toasty.info(getApplicationContext(), getString(R.string.checkNetConnection)); - } + } - } + } + else { - } + String instanceHost; + if(AppUtil.httpCheck(instanceUrl)) { - private void versionCheck(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP, final String loginToken_, final int loginType) { + URI uri = null; + try { + uri = new URI(instanceUrl); + } + catch(URISyntaxException e) { + e.printStackTrace(); + } + assert uri != null; + instanceHost = uri.getHost(); - final TinyDB tinyDb = new TinyDB(getApplicationContext()); + } + else { + instanceHost = instanceUrl; + } - Call callVersion = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .getGiteaVersion(); + String instanceUrlWithProtocol; + if(protocol.toLowerCase().equals("https")) { + instanceUrl = "https://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "https://" + instanceHost; + } + else { + instanceUrl = "http://" + instanceHost + "/api/v1/"; + instanceUrlWithProtocol = "http://" + instanceHost; + } - callVersion.enqueue(new Callback() { + tinyDb.putString("instanceUrlRaw", instanceHost); + //tinyDb.putString("loginUid", loginUid); + tinyDb.putString("instanceUrl", instanceUrl); + tinyDb.putString("instanceUrlWithProtocol", instanceUrlWithProtocol); - @Override - public void onResponse(@NonNull final Call callVersion, @NonNull retrofit2.Response responseVersion) { + if(connToInternet) { - if (responseVersion.code() == 200) { + if(instanceUrlET.getText().toString().equals("")) { - GiteaVersion version = responseVersion.body(); - assert version != null; + Toasty.info(getApplicationContext(), getString(R.string.emptyFieldURL)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - VersionCheck vt = VersionCheck.check(getString(R.string.versionLow), getString(R.string.versionHigh), version.getVersion()); + } + if(loginToken_.equals("")) { - switch (vt) { - case UNSUPPORTED_NEW: - //Toasty.info(getApplicationContext(), getString(R.string.versionUnsupportedNew)); - case SUPPORTED_LATEST: - case SUPPORTED_OLD: - case DEVELOPMENT: - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - return; - case UNSUPPORTED_OLD: + Toasty.info(getApplicationContext(), getString(R.string.loginTokenError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + return; - 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), new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { - dialog.dismiss(); - enableProcessButton(); - } - }) - .setPositiveButton(getString(R.string.textContinue), new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { + versionCheck(instanceUrl, loginUid, loginPass, 123, loginToken_, 2); + } + else { - dialog.dismiss(); - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + Toasty.info(getApplicationContext(), getString(R.string.checkNetConnection)); - } - }); + } - AlertDialog alertDialog = alertDialogBuilder.create(); + } - alertDialog.show(); - return; - default: // UNKNOWN - Toasty.info(getApplicationContext(), getString(R.string.versionUnknow)); - enableProcessButton(); + } - } + private void versionCheck(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP, final String loginToken_, final int loginType) { - } - else if (responseVersion.code() == 403) { - login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - } - } + final TinyDB tinyDb = new TinyDB(getApplicationContext()); - 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_); - } - } + Call callVersion = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().getGiteaVersion(); - @Override - public void onFailure(@NonNull Call callVersion, Throwable t) { + callVersion.enqueue(new Callback() { - Log.e("onFailure-version", t.toString()); + @Override + public void onResponse(@NonNull final Call callVersion, @NonNull retrofit2.Response responseVersion) { - if(t instanceof NoRouteToHostException) { - Toasty.info(getApplicationContext(), "Could not connect to host. Please check your url or port " + - "for issues."); - } - else { - Toasty.info(getApplicationContext(), getResources().getString(R.string.commentError)); - } + if(responseVersion.code() == 200) { - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + GiteaVersion version = responseVersion.body(); + assert version != null; - } + VersionCheck vt = VersionCheck.check(getString(R.string.versionLow), getString(R.string.versionHigh), version.getVersion()); - }); + switch(vt) { + case UNSUPPORTED_NEW: + //Toasty.info(getApplicationContext(), getString(R.string.versionUnsupportedNew)); + case SUPPORTED_LATEST: + case SUPPORTED_OLD: + case DEVELOPMENT: + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + return; + case UNSUPPORTED_OLD: - } + AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(ctx); - private void letTheUserInViaToken(String instanceUrl, final String loginToken_) { + 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), new DialogInterface.OnClickListener() { - final TinyDB tinyDb = new TinyDB(getApplicationContext()); + @Override + public void onClick(DialogInterface dialog, int which) { - Call call = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .getUserInfo("token " + loginToken_); + dialog.dismiss(); + enableProcessButton(); + } + }).setPositiveButton(getString(R.string.textContinue), new DialogInterface.OnClickListener() { - call.enqueue(new Callback() { + @Override + public void onClick(DialogInterface dialog, int which) { - @Override - public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { + dialog.dismiss(); + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); - UserInfo userDetails = response.body(); + } + }); - if (response.isSuccessful()) { + AlertDialog alertDialog = alertDialogBuilder.create(); - if (response.code() == 200) { + alertDialog.show(); + return; + default: // UNKNOWN + Toasty.info(getApplicationContext(), getString(R.string.versionUnknow)); + enableProcessButton(); - tinyDb.putBoolean("loggedInMode", true); - assert userDetails != null; - tinyDb.putString(userDetails.getLogin() + "-token", loginToken_); - tinyDb.putString("loginUid", userDetails.getLogin()); + } - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + } + else if(responseVersion.code() == 403) { + login(loginType, instanceUrl, loginUid, loginPass, loginOTP, loginToken_); + } + } - } + private void login(int loginType, String instanceUrl, String loginUid, String loginPass, int loginOTP, String loginToken_) { - } - else if(response.code() == 401) { + if(loginType == 1) { + letTheUserIn(instanceUrl, loginUid, loginPass, loginOTP); + } + else if(loginType == 2) { // token + letTheUserInViaToken(instanceUrl, loginToken_); + } + } - String toastError = getResources().getString(R.string.unauthorizedApiError); - Toasty.info(getApplicationContext(), toastError); + @Override + public void onFailure(@NonNull Call callVersion, Throwable t) { - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + Log.e("onFailure-version", t.toString()); - } - else { + if(t instanceof NoRouteToHostException) { + Toasty.info(getApplicationContext(), "Could not connect to host. Please check your url or port " + "for issues."); + } + else { + Toasty.info(getApplicationContext(), getResources().getString(R.string.commentError)); + } - String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); - Toasty.info(getApplicationContext(), toastError); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + } - } + }); - } + } - @Override - public void onFailure(@NonNull Call call, @NonNull Throwable t) { - Log.e("onFailure", t.toString()); - Toasty.info(getApplicationContext(), getResources().getString(R.string.genericError)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - } - }); + private void letTheUserInViaToken(String instanceUrl, final String loginToken_) { - } + final TinyDB tinyDb = new TinyDB(getApplicationContext()); - private void letTheUserIn(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP) { + Call call = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().getUserInfo("token " + loginToken_); - final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); + call.enqueue(new Callback() { - Call> call; - if(loginOTP != 0) { - call = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .getUserTokensWithOTP(credential, loginOTP, loginUid); - } - else { - call = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .getUserTokens(credential, loginUid); - } + @Override + public void onResponse(@NonNull Call call, @NonNull retrofit2.Response response) { - call.enqueue(new Callback>() { + UserInfo userDetails = response.body(); - @Override - public void onResponse(@NonNull Call> call, @NonNull retrofit2.Response> response) { + if(response.isSuccessful()) { - List userTokens = response.body(); - final TinyDB tinyDb = new TinyDB(getApplicationContext()); - final AppUtil appUtil = new AppUtil(); - //Headers responseHeaders = response.headers(); + if(response.code() == 200) { - if (response.isSuccessful()) { + tinyDb.putBoolean("loggedInMode", true); + assert userDetails != null; + tinyDb.putString(userDetails.getLogin() + "-token", loginToken_); + tinyDb.putString("loginUid", userDetails.getLogin()); - if (response.code() == 200) { + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - boolean setTokenFlag = false; + } - assert userTokens != null; - if (userTokens.size() > 0) { + } + else if(response.code() == 401) { - if(userTokens.get(0).getToken_last_eight() != null) { + String toastError = getResources().getString(R.string.unauthorizedApiError); + Toasty.info(getApplicationContext(), toastError); - 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()); - } + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } - else { + } + else { - 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()); - } + String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); + Toasty.info(getApplicationContext(), toastError); - } + enableProcessButton(); + loginButton.setText(R.string.btnLogin); - } + } - if(tinyDb.getString(loginUid + "-token").isEmpty() || !setTokenFlag) { + } - UserTokens createUserToken = new UserTokens("gitnex-app-" + device_id); + @Override + public void onFailure(@NonNull Call call, @NonNull Throwable t) { - Call callCreateToken; - if(loginOTP != 0) { - callCreateToken = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .createNewTokenWithOTP(credential, loginOTP, loginUid, createUserToken); - } - else { - callCreateToken = RetrofitClient - .getInstance(instanceUrl, getApplicationContext()) - .getApiInterface() - .createNewToken(credential, loginUid, createUserToken); - } + Log.e("onFailure", t.toString()); + Toasty.info(getApplicationContext(), getResources().getString(R.string.genericError)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + } + }); - callCreateToken.enqueue(new Callback() { + } - @Override - public void onResponse(@NonNull Call callCreateToken, @NonNull retrofit2.Response responseCreate) { + private void letTheUserIn(final String instanceUrl, final String loginUid, final String loginPass, final int loginOTP) { - if(responseCreate.isSuccessful()) { + final String credential = Credentials.basic(loginUid, loginPass, StandardCharsets.UTF_8); - if(responseCreate.code() == 201) { + Call> call; + if(loginOTP != 0) { + call = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().getUserTokensWithOTP(credential, loginOTP, loginUid); + } + else { + call = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().getUserTokens(credential, loginUid); + } - UserTokens newToken = responseCreate.body(); - assert newToken != null; - //Log.i("Tokens-NEW", "new:" + newToken.getSha1()); + call.enqueue(new Callback>() { - if (!newToken.getSha1().equals("")) { + @Override + public void onResponse(@NonNull Call> call, @NonNull retrofit2.Response> response) { - tinyDb.remove("loginPass"); - tinyDb.putBoolean("loggedInMode", true); - tinyDb.putString(loginUid + "-token", newToken.getSha1()); - tinyDb.putString(loginUid + "-token-last-eight", appUtil.getLastCharactersOfWord(newToken.getSha1(), 8)); - //Log.i("Tokens", "new:" + newToken.getSha1() + " old:" + tinyDb.getString(loginUid + "-token")); + List userTokens = response.body(); + final TinyDB tinyDb = new TinyDB(getApplicationContext()); + final AppUtil appUtil = new AppUtil(); + //Headers responseHeaders = response.headers(); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + if(response.isSuccessful()) { - } + if(response.code() == 200) { - } + boolean setTokenFlag = false; - } - else if(responseCreate.code() == 500) { + assert userTokens != null; + if(userTokens.size() > 0) { - String toastError = getResources().getString(R.string.genericApiStatusError) + responseCreate.code(); - Toasty.info(getApplicationContext(), toastError); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + 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()); + } - } + } + else { - @Override - public void onFailure(@NonNull Call createUserToken, Throwable t) { + 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()); + } - } + } - }); - } - else { + } - //Log.i("Current Token", tinyDb.getString(loginUid + "-token")); - tinyDb.putBoolean("loggedInMode", true); - startActivity(new Intent(LoginActivity.this, MainActivity.class)); - finish(); + if(tinyDb.getString(loginUid + "-token").isEmpty() || !setTokenFlag) { - } + UserTokens createUserToken = new UserTokens("gitnex-app-" + device_id); - } + Call callCreateToken; + if(loginOTP != 0) { + callCreateToken = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().createNewTokenWithOTP(credential, loginOTP, loginUid, createUserToken); + } + else { + callCreateToken = RetrofitClient.getInstance(instanceUrl, getApplicationContext()).getApiInterface().createNewToken(credential, loginUid, createUserToken); + } - } - else if(response.code() == 500) { + callCreateToken.enqueue(new Callback() { - String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); - Toasty.info(getApplicationContext(), toastError); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + @Override + public void onResponse(@NonNull Call callCreateToken, @NonNull retrofit2.Response responseCreate) { - } - else { + if(responseCreate.isSuccessful()) { - String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); - //Log.i("error message else4", String.valueOf(response.code())); + if(responseCreate.code() == 201) { - Toasty.info(getApplicationContext(), toastError); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); + UserTokens newToken = responseCreate.body(); + assert newToken != null; + //Log.i("Tokens-NEW", "new:" + newToken.getSha1()); - } + if(!newToken.getSha1().equals("")) { - } + tinyDb.remove("loginPass"); + tinyDb.putBoolean("loggedInMode", true); + tinyDb.putString(loginUid + "-token", newToken.getSha1()); + tinyDb.putString(loginUid + "-token-last-eight", appUtil.getLastCharactersOfWord(newToken.getSha1(), 8)); + //Log.i("Tokens", "new:" + newToken.getSha1() + " old:" + tinyDb.getString(loginUid + "-token")); - @Override - public void onFailure(@NonNull Call> call, @NonNull Throwable t) { - Log.e("onFailure-login", t.toString()); - Toasty.info(getApplicationContext(), getResources().getString(R.string.malformedJson)); - enableProcessButton(); - loginButton.setText(R.string.btnLogin); - } - }); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); - } + } - private void disableProcessButton() { + } - loginButton.setEnabled(false); - GradientDrawable shape = new GradientDrawable(); - shape.setCornerRadius( 8 ); - shape.setColor(getResources().getColor(R.color.hintColor)); - loginButton.setBackground(shape); + } + else if(responseCreate.code() == 500) { - } + String toastError = getResources().getString(R.string.genericApiStatusError) + responseCreate.code(); + Toasty.info(getApplicationContext(), toastError); + 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); + } - } + @Override + public void onFailure(@NonNull Call createUserToken, Throwable t) { + + } + + }); + } + else { + + //Log.i("Current Token", tinyDb.getString(loginUid + "-token")); + tinyDb.putBoolean("loggedInMode", true); + startActivity(new Intent(LoginActivity.this, MainActivity.class)); + finish(); + + } + + } + + } + else if(response.code() == 500) { + + String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); + Toasty.info(getApplicationContext(), toastError); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + + } + else { + + String toastError = getResources().getString(R.string.genericApiStatusError) + response.code(); + //Log.i("error message else4", String.valueOf(response.code())); + + Toasty.info(getApplicationContext(), toastError); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + + } + + } + + @Override + public void onFailure(@NonNull Call> call, @NonNull Throwable t) { + + Log.e("onFailure-login", t.toString()); + Toasty.info(getApplicationContext(), getResources().getString(R.string.malformedJson)); + enableProcessButton(); + loginButton.setText(R.string.btnLogin); + } + }); + + } + + 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); + + } }