use installreferrer libray instead of broadcast listener

This commit is contained in:
Daniel Gultsch 2020-01-11 11:08:09 +01:00
parent 388c656bb9
commit 8e0c02f3cc
8 changed files with 108 additions and 90 deletions

View file

@ -22,6 +22,8 @@ configurations {
playstoreImplementation playstoreImplementation
compatImplementation compatImplementation
conversationsFreeCompatImplementation conversationsFreeCompatImplementation
conversationsPlaystoreCompatImplementation
conversationsPlaystoreSystemImplementation
quicksyFreeCompatImplementation quicksyFreeCompatImplementation
quicksyImplementation quicksyImplementation
} }
@ -36,6 +38,8 @@ dependencies {
exclude group: 'com.google.firebase', module: 'firebase-analytics' exclude group: 'com.google.firebase', module: 'firebase-analytics'
exclude group: 'com.google.firebase', module: 'firebase-measurement-connector' exclude group: 'com.google.firebase', module: 'firebase-measurement-connector'
} }
conversationsPlaystoreCompatImplementation("com.android.installreferrer:installreferrer:1.1")
conversationsPlaystoreSystemImplementation("com.android.installreferrer:installreferrer:1.1")
implementation 'org.sufficientlysecure:openpgp-api:10.0' implementation 'org.sufficientlysecure:openpgp-api:10.0'
implementation('com.theartofdev.edmodo:android-image-cropper:2.7.+') { implementation('com.theartofdev.edmodo:android-image-cropper:2.7.+') {
exclude group: 'com.android.support', module: 'appcompat-v7' exclude group: 'com.android.support', module: 'appcompat-v7'
@ -86,8 +90,8 @@ android {
defaultConfig { defaultConfig {
minSdkVersion 16 minSdkVersion 16
targetSdkVersion 28 targetSdkVersion 28
versionCode 353 versionCode 359
versionName "2.6.2" versionName "2.6.3-alpha.6"
archivesBaseName += "-$versionName" archivesBaseName += "-$versionName"
applicationId "eu.siacs.conversations" applicationId "eu.siacs.conversations"
resValue "string", "applicationId", applicationId resValue "string", "applicationId", applicationId
@ -147,12 +151,12 @@ android {
sourceSets { sourceSets {
quicksyFreeCompat { quicksyFreeCompat {
java { java {
srcDirs 'src/freeCompat/java' srcDir 'src/freeCompat/java'
} }
} }
quicksyPlaystoreCompat { quicksyPlaystoreCompat {
java { java {
srcDirs 'src/playstoreCompat/java' srcDir 'src/playstoreCompat/java'
} }
res { res {
srcDir 'src/playstoreCompat/res' srcDir 'src/playstoreCompat/res'
@ -166,12 +170,19 @@ android {
} }
conversationsFreeCompat { conversationsFreeCompat {
java { java {
srcDirs 'src/freeCompat/java' srcDir 'src/freeCompat/java'
srcDir 'src/conversationsFree/java'
}
}
conversationsFreeSystem {
java {
srcDir 'src/conversationsFree/java'
} }
} }
conversationsPlaystoreCompat { conversationsPlaystoreCompat {
java { java {
srcDirs 'src/playstoreCompat/java' srcDir 'src/playstoreCompat/java'
srcDir 'src/conversationsPlaystore/java'
} }
res { res {
srcDir 'src/playstoreCompat/res' srcDir 'src/playstoreCompat/res'
@ -179,6 +190,9 @@ android {
} }
} }
conversationsPlaystoreSystem { conversationsPlaystoreSystem {
java {
srcDir 'src/conversationsPlaystore/java'
}
res { res {
srcDir 'src/conversationsPlaystore/res' srcDir 'src/conversationsPlaystore/res'
} }

View file

@ -39,14 +39,5 @@
<data android:scheme="file" /> <data android:scheme="file" />
</intent-filter> </intent-filter>
</activity> </activity>
<receiver
android:name=".services.InstallReferrerService"
android:enabled="true"
android:exported="true">
<intent-filter>
<action android:name="com.android.vending.INSTALL_REFERRER" />
</intent-filter>
</receiver>
</application> </application>
</manifest> </manifest>

View file

@ -1,39 +0,0 @@
package eu.siacs.conversations.services;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.SharedPreferences;
import android.preference.PreferenceManager;
import android.util.Log;
import java.net.URLDecoder;
import eu.siacs.conversations.Config;
import eu.siacs.conversations.ui.StartConversationActivity;
import eu.siacs.conversations.utils.SignupUtils;
public class InstallReferrerService extends BroadcastReceiver {
public static final String INSTALL_REFERRER_BROADCAST_ACTION = "eu.siacs.conversations.install_referrer";
@Override
public void onReceive(final Context context, final Intent intent) {
final String referrer = intent == null ? null : intent.getStringExtra("referrer");
if (referrer == null) {
Log.d(Config.LOGTAG, "received empty referrer");
return;
}
try {
final String decoded = URLDecoder.decode(referrer, "UTF-8");
final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(context);
preferences.edit().putString(SignupUtils.INSTALL_REFERRER, decoded).apply();
Log.d(Config.LOGTAG, "stored referrer: " + decoded);
final Intent broadcastIntent = new Intent(INSTALL_REFERRER_BROADCAST_ACTION);
broadcastIntent.putExtra(StartConversationActivity.EXTRA_INVITE_URI, decoded);
context.sendBroadcast(broadcastIntent);
} catch (final Exception e) {
Log.d(Config.LOGTAG, "unable to process referrer", e);
}
}
}

View file

@ -1,15 +1,12 @@
package eu.siacs.conversations.ui; package eu.siacs.conversations.ui;
import android.content.Intent; import android.content.Intent;
import android.content.SharedPreferences;
import android.content.pm.ActivityInfo; import android.content.pm.ActivityInfo;
import android.databinding.DataBindingUtil; import android.databinding.DataBindingUtil;
import android.os.Bundle; import android.os.Bundle;
import android.preference.PreferenceManager;
import android.support.v7.widget.Toolbar; import android.support.v7.widget.Toolbar;
import android.text.Editable; import android.text.Editable;
import android.text.TextWatcher; import android.text.TextWatcher;
import android.util.Log;
import android.view.View; import android.view.View;
import android.widget.Toast; import android.widget.Toast;
@ -20,7 +17,7 @@ import eu.siacs.conversations.R;
import eu.siacs.conversations.databinding.MagicCreateBinding; import eu.siacs.conversations.databinding.MagicCreateBinding;
import eu.siacs.conversations.entities.Account; import eu.siacs.conversations.entities.Account;
import eu.siacs.conversations.utils.CryptoHelper; import eu.siacs.conversations.utils.CryptoHelper;
import eu.siacs.conversations.utils.SignupUtils; import eu.siacs.conversations.utils.InstallReferrerUtils;
import rocks.xmpp.addr.Jid; import rocks.xmpp.addr.Jid;
public class MagicCreateActivity extends XmppActivity implements TextWatcher { public class MagicCreateActivity extends XmppActivity implements TextWatcher {
@ -127,9 +124,7 @@ public class MagicCreateActivity extends XmppActivity implements TextWatcher {
@Override @Override
public void onDestroy() { public void onDestroy() {
Log.d(Config.LOGTAG,"purge install referrer"); InstallReferrerUtils.markInstallReferrerExecuted(this);
final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this);
preferences.edit().remove(SignupUtils.INSTALL_REFERRER).apply();
super.onDestroy(); super.onDestroy();
} }

View file

@ -1,14 +1,9 @@
package eu.siacs.conversations.ui; package eu.siacs.conversations.ui;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.IntentFilter;
import android.content.SharedPreferences;
import android.content.pm.ActivityInfo; import android.content.pm.ActivityInfo;
import android.databinding.DataBindingUtil; import android.databinding.DataBindingUtil;
import android.os.Bundle; import android.os.Bundle;
import android.preference.PreferenceManager;
import android.support.annotation.NonNull; import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity; import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar; import android.support.v7.widget.Toolbar;
@ -23,7 +18,7 @@ import eu.siacs.conversations.Config;
import eu.siacs.conversations.R; import eu.siacs.conversations.R;
import eu.siacs.conversations.databinding.ActivityWelcomeBinding; import eu.siacs.conversations.databinding.ActivityWelcomeBinding;
import eu.siacs.conversations.entities.Account; import eu.siacs.conversations.entities.Account;
import eu.siacs.conversations.services.InstallReferrerService; import eu.siacs.conversations.utils.InstallReferrerUtils;
import eu.siacs.conversations.utils.SignupUtils; import eu.siacs.conversations.utils.SignupUtils;
import eu.siacs.conversations.utils.XmppUri; import eu.siacs.conversations.utils.XmppUri;
import rocks.xmpp.addr.Jid; import rocks.xmpp.addr.Jid;
@ -37,18 +32,13 @@ public class WelcomeActivity extends XmppActivity {
private XmppUri inviteUri; private XmppUri inviteUri;
private BroadcastReceiver installReferrerBroadcastReceiver = new BroadcastReceiver() { public void onInstallReferrerDiscovered(final String referrer) {
@Override Log.d(Config.LOGTAG,"welcome activity: on install referrer discovered "+referrer);
public void onReceive(Context context, Intent data) { if (referrer != null) {
final String invite = data.getStringExtra(StartConversationActivity.EXTRA_INVITE_URI); final XmppUri xmppUri = new XmppUri(referrer);
if (invite == null) { runOnUiThread(() -> processXmppUri(xmppUri));
return;
} }
Log.d(Config.LOGTAG, "welcome activity received install referrer uri: " + invite);
final XmppUri xmppUri = new XmppUri(invite);
processXmppUri(xmppUri);
} }
};
private boolean processXmppUri(final XmppUri xmppUri) { private boolean processXmppUri(final XmppUri xmppUri) {
if (xmppUri.isValidJid()) { if (xmppUri.isValidJid()) {
@ -90,14 +80,11 @@ public class WelcomeActivity extends XmppActivity {
if (this.mTheme != theme) { if (this.mTheme != theme) {
recreate(); recreate();
} }
final IntentFilter intentFilter = new IntentFilter(); new InstallReferrerUtils(this);
intentFilter.addAction(InstallReferrerService.INSTALL_REFERRER_BROADCAST_ACTION);
registerReceiver(installReferrerBroadcastReceiver, intentFilter);
} }
@Override @Override
public void onStop() { public void onStop() {
unregisterReceiver(installReferrerBroadcastReceiver);
super.onStop(); super.onStop();
} }
@ -114,12 +101,6 @@ public class WelcomeActivity extends XmppActivity {
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT); setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
} }
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this);
final String referrer = preferences.getString(SignupUtils.INSTALL_REFERRER,null);
final XmppUri referrerUri = referrer == null ? null : new XmppUri(referrer);
if (referrerUri != null && processXmppUri(referrerUri)) {
return;
}
ActivityWelcomeBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_welcome); ActivityWelcomeBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_welcome);
setSupportActionBar((Toolbar) binding.toolbar); setSupportActionBar((Toolbar) binding.toolbar);
configureActionBar(getSupportActionBar(), false); configureActionBar(getSupportActionBar(), false);

View file

@ -17,8 +17,6 @@ import rocks.xmpp.addr.Jid;
public class SignupUtils { public class SignupUtils {
public static final String INSTALL_REFERRER = "install_referrer";
public static boolean isSupportTokenRegistry() { public static boolean isSupportTokenRegistry() {
return true; return true;
} }

View file

@ -0,0 +1,15 @@
package eu.siacs.conversations.utils;
import eu.siacs.conversations.ui.MagicCreateActivity;
import eu.siacs.conversations.ui.WelcomeActivity;
public class InstallReferrerUtils {
public InstallReferrerUtils(WelcomeActivity welcomeActivity) {
}
public static void markInstallReferrerExecuted(MagicCreateActivity magicCreateActivity) {
//stub
}
}

View file

@ -0,0 +1,63 @@
package eu.siacs.conversations.utils;
import android.app.Activity;
import android.content.SharedPreferences;
import android.os.RemoteException;
import android.preference.PreferenceManager;
import android.util.Log;
import com.android.installreferrer.api.InstallReferrerClient;
import com.android.installreferrer.api.InstallReferrerStateListener;
import com.android.installreferrer.api.ReferrerDetails;
import eu.siacs.conversations.Config;
import eu.siacs.conversations.ui.WelcomeActivity;
public class InstallReferrerUtils implements InstallReferrerStateListener {
private static final String PROCESSED_INSTALL_REFERRER = "processed_install_referrer";
private final WelcomeActivity welcomeActivity;
private final InstallReferrerClient installReferrerClient;
public InstallReferrerUtils(WelcomeActivity welcomeActivity) {
this.welcomeActivity = welcomeActivity;
final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(welcomeActivity);
if (preferences.getBoolean(PROCESSED_INSTALL_REFERRER, false)) {
Log.d(Config.LOGTAG, "install referrer already processed");
this.installReferrerClient = null;
return;
}
this.installReferrerClient = InstallReferrerClient.newBuilder(welcomeActivity).build();
this.installReferrerClient.startConnection(this);
}
public static void markInstallReferrerExecuted(final Activity context) {
final SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(context);
preferences.edit().putBoolean(PROCESSED_INSTALL_REFERRER, true).apply();
}
@Override
public void onInstallReferrerSetupFinished(int responseCode) {
switch (responseCode) {
case InstallReferrerClient.InstallReferrerResponse.OK:
try {
final ReferrerDetails referrerDetails = installReferrerClient.getInstallReferrer();
final String referrer = referrerDetails.getInstallReferrer();
welcomeActivity.onInstallReferrerDiscovered(referrer);
} catch (RemoteException e) {
Log.d(Config.LOGTAG, "unable to get install referrer", e);
}
break;
default:
Log.d(Config.LOGTAG, "unable to setup install referrer client. code=" + responseCode);
}
}
@Override
public void onInstallReferrerServiceDisconnected() {
}
}