Skip to content

Commit 7e41d73

Browse files
committed
Move getCryptoVersion from CryptoService to Matrix companion, it does not need a session to get the value.
This simplify a lot accessing this data.
1 parent 28fa4ab commit 7e41d73

File tree

10 files changed

+10
-135
lines changed

10 files changed

+10
-135
lines changed

matrix-sdk-android/src/main/java/org/matrix/android/sdk/api/Matrix.kt

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -147,5 +147,12 @@ class Matrix(context: Context, matrixConfiguration: MatrixConfiguration) {
147147
fun getSdkVersion(): String {
148148
return BuildConfig.SDK_VERSION + " (" + BuildConfig.GIT_SDK_REVISION + ")"
149149
}
150+
151+
fun getCryptoVersion(longFormat: Boolean): String {
152+
val version = org.matrix.rustcomponents.sdk.crypto.version()
153+
val gitHash = org.matrix.rustcomponents.sdk.crypto.versionInfo().gitSha
154+
val vodozemac = org.matrix.rustcomponents.sdk.crypto.vodozemacVersion()
155+
return if (longFormat) "Rust SDK $version ($gitHash), Vodozemac $vodozemac" else version
156+
}
150157
}
151158
}

matrix-sdk-android/src/main/java/org/matrix/android/sdk/api/session/crypto/CryptoService.kt

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -60,8 +60,6 @@ interface CryptoService {
6060

6161
suspend fun deleteDevices(@Size(min = 1) deviceIds: List<String>, userInteractiveAuthInterceptor: UserInteractiveAuthInterceptor)
6262

63-
fun getCryptoVersion(longFormat: Boolean): String
64-
6563
fun isCryptoEnabled(): Boolean
6664

6765
fun isRoomBlacklistUnverifiedDevices(roomId: String?): Boolean

matrix-sdk-android/src/main/java/org/matrix/android/sdk/internal/crypto/RustCryptoService.kt

Lines changed: 0 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -183,13 +183,6 @@ internal class RustCryptoService @Inject constructor(
183183
deleteDevices(listOf(deviceId), userInteractiveAuthInterceptor)
184184
}
185185

186-
override fun getCryptoVersion(longFormat: Boolean): String {
187-
val version = org.matrix.rustcomponents.sdk.crypto.version()
188-
val gitHash = org.matrix.rustcomponents.sdk.crypto.versionInfo().gitSha
189-
val vodozemac = org.matrix.rustcomponents.sdk.crypto.vodozemacVersion()
190-
return if (longFormat) "Rust SDK $version ($gitHash), Vodozemac $vodozemac" else version
191-
}
192-
193186
override suspend fun getMyCryptoDevice(): CryptoDeviceInfo = withContext(coroutineDispatchers.io) {
194187
olmMachine.ownDevice()
195188
}

vector-app/src/main/java/im/vector/app/VectorApplication.kt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -135,6 +135,7 @@ class VectorApplication :
135135
SuperProperties(
136136
appPlatform = SuperProperties.AppPlatform.EA,
137137
cryptoSDK = SuperProperties.CryptoSDK.Rust,
138+
cryptoSDKVersion = Matrix.getCryptoVersion(longFormat = false)
138139
)
139140
)
140141
invitesAcceptor.initialize()

vector/src/main/java/im/vector/app/features/analytics/impl/AutoSuperPropertiesFlowProvider.kt

Lines changed: 0 additions & 43 deletions
This file was deleted.

vector/src/main/java/im/vector/app/features/analytics/impl/DefaultVectorAnalytics.kt

