X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/876204faf03075e286cf550b3bfba86d3f5a1419..5ca1b94865fcb868c44fe11df01ba17d33673b17:/src/com/owncloud/android/MainApp.java diff --git a/src/com/owncloud/android/MainApp.java b/src/com/owncloud/android/MainApp.java index 2d819f49..760a5e79 100644 --- a/src/com/owncloud/android/MainApp.java +++ b/src/com/owncloud/android/MainApp.java @@ -22,11 +22,14 @@ package com.owncloud.android; import android.app.Application; import android.content.Context; +import android.content.pm.PackageInfo; +import android.content.pm.PackageManager; 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; + /** * Main Application of the project * @@ -34,7 +37,9 @@ 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") @@ -49,10 +54,10 @@ 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); } @@ -117,4 +122,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; + } }