From 0d06966085dfc4744acaf6adf144fc6fa3ab6d9e Mon Sep 17 00:00:00 2001 From: aforaleka Date: Tue, 24 Sep 2024 16:35:17 -0400 Subject: [PATCH 1/3] add api state params to tracking --- .../state/v2/supervisor/NetworkHelper.kt | 13 +++++++++++++ .../state/v2/supervisor/NetworkSupervisor.kt | 2 +- .../v2/supervisor/SubaccountTransactionTracker.kt | 2 +- 3 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkHelper.kt b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkHelper.kt index 7edeee266..7864ebf5f 100644 --- a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkHelper.kt +++ b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkHelper.kt @@ -25,6 +25,7 @@ import exchange.dydx.abacus.utils.JsonEncoder import exchange.dydx.abacus.utils.ParsingHelper import exchange.dydx.abacus.utils.ServerTime import exchange.dydx.abacus.utils.UIImplementations +import exchange.dydx.abacus.utils.iMapOf import kollections.iListOf import kollections.iSetOf import kollections.toIMap @@ -555,4 +556,16 @@ class NetworkHelper( } } } + + internal fun apiStateParams(): IMap? { + val indexerTime = lastIndexerCallTime?.toEpochMilliseconds() + val validatorTime = lastValidatorCallTime?.toEpochMilliseconds() + val interval = indexerTime?.let { Clock.System.now().toEpochMilliseconds() - it } + return iMapOf( + "lastSuccessfulIndexerRPC" to indexerTime?.toDouble(), + "lastSuccessfulFullNodeRPC" to validatorTime?.toDouble(), + "elapsedTime" to interval?.toDouble(), + "validatorUrl" to validatorUrl, + ) as IMap? + } } diff --git a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt index 61b18ddb4..f6271989a 100644 --- a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt +++ b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt @@ -85,7 +85,7 @@ internal open class NetworkSupervisor( } internal fun tracking(eventName: String, params: IMap?) { - val requiredParams = helper.validatorUrl?.let { iMapOf("validatorUrl" to it) } ?: iMapOf() + val requiredParams = helper.apiStateParams() val mergedParams = params?.let { ParsingHelper.merge(params.filterNotNull(), requiredParams) } ?: requiredParams val paramsAsString = helper.jsonEncoder.encode(mergedParams) helper.ioImplementations.threading?.async(ThreadingType.main) { diff --git a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/SubaccountTransactionTracker.kt b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/SubaccountTransactionTracker.kt index 367d7cdc0..769ee55ba 100644 --- a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/SubaccountTransactionTracker.kt +++ b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/SubaccountTransactionTracker.kt @@ -47,7 +47,7 @@ internal class SubaccountTransactionTracker( } override fun tracking(eventName: String, params: IMap?) { - val requiredParams = helper.validatorUrl?.let { iMapOf("validatorUrl" to it) } ?: iMapOf() + val requiredParams = helper.apiStateParams() val mergedParams = params?.let { ParsingHelper.merge(params.filterNotNull(), requiredParams) } ?: requiredParams From 6346be573a2c5a538bd32c88b2bafc52cdb69d75 Mon Sep 17 00:00:00 2001 From: aforaleka Date: Tue, 24 Sep 2024 16:39:06 -0400 Subject: [PATCH 2/3] spotless --- .../state/v2/supervisor/NetworkSupervisor.kt | 1 - 1 file changed, 1 deletion(-) diff --git a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt index f6271989a..a21b9586e 100644 --- a/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt +++ b/src/commonMain/kotlin/exchange.dydx.abacus/state/v2/supervisor/NetworkSupervisor.kt @@ -9,7 +9,6 @@ import exchange.dydx.abacus.utils.AnalyticsUtils import exchange.dydx.abacus.utils.IMap import exchange.dydx.abacus.utils.ParsingHelper import exchange.dydx.abacus.utils.filterNotNull -import exchange.dydx.abacus.utils.iMapOf import kollections.iListOf internal open class NetworkSupervisor( From 38b3cb7d4e61425d0bc317af183f8518ffd9523e Mon Sep 17 00:00:00 2001 From: aforaleka Date: Tue, 24 Sep 2024 16:48:27 -0400 Subject: [PATCH 3/3] bump again --- build.gradle.kts | 2 +- v4_abacus.podspec | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 3853f483b..ef118d7f1 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -52,7 +52,7 @@ allprojects { } group = "exchange.dydx.abacus" -version = "1.11.16" +version = "1.11.17" repositories { google() diff --git a/v4_abacus.podspec b/v4_abacus.podspec index 7ce4450df..1e475ac89 100644 --- a/v4_abacus.podspec +++ b/v4_abacus.podspec @@ -1,6 +1,6 @@ Pod::Spec.new do |spec| spec.name = 'v4_abacus' - spec.version = '1.11.16' + spec.version = '1.11.17' spec.homepage = 'https://github.com/dydxprotocol/v4-abacus' spec.source = { :http=> ''} spec.authors = ''