/*
- * Copyright © 2019 Damyan Ivanov.
+ * Copyright © 2021 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
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.db.DB;
import net.ktnx.mobileledger.model.Data;
+import net.ktnx.mobileledger.ui.profiles.ProfileDetailModel;
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 org.jetbrains.annotations.NotNull;
+
+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 static ProfileDetailModel profileModel;
private MobileLedgerDatabase dbHelper;
+ private boolean monthNamesPrepared = false;
+ public static SQLiteDatabase getDatabase() {
+ if (instance == null)
+ throw new RuntimeException("Application not created yet");
+
+ return instance.getDB();
+ }
+ public static void prepareMonthNames() {
+ instance.prepareMonthNames(false);
+ }
+ public static void setAuthenticationDataFromProfileModel(ProfileDetailModel model) {
+ profileModel = model;
+ }
+ public static void resetAuthenticationData() {
+ profileModel = null;
+ }
+ private String getAuthURL() {
+ if (profileModel != null)
+ return profileModel.getUrl();
+ return Data.getProfile()
+ .getUrl();
+ }
+ private String getAuthUserName() {
+ if (profileModel != null)
+ return profileModel.getAuthUserName();
+ return Data.getProfile()
+ .getAuthUserName();
+ }
+ private String getAuthPassword() {
+ if (profileModel != null)
+ return profileModel.getAuthPassword();
+ return Data.getProfile()
+ .getAuthPassword();
+ }
+ private boolean getAuthEnabled() {
+ if (profileModel != null)
+ return profileModel.getUseAuthentication();
+ return Data.getProfile()
+ .isAuthEnabled();
+ }
@Override
public void onCreate() {
+ 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() {
+ if (getAuthEnabled()) {
+ try {
+ final URL url = new URL(getAuthURL());
+ final String requestingHost = getRequestingHost();
+ final String expectedHost = url.getHost();
+ if (requestingHost.equalsIgnoreCase(expectedHost))
+ return new PasswordAuthentication(getAuthUserName(),
+ 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();
+ }
+ });
}
- 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() {
- if (dbHelper != null) dbHelper.close();
+ Logger.debug("flow", "App onTerminate()");
+ if (dbHelper != null)
+ dbHelper.close();
super.onTerminate();
}
@Override
- public void onConfigurationChanged(Configuration newConfig) {
+ public void onConfigurationChanged(@NotNull Configuration newConfig) {
super.onConfigurationChanged(newConfig);
- updateMonthNames();
- }
- public static SQLiteDatabase getDatabase() {
- if (instance == null) throw new RuntimeException("Application not created yet");
-
- return instance.getDB();
+ prepareMonthNames(true);
+ Data.refreshCurrencyData(Locale.getDefault());
+ Data.locale.setValue(Locale.getDefault());
}
public SQLiteDatabase getDB() {
- if (dbHelper == null) initDb();
-
- final SQLiteDatabase db = dbHelper.getWritableDatabase();
- db.execSQL("pragma case_sensitive_like=ON;");
+ if (dbHelper == null)
+ initDb();
- return db;
+ return dbHelper.getWritableDatabase();
}
private synchronized void initDb() {
- if (dbHelper != null) return;
+ if (dbHelper != null)
+ return;
+ // Let Room do any possible migrations
+ // this method may be removed when all DB access is made via Room
+ DB.get()
+ .compileStatement("select count(*) from profiles");
dbHelper = new MobileLedgerDatabase(this);
}
}