X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2FApp.java;h=68f1b9c43c1e14f6f999c9edbfcf832839d539ce;hb=bc308eb5e470d3f51e91bebad2f368d618593907;hp=b6ae697f355409d9b1256b05b57174427d4b598b;hpb=76522e26b306350d61f2358f2f993fddfb30d76d;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/App.java b/app/src/main/java/net/ktnx/mobileledger/App.java index b6ae697f..68f1b9c4 100644 --- a/app/src/main/java/net/ktnx/mobileledger/App.java +++ b/app/src/main/java/net/ktnx/mobileledger/App.java @@ -1,5 +1,5 @@ /* - * Copyright © 2019 Damyan Ivanov. + * 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 @@ -18,22 +18,27 @@ package net.ktnx.mobileledger; import android.app.Application; -import android.content.SharedPreferences; import android.content.res.Configuration; import android.content.res.Resources; import android.database.sqlite.SQLiteDatabase; -import android.preference.PreferenceManager; +import android.util.Log; import net.ktnx.mobileledger.model.Data; +import net.ktnx.mobileledger.model.MobileLedgerProfile; import net.ktnx.mobileledger.utils.Globals; import net.ktnx.mobileledger.utils.Logger; import net.ktnx.mobileledger.utils.MobileLedgerDatabase; -import static net.ktnx.mobileledger.ui.activity.SettingsActivity.PREF_KEY_SHOW_ONLY_STARRED_ACCOUNTS; +import java.net.Authenticator; +import java.net.MalformedURLException; +import java.net.PasswordAuthentication; +import java.net.URL; +import java.util.Locale; public class App extends Application { public static App instance; private MobileLedgerDatabase dbHelper; + private boolean monthNamesPrepared = false; public static SQLiteDatabase getDatabase() { if (instance == null) throw new RuntimeException("Application not created yet"); @@ -44,28 +49,55 @@ public class App extends Application { Logger.debug("flow", "App onCreate()"); instance = this; super.onCreate(); - updateMonthNames(); - SharedPreferences p = PreferenceManager.getDefaultSharedPreferences(this); - Data.optShowOnlyStarred.set(p.getBoolean(PREF_KEY_SHOW_ONLY_STARRED_ACCOUNTS, false)); - SharedPreferences.OnSharedPreferenceChangeListener handler = - (preference, value) -> Data.optShowOnlyStarred - .set(preference.getBoolean(PREF_KEY_SHOW_ONLY_STARRED_ACCOUNTS, false)); - p.registerOnSharedPreferenceChangeListener(handler); + Data.refreshCurrencyData(Locale.getDefault()); + Authenticator.setDefault(new Authenticator() { + @Override + protected PasswordAuthentication getPasswordAuthentication() { + MobileLedgerProfile p = Data.profile.getValue(); + if ((p != null) && p.isAuthEnabled()) { + try { + final URL url = new URL(p.getUrl()); + final String requestingHost = getRequestingHost(); + final String expectedHost = url.getHost(); + if (requestingHost.equalsIgnoreCase(expectedHost)) + return new PasswordAuthentication(p.getAuthUserName(), + p.getAuthPassword().toCharArray()); + else Log.w("http-auth", + String.format("Requesting host [%s] differs from expected [%s]", + requestingHost, expectedHost)); + } + catch (MalformedURLException e) { + e.printStackTrace(); + } + } + + return super.getPasswordAuthentication(); + } + }); + } + public static void prepareMonthNames() { + instance.prepareMonthNames(false); } - private void updateMonthNames() { + private void prepareMonthNames(boolean force) { + if (force || monthNamesPrepared) + return; Resources rm = getResources(); Globals.monthNames = rm.getStringArray(R.array.month_names); + monthNamesPrepared = true; } @Override public void onTerminate() { Logger.debug("flow", "App onTerminate()"); - if (dbHelper != null) dbHelper.close(); + if (dbHelper != null) + dbHelper.close(); super.onTerminate(); } @Override public void onConfigurationChanged(Configuration newConfig) { super.onConfigurationChanged(newConfig); - updateMonthNames(); + prepareMonthNames(true); + Data.refreshCurrencyData(Locale.getDefault()); + Data.locale.setValue(Locale.getDefault()); } public SQLiteDatabase getDB() { if (dbHelper == null) initDb();