Lines changed: 0 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,6 @@ class DefaultVectorAnalytics @Inject constructor(
4242
private val analyticsConfig: AnalyticsConfig,
4343
private val analyticsStore: AnalyticsStore,
4444
private val lateInitUserPropertiesFactory: LateInitUserPropertiesFactory,
45-
private val autoSuperPropertiesFlowProvider: AutoSuperPropertiesFlowProvider,
4645
@NamedGlobalScope private val globalScope: CoroutineScope
4746
) : VectorAnalytics {
4847

@@ -70,7 +69,6 @@ class DefaultVectorAnalytics @Inject constructor(
7069
override fun init() {
7170
observeUserConsent()
7271
observeAnalyticsId()
73-
observeAutoSuperProperties()
7472
}
7573

7674
override fun getUserConsent(): Flow<Boolean> {
@@ -118,12 +116,6 @@ class DefaultVectorAnalytics @Inject constructor(
118116
.launchIn(globalScope)
119117
}
120118

121-
private fun observeAutoSuperProperties() {
122-
autoSuperPropertiesFlowProvider.superPropertiesFlow.onEach {
123-
updateSuperProperties(it)
124-
}.launchIn(globalScope)
125-
}
126-
127119
private suspend fun identifyPostHog() {
128120
val id = analyticsId ?: return
129121
if (!userConsent.orFalse()) return

vector/src/main/java/im/vector/app/features/rageshake/BugReporter.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -265,7 +265,7 @@ class BugReporter @Inject constructor(
265265
activeSessionHolder.getSafeActiveSession()?.let { session ->
266266
userId = session.myUserId
267267
deviceId = session.sessionParams.deviceId
268-
olmVersion = session.cryptoService().getCryptoVersion(true)
268+
olmVersion = Matrix.getCryptoVersion(true)
269269
}
270270

271271
if (!mIsCancelled) {

vector/src/main/java/im/vector/app/features/settings/VectorSettingsHelpAboutFragment.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -96,7 +96,7 @@ class VectorSettingsHelpAboutFragment :
9696

9797
// olm version
9898
findPreference<VectorPreference>(VectorPreferences.SETTINGS_CRYPTO_VERSION_PREFERENCE_KEY)!!
99-
.summary = session.cryptoService().getCryptoVersion(true)
99+
.summary = Matrix.getCryptoVersion(true)
100100
}
101101

102102
companion object {

vector/src/test/java/im/vector/app/features/analytics/impl/DefaultVectorAnalyticsTest.kt

Lines changed: 0 additions & 37 deletions
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,6 @@ package im.vector.app.features.analytics.impl
1818

1919
import im.vector.app.features.analytics.plan.SuperProperties
2020
import im.vector.app.test.fakes.FakeAnalyticsStore
21-
import im.vector.app.test.fakes.FakeAutoSuperPropertiesFlowProvider
2221
import im.vector.app.test.fakes.FakeLateInitUserPropertiesFactory
2322
import im.vector.app.test.fakes.FakePostHog
2423
import im.vector.app.test.fakes.FakePostHogFactory
@@ -46,7 +45,6 @@ class DefaultVectorAnalyticsTest {
4645
private val fakeAnalyticsStore = FakeAnalyticsStore()
4746
private val fakeLateInitUserPropertiesFactory = FakeLateInitUserPropertiesFactory()
4847
private val fakeSentryAnalytics = FakeSentryAnalytics()
49-
private val fakeAutoSuperPropertiesFlowProvider = FakeAutoSuperPropertiesFlowProvider()
5048

5149
private val defaultVectorAnalytics = DefaultVectorAnalytics(
5250
postHogFactory = FakePostHogFactory(fakePostHog.instance).instance,
@@ -55,7 +53,6 @@ class DefaultVectorAnalyticsTest {
5553
globalScope = CoroutineScope(Dispatchers.Unconfined),
5654
analyticsConfig = anAnalyticsConfig(isEnabled = true),
5755
lateInitUserPropertiesFactory = fakeLateInitUserPropertiesFactory.instance,
58-
autoSuperPropertiesFlowProvider = fakeAutoSuperPropertiesFlowProvider.instance,
5956
)
6057

6158
@Before
@@ -289,40 +286,6 @@ class DefaultVectorAnalyticsTest {
289286
)
290287
}
291288

292-
@Test
293-
fun `Update super properties from flow`() = runTest {
294-
fakeAnalyticsStore.givenUserContent(consent = true)
295-
296-
fakeAutoSuperPropertiesFlowProvider.postSuperProperty(
297-
SuperProperties(
298-
cryptoSDKVersion = "0"
299-
)
300-
)
301-
302-
val fakeEvent = aVectorAnalyticsEvent("THE_NAME", null)
303-
defaultVectorAnalytics.capture(fakeEvent)
304-
305-
fakePostHog.verifyEventTracked(
306-
"THE_NAME",
307-
mapOf(
308-
"cryptoSDKVersion" to "0"
309-
)
310-
)
311-
312-
fakeAutoSuperPropertiesFlowProvider.postSuperProperty(SuperProperties(
313-
cryptoSDKVersion = "1"
314-
))
315-
316-
defaultVectorAnalytics.capture(fakeEvent)
317-
318-
fakePostHog.verifyEventTracked(
319-
"THE_NAME",
320-
mapOf(
321-
"cryptoSDKVersion" to "1"
322-
)
323-
)
324-
}
325-
326289
private fun Map<String, Any?>?.clearNulls(): Map<String, Any>? {
327290
if (this == null) return null
328291

vector/src/test/java/im/vector/app/test/fakes/FakeAutoSuperPropertiesFlowProvider.kt

Lines changed: 0 additions & 36 deletions
This file was deleted.

0 commit comments

Comments
 (0)