Clear UTM parameters

This commit is contained in:
Thomas 2022-05-04 16:50:34 +02:00
parent 14cb5ffef3
commit 92b616cca7
2 changed files with 62 additions and 1 deletions

View file

@ -265,6 +265,37 @@ public class Helper {
public static final Pattern wikipediaPattern = Pattern.compile("([\\w_-]+)\\.wikipedia.org/(((?!([\"'<])).)*)"); public static final Pattern wikipediaPattern = Pattern.compile("([\\w_-]+)\\.wikipedia.org/(((?!([\"'<])).)*)");
public static final Pattern codePattern = Pattern.compile("code=([\\w-]+)"); public static final Pattern codePattern = Pattern.compile("code=([\\w-]+)");
/*
* List from ClearUrls
* https://gitlab.com/KevinRoebert/ClearUrls/blob/master/data/data.min.json#L106
*/
private static final String[] UTM_PARAMS = {
"utm_\\w+",
"ga_source",
"ga_medium",
"ga_term",
"ga_content",
"ga_campaign",
"ga_place",
"yclid",
"_openstat",
"fb_action_ids",
"fb_action_types",
"fb_source",
"fb_ref",
"fbclid",
"action_object_map",
"action_type_map",
"action_ref_map",
"gs_l",
"mkt_tok",
"hmb_campaign",
"hmb_medium",
"hmb_source",
"[\\?|&]ref[\\_]?"
};
// --- Static Map of patterns used in spannable status content // --- Static Map of patterns used in spannable status content
public static final Map<PatternType, Pattern> patternHashMap; public static final Map<PatternType, Pattern> patternHashMap;
public static int counter = 1; public static int counter = 1;
@ -613,7 +644,6 @@ public class Helper {
* @param url String url to open * @param url String url to open
*/ */
public static void openBrowser(Context context, String url) { public static void openBrowser(Context context, String url) {
//url = transformURL(context, url);
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context); SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context);
boolean embedded_browser = sharedpreferences.getBoolean(context.getString(R.string.SET_EMBEDDED_BROWSER), true); boolean embedded_browser = sharedpreferences.getBoolean(context.getString(R.string.SET_EMBEDDED_BROWSER), true);
if (embedded_browser && !url.toLowerCase().startsWith("gemini://")) { if (embedded_browser && !url.toLowerCase().startsWith("gemini://")) {
@ -714,9 +744,36 @@ public class Helper {
return "https://" + wikipediaReplaceHost + "/" + path + lang; return "https://" + wikipediaReplaceHost + "/" + path + lang;
} }
} }
boolean filterUTM = Helper.getSharedValue(context, context.getString(R.string.SET_FILTER_UTM));
if (filterUTM) {
return remove_tracking_param(context, url);
}
return url; return url;
} }
/**
* Remove tracking parameters
*
* @param context - Context
* @param original_content - String original URL
* @return cleaned URL
*/
private static String remove_tracking_param(Context context, String original_content) {
if (original_content == null)
return original_content;
String cleaned_content = original_content;
for (String utm : UTM_PARAMS) {
cleaned_content = cleaned_content.replaceAll("&amp;" + utm + "=[0-9a-zA-Z._-]*", "");
cleaned_content = cleaned_content.replaceAll("&" + utm + "=[0-9a-zA-Z._-]*", "");
cleaned_content = cleaned_content.replaceAll("\\?" + utm + "=[0-9a-zA-Z._-]*", "?");
}
if (cleaned_content.endsWith("?")) {
cleaned_content = cleaned_content.substring(0, cleaned_content.length() - 1);
}
return cleaned_content;
}
@SuppressLint("DefaultLocale") @SuppressLint("DefaultLocale")
public static String withSuffix(long count) { public static String withSuffix(long count) {
if (count < 1000) return "" + count; if (count < 1000) return "" + count;

View file

@ -177,10 +177,14 @@ public class SpannableHelper {
content.replace(matchStart, matchEnd, urlText); content.replace(matchStart, matchEnd, urlText);
matchEnd = matchStart + 31; matchEnd = matchStart + 31;
offSetTruncate += (newURL.length() - urlText.length()); offSetTruncate += (newURL.length() - urlText.length());
} else {
matchEnd = matchStart + (newURL.length());
} }
if (!urlText.startsWith("http")) { if (!urlText.startsWith("http")) {
continue; continue;
} }
if (matchStart >= 0 && matchEnd <= content.length() && matchEnd >= matchStart) { if (matchStart >= 0 && matchEnd <= content.length() && matchEnd >= matchStart) {
content.setSpan(new ClickableSpan() { content.setSpan(new ClickableSpan() {
@Override @Override