X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/876204faf03075e286cf550b3bfba86d3f5a1419..a99a28cc61d48eca63803c3d661ea1be14f99aec:/src/com/owncloud/android/MainApp.java diff --git a/src/com/owncloud/android/MainApp.java b/src/com/owncloud/android/MainApp.java index 2d819f49..401f6075 100644 --- a/src/com/owncloud/android/MainApp.java +++ b/src/com/owncloud/android/MainApp.java @@ -20,13 +20,26 @@ */ package com.owncloud.android; +import android.app.Activity; import android.app.Application; import android.content.Context; +import android.content.Intent; +import android.content.SharedPreferences; +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.os.Build; +import android.os.Bundle; +import android.os.Environment; +import android.preference.PreferenceManager; +import com.owncloud.android.authentication.PassCodeManager; import com.owncloud.android.datamodel.ThumbnailsCacheManager; import com.owncloud.android.lib.common.OwnCloudClientManagerFactory; import com.owncloud.android.lib.common.OwnCloudClientManagerFactory.Policy; import com.owncloud.android.lib.common.utils.Log_OC; +import com.owncloud.android.utils.ExceptionHandler; + + /** * Main Application of the project * @@ -34,25 +47,41 @@ import com.owncloud.android.lib.common.utils.Log_OC; * classes */ public class MainApp extends Application { - + + private static final String TAG = MainApp.class.getSimpleName(); + private static final String AUTH_ON = "on"; - + @SuppressWarnings("unused") private static final String POLICY_SINGLE_SESSION_PER_ACCOUNT = "single session per account"; @SuppressWarnings("unused") private static final String POLICY_ALWAYS_NEW_CLIENT = "always new client"; private static Context mContext; + + private static String storagePath; + + private static boolean mOnlyOnDevice = false; + public void onCreate(){ super.onCreate(); MainApp.mContext = getApplicationContext(); + + // Setup handler for uncaught exceptions. + Thread.setDefaultUncaughtExceptionHandler(new ExceptionHandler()); + + SharedPreferences appPrefs = + PreferenceManager.getDefaultSharedPreferences(getApplicationContext()); + MainApp.storagePath = appPrefs.getString("storage_path", Environment. + getExternalStorageDirectory().getAbsolutePath()); + boolean isSamlAuth = AUTH_ON.equals(getString(R.string.auth_method_saml_web_sso)); - - if (isSamlAuth) { + + OwnCloudClientManagerFactory.setUserAgent(getUserAgent()); + if (isSamlAuth) { OwnCloudClientManagerFactory.setDefaultPolicy(Policy.SINGLE_SESSION_PER_ACCOUNT); - } else { OwnCloudClientManagerFactory.setDefaultPolicy(Policy.ALWAYS_NEW_CLIENT); } @@ -67,15 +96,67 @@ public class MainApp extends Application { // Set folder for store logs Log_OC.setLogDataFolder(dataFolder); - Log_OC.startLogging(); + Log_OC.startLogging(MainApp.storagePath); Log_OC.d("Debug", "start logging"); } + + // register global protection with pass code + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) { + this.registerActivityLifecycleCallbacks( new ActivityLifecycleCallbacks() { + + @Override + public void onActivityCreated(Activity activity, Bundle savedInstanceState) { + Log_OC.d(activity.getClass().getSimpleName(), "onCreate(Bundle) starting" ); + PassCodeManager.getPassCodeManager().onActivityCreated(activity); + } + + @Override + public void onActivityStarted(Activity activity) { + Log_OC.d(activity.getClass().getSimpleName(), "onStart() starting" ); + PassCodeManager.getPassCodeManager().onActivityStarted(activity); + } + + @Override + public void onActivityResumed(Activity activity) { + Log_OC.d(activity.getClass().getSimpleName(), "onResume() starting" ); + } + + @Override + public void onActivityPaused(Activity activity) { + Log_OC.d(activity.getClass().getSimpleName(), "onPause() ending"); + } + + @Override + public void onActivityStopped(Activity activity) { + Log_OC.d(activity.getClass().getSimpleName(), "onStop() ending" ); + PassCodeManager.getPassCodeManager().onActivityStopped(activity); + } + + @Override + public void onActivitySaveInstanceState(Activity activity, Bundle outState) { + Log_OC.d(activity.getClass().getSimpleName(), "onSaveInstanceState(Bundle) starting" ); + } + + @Override + public void onActivityDestroyed(Activity activity) { + Log_OC.d(activity.getClass().getSimpleName(), "onDestroy() ending" ); + } + }); + } } public static Context getAppContext() { return MainApp.mContext; } + public static String getStoragePath(){ + return MainApp.storagePath; + } + + public static void setStoragePath(String path){ + MainApp.storagePath = path; + } + // Methods to obtain Strings referring app_name // From AccountAuthenticator // public static final String ACCOUNT_TYPE = "owncloud"; @@ -117,4 +198,33 @@ public class MainApp extends Application { return getAppContext().getResources().getString(R.string.log_name); } + public static void showOnlyFilesOnDevice(boolean state){ + mOnlyOnDevice = state; + } + + public static boolean getOnlyOnDevice(){ + return mOnlyOnDevice; + } + + // user agent + public static String getUserAgent() { + String appString = getAppContext().getResources().getString(R.string.user_agent); + String packageName = getAppContext().getPackageName(); + String version = ""; + + PackageInfo pInfo = null; + try { + pInfo = getAppContext().getPackageManager().getPackageInfo(packageName, 0); + if (pInfo != null) { + version = pInfo.versionName; + } + } catch (PackageManager.NameNotFoundException e) { + Log_OC.e(TAG, "Trying to get packageName", e.getCause()); + } + + // Mozilla/5.0 (Android) ownCloud-android/1.7.0 + String userAgent = String.format(appString, version); + + return userAgent; + } }