X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/2ada53c99b44e548615dfb9d2456f4e2f1930414..e0867d2b28b3e29430eead9938f9fc6a9b2944be:/src/com/owncloud/android/MainApp.java diff --git a/src/com/owncloud/android/MainApp.java b/src/com/owncloud/android/MainApp.java index cad43d65..789fa14d 100644 --- a/src/com/owncloud/android/MainApp.java +++ b/src/com/owncloud/android/MainApp.java @@ -1,5 +1,9 @@ -/* ownCloud Android client application - * Copyright (C) 2012-2013 ownCloud Inc. +/** + * ownCloud Android client application + * + * @author masensio + * @author David A. Velasco + * Copyright (C) 2015 ownCloud Inc. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2, @@ -16,27 +20,45 @@ */ package com.owncloud.android; -import java.io.File; - +import android.app.Activity; import android.app.Application; import android.content.Context; -import android.os.Environment; +import android.content.Intent; +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; +import android.os.Build; +import android.os.Bundle; +import com.owncloud.android.authentication.AuthenticatorActivity; +import com.owncloud.android.authentication.PinCheck; +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.utils.Log_OC; +import com.owncloud.android.lib.common.utils.Log_OC; +import com.owncloud.android.ui.activity.PinCodeActivity; + +import java.util.HashSet; +import java.util.Set; + /** * Main Application of the project * * Contains methods to build the "static" strings. These strings were before constants in different * classes - * - * @author masensio - * @author David A. Velasco */ public class MainApp extends Application { - + + private static final String TAG = MainApp.class.getSimpleName(); + private static final String AUTH_ON = "on"; + + private static final Set sExemptOfPasscodeActivites; + + static { + sExemptOfPasscodeActivites = new HashSet(); + sExemptOfPasscodeActivites.add(AuthenticatorActivity.class.getCanonicalName()); + sExemptOfPasscodeActivites.add(PinCodeActivity.class.getCanonicalName()); + } @SuppressWarnings("unused") private static final String POLICY_SINGLE_SESSION_PER_ACCOUNT = "single session per account"; @@ -50,19 +72,79 @@ public class MainApp extends Application { MainApp.mContext = getApplicationContext(); 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); } + + // initialise thumbnails cache on background thread + new ThumbnailsCacheManager.InitDiskCacheTask().execute(); if (BuildConfig.DEBUG) { - String logpath = Environment.getExternalStorageDirectory()+File.separator+"owncloud"+File.separator+"log"; + + String dataFolder = getDataFolder(); + + // Set folder for store logs + Log_OC.setLogDataFolder(dataFolder); + + Log_OC.startLogging(); Log_OC.d("Debug", "start logging"); - Log_OC.v("PATH", logpath); - Log_OC.startLogging(logpath); + } + + // 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(TAG, activity.getClass().getSimpleName() + " in onCreate(Bundle)" ); + } + + @Override + public void onActivityStarted(Activity activity) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onStart()" ); + } + + @Override + public void onActivityResumed(Activity activity) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onResume()" ); + if (!sExemptOfPasscodeActivites.contains(activity.getClass().getCanonicalName()) && + PinCheck.checkIfPinEntry() + ){ + Intent i = new Intent(MainApp.getAppContext(), PinCodeActivity.class); + //i.putExtra(PinCodeActivity.EXTRA_ACTIVITY, activity.getClass().getSimpleName()); + i.setAction(PinCodeActivity.ACTION_REQUEST); + activity.startActivity(i); + } + } + + @Override + public void onActivityPaused(Activity activity) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onPause()"); + PinCheck.setUnlockTimestamp(); + } + + @Override + public void onActivityStopped(Activity activity) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onStop()" ); + + } + + @Override + public void onActivitySaveInstanceState(Activity activity, Bundle outState) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onSaveInstanceState(Bundle)" ); + + } + + @Override + public void onActivityDestroyed(Activity activity) { + Log_OC.d(TAG, activity.getClass().getSimpleName() + " in onDestroy()" ); + + } + }); } } @@ -76,7 +158,7 @@ public class MainApp extends Application { public static String getAccountType() { return getAppContext().getResources().getString(R.string.account_type); } - + // From AccountAuthenticator // public static final String AUTHORITY = "org.owncloud"; public static String getAuthority() { @@ -111,4 +193,25 @@ public class MainApp extends Application { return getAppContext().getResources().getString(R.string.log_name); } + // 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; + } }