Skip to content

Commit

Permalink
different Pusher AppId
Browse files Browse the repository at this point in the history
  • Loading branch information
p1gp1g committed Jun 7, 2021
1 parent 6c80b3a commit 5f5b873
Show file tree
Hide file tree
Showing 7 changed files with 26 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ class NotificationTroubleshootTestManagerFactory @Inject constructor(
mgr.addTest(testSystemSettings)
mgr.addTest(testAccountSettings)
mgr.addTest(testDeviceSettings)
if (UPHelper.DistributorExists(fragment.requireContext())) {
if (UPHelper.distributorExists(fragment.requireContext())) {
mgr.addTest(testBingRulesSettings)
mgr.addTest(testNewEndpoint)
mgr.addTest(testTokenRegistration)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ class NotificationTroubleshootTestManagerFactory @Inject constructor(
mgr.addTest(testSystemSettings)
mgr.addTest(testAccountSettings)
mgr.addTest(testDeviceSettings)
if (UPHelper.DistributorExists(fragment.requireContext())) {
if (UPHelper.distributorExists(fragment.requireContext())) {
mgr.addTest(testBingRulesSettings)
mgr.addTest(testPlayServices)
mgr.addTest(testNewEndpoint)
Expand Down
18 changes: 13 additions & 5 deletions vector/src/main/java/im/vector/app/core/pushers/PushersManager.kt
Original file line number Diff line number Diff line change
Expand Up @@ -39,19 +39,19 @@ class PushersManager @Inject constructor(

currentSession.testPush(
UPHelper.getPushGateway(context)!!,
stringProvider.getString(R.string.pusher_app_id),
getPusherAppId(context),
UPHelper.getUpEndpoint(context)!!,
TEST_EVENT_ID
)
}

fun registerPusher(pushKey: String, gateway: String): UUID {
fun registerPusher(context: Context, pushKey: String, gateway: String): UUID {
val currentSession = activeSessionHolder.getActiveSession()
val profileTag = DEFAULT_PUSHER_FILE_TAG + "_" + abs(currentSession.myUserId.hashCode())

return currentSession.addHttpPusher(
pushKey, // this is the UnifiedPush endpoint
stringProvider.getString(R.string.pusher_app_id),
getPusherAppId(context),
profileTag,
localeProvider.current().language,
appNameProvider.getAppName(),
Expand All @@ -62,9 +62,17 @@ class PushersManager @Inject constructor(
)
}

suspend fun unregisterPusher(pushKey: String) {
suspend fun unregisterPusher(context: Context, pushKey: String) {
val currentSession = activeSessionHolder.getSafeActiveSession() ?: return
currentSession.removeHttpPusher(pushKey, stringProvider.getString(R.string.pusher_app_id))
currentSession.removeHttpPusher(pushKey, getPusherAppId(context))
}

private fun getPusherAppId(context: Context) : String {
val appId = stringProvider.getString(R.string.pusher_app_id)
return if (UPHelper.isEmbeddedDistributor(context)) {
"${appId}.fcm"
} else
"${appId}.up"
}

companion object {
Expand Down
8 changes: 7 additions & 1 deletion vector/src/main/java/im/vector/app/core/pushers/UPHelper.kt
Original file line number Diff line number Diff line change
Expand Up @@ -153,8 +153,14 @@ object UPHelper {
return false
}

fun DistributorExists(context: Context): Boolean {
fun distributorExists(context: Context): Boolean {
val up = Registration()
return up.getDistributor(context).isNotEmpty()
}

fun isEmbeddedDistributor(context: Context) : Boolean {
val up = Registration()
return up.getDistributor(context) == context.packageName
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ val upHandler = object: MessagingReceiverHandler {
val gateway = UPHelper.customOrDefaultGateway(context, endpoint)
UPHelper.storePushGateway(context, gateway)
UPHelper.storeUpEndpoint(context, endpoint)
pusherManager.registerPusher(endpoint, gateway)
pusherManager.registerPusher(context, endpoint, gateway)
}
val mode = BackgroundSyncMode.FDROID_BACKGROUND_SYNC_MODE_DISABLED
vectorPreferences.setFdroidSyncBackgroundMode(mode)
Expand All @@ -172,7 +172,7 @@ val upHandler = object: MessagingReceiverHandler {
vectorPreferences.setFdroidSyncBackgroundMode(mode)
runBlocking {
try {
pusherManager.unregisterPusher(UPHelper.getUpEndpoint(context)!!)
pusherManager.unregisterPusher(context, UPHelper.getUpEndpoint(context)!!)
} catch (e: Exception) {
Timber.d("Probably unregistering a non existant pusher")
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -296,7 +296,7 @@ class VectorSettingsNotificationPreferenceFragment @Inject constructor(
lifecycleScope.launch {
runCatching {
try {
pushManager.unregisterPusher(it)
pushManager.unregisterPusher(requireContext(), it)
} catch (e: Exception) {
Timber.d("Probably unregistering a non existant pusher")
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ class TestTokenRegistration @Inject constructor(private val context: AppCompatAc
stringProvider.getString(R.string.sas_error_unknown))
quickFix = object : TroubleshootQuickFix(R.string.settings_troubleshoot_test_token_registration_quick_fix) {
override fun doFix() {
val workId = pushersManager.registerPusher(pushToken, pushGateway)
val workId = pushersManager.registerPusher(context, pushToken, pushGateway)
WorkManager.getInstance(context).getWorkInfoByIdLiveData(workId).observe(context, Observer { workInfo ->
if (workInfo != null) {
if (workInfo.state == WorkInfo.State.SUCCEEDED) {
Expand Down

0 comments on commit 5f5b873

Please sign in to comment.