X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Futils%2FNetworkUtil.java;h=c9f0151ba4b84b12175bbf828eb425e7607c07f8;hb=f973784f579d42988174acf0b24593aa23180fa6;hp=44a7eb9db579a539388aaf83ad38c7da708d5857;hpb=7d6fd4b4e3bfc08ee9c72a1d595b284df2517e59;p=mobile-ledger.git
diff --git a/app/src/main/java/net/ktnx/mobileledger/utils/NetworkUtil.java b/app/src/main/java/net/ktnx/mobileledger/utils/NetworkUtil.java
index 44a7eb9d..c9f0151b 100644
--- a/app/src/main/java/net/ktnx/mobileledger/utils/NetworkUtil.java
+++ b/app/src/main/java/net/ktnx/mobileledger/utils/NetworkUtil.java
@@ -1,46 +1,50 @@
/*
- * Copyright © 2018 Damyan Ivanov.
- * This file is part of Mobile-Ledger.
- * Mobile-Ledger is free software: you can distribute it and/or modify it
+ * Copyright © 2020 Damyan Ivanov.
+ * This file is part of MoLe.
+ * MoLe is free software: you can distribute it and/or modify it
* under the term of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your opinion), any later version.
*
- * Mobile-Ledger is distributed in the hope that it will be useful,
+ * MoLe is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License terms for details.
*
* You should have received a copy of the GNU General Public License
- * along with Mobile-Ledger. If not, see .
+ * along with MoLe. If not, see .
*/
package net.ktnx.mobileledger.utils;
-import android.content.SharedPreferences;
-import android.util.Base64;
-import android.util.Log;
+import androidx.annotation.NonNull;
+
+import net.ktnx.mobileledger.model.MobileLedgerProfile;
+
+import org.jetbrains.annotations.NotNull;
import java.io.IOException;
import java.net.HttpURLConnection;
import java.net.URL;
+import static net.ktnx.mobileledger.utils.Logger.debug;
+
public final class NetworkUtil {
private static final int thirtySeconds = 30000;
- public static HttpURLConnection prepare_connection(SharedPreferences pref, String path) throws
- IOException {
- final String backend_url = pref.getString("backend_url", "");
- final boolean use_auth = pref.getBoolean("backend_use_http_auth", false);
- Log.d("network", "Connecting to "+backend_url + "/" + path);
- HttpURLConnection http = (HttpURLConnection) new URL(backend_url + "/" + path).openConnection();
- if (use_auth) {
- final String auth_user = pref.getString("backend_auth_user", "");
- final String auth_password = pref.getString("backend_auth_password", "");
- final byte[] bytes = (String.format("%s:%s", auth_user, auth_password)).getBytes("UTF-8");
- final String value = Base64.encodeToString(bytes, Base64.DEFAULT);
- http.setRequestProperty("Authorization", "Basic " + value);
- }
- http.setAllowUserInteraction(false);
+ @NotNull
+ public static HttpURLConnection prepareConnection(@NonNull MobileLedgerProfile profile,
+ @NonNull String path) throws IOException {
+ return prepareConnection(profile.getUrl(), path, profile.isAuthEnabled());
+ }
+ public static HttpURLConnection prepareConnection(@NonNull String url, @NonNull String path,
+ boolean authEnabled) throws IOException {
+ String connectURL = url;
+ if (!connectURL.endsWith("/"))
+ connectURL += "/";
+ connectURL += path;
+ debug("network", "Connecting to " + connectURL);
+ HttpURLConnection http = (HttpURLConnection) new URL(connectURL).openConnection();
+ http.setAllowUserInteraction(true);
http.setRequestProperty("Accept-Charset", "UTF-8");
http.setInstanceFollowRedirects(false);
http.setUseCaches(false);