| Index: chrome/android/java/src/org/chromium/chrome/browser/IntentHandler.java
|
| diff --git a/chrome/android/java/src/org/chromium/chrome/browser/IntentHandler.java b/chrome/android/java/src/org/chromium/chrome/browser/IntentHandler.java
|
| index 939a3d623e09b92cd60f927e5744491dad1a30cd..cc6da7bb5accda978b33d112153251c968bb0ea0 100644
|
| --- a/chrome/android/java/src/org/chromium/chrome/browser/IntentHandler.java
|
| +++ b/chrome/android/java/src/org/chromium/chrome/browser/IntentHandler.java
|
| @@ -4,6 +4,7 @@
|
|
|
| package org.chromium.chrome.browser;
|
|
|
| +import android.app.Activity;
|
| import android.app.KeyguardManager;
|
| import android.app.PendingIntent;
|
| import android.app.SearchManager;
|
| @@ -183,7 +184,8 @@ public class IntentHandler {
|
| private static final String PACKAGE_MESSENGER = "com.google.android.apps.messaging";
|
| private static final String PACKAGE_LINE = "jp.naver.line.android";
|
| private static final String PACKAGE_WHATSAPP = "com.whatsapp";
|
| - private static final String FACEBOOK_LINK_PREFIX = "http://m.facebook.com/l.php?";
|
| + private static final String FACEBOOK_REFERRER_URL = "android-app://m.facebook.com";
|
| + private static final String FACEBOOK_INTERNAL_BROWSER_REFERRER = "http://m.facebook.com";
|
| private static final String TWITTER_LINK_PREFIX = "http://t.co/";
|
| private static final String NEWS_LINK_PREFIX = "http://news.google.com/news/url?";
|
|
|
| @@ -292,12 +294,22 @@ public class IntentHandler {
|
| ExternalAppId externalId = ExternalAppId.OTHER;
|
| if (appId == null) {
|
| String url = getUrlFromIntent(intent);
|
| + String referrer = getReferrerUrl(intent);
|
| if (url != null && url.startsWith(TWITTER_LINK_PREFIX)) {
|
| externalId = ExternalAppId.TWITTER;
|
| - } else if (url != null && url.startsWith(FACEBOOK_LINK_PREFIX)) {
|
| + } else if (FACEBOOK_REFERRER_URL.equals(referrer)) {
|
| + // This happens when "Links Open Externally" is checked in the Facebook app.
|
| externalId = ExternalAppId.FACEBOOK;
|
| } else if (url != null && url.startsWith(NEWS_LINK_PREFIX)) {
|
| externalId = ExternalAppId.NEWS;
|
| + } else {
|
| + Bundle headers = IntentUtils.safeGetBundleExtra(intent, Browser.EXTRA_HEADERS);
|
| + if (headers != null
|
| + && FACEBOOK_INTERNAL_BROWSER_REFERRER.equals(headers.get("Referer"))) {
|
| + // This happens when "Links Open Externally" is unchecked in the Facebook app,
|
| + // and we use "Open With..." from the internal browser.
|
| + externalId = ExternalAppId.FACEBOOK;
|
| + }
|
| }
|
| } else {
|
| if (appId.equals(PACKAGE_PLUS)) {
|
|
|