Track non-fatal issues via analytics

This commit is contained in:
Andy Uhnak
2022-06-15 17:43:52 +01:00
parent bd8b07113a
commit f1cd863330
4 changed files with 90 additions and 3 deletions
+15 -2
View File
@@ -17,8 +17,12 @@
import PostHog
import AnalyticsEvents
/// A class responsible for managing an analytics client
/// and sending events through this client.
/// A class responsible for managing a variety of analytics clients
/// and sending events through these clients.
///
/// Events may include user activity, or app health data such as crashes,
/// non-fatal issues and performance. `Analytics` class serves as a façade
/// to all these use cases.
///
/// ## Creating Analytics Events
///
@@ -42,6 +46,9 @@ import AnalyticsEvents
/// The analytics client to send events with.
private var client: AnalyticsClientProtocol = PostHogAnalyticsClient()
/// The monitoring client to track crashes, issues and performance
private var monitoringClient = SentryMonitoringClient()
/// The service used to interact with account data settings.
private var service: AnalyticsService?
@@ -106,6 +113,7 @@ import AnalyticsEvents
// The order is important here. PostHog ignores the reset if stopped.
reset()
client.stop()
monitoringClient.stop()
MXLog.debug("[Analytics] Stopped.")
}
@@ -115,6 +123,7 @@ import AnalyticsEvents
guard RiotSettings.shared.enableAnalytics, !isRunning else { return }
client.start()
monitoringClient.start()
// Sanity check in case something went wrong.
guard client.isRunning else { return }
@@ -163,6 +172,7 @@ import AnalyticsEvents
/// Note: **MUST** be called before stopping PostHog or the reset is ignored.
func reset() {
client.reset()
monitoringClient.reset()
MXLog.debug("[Analytics] Reset.")
RiotSettings.shared.isIdentifiedForAnalytics = false
@@ -374,4 +384,7 @@ extension Analytics: MXAnalyticsDelegate {
capture(event: event)
}
func trackNonFatalIssue(_ issue: String, details: [String : Any]?) {
monitoringClient.trackNonFatalIssue(issue, details: details)
}
}
@@ -0,0 +1,67 @@
//
// Copyright 2022 New Vector Ltd
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
import Foundation
import Sentry
import MatrixSDK
/// Sentry client used as part of the Analytics set of tools to track health metrics
/// of the application, such as crashes, non-fatal issues and performance.
///
/// All analytics tracking, incl. health metrics, is subject to user consent,
/// configurable in user settings.
struct SentryMonitoringClient {
private static let sentryDSN = "https://a5e37731f9b94642a1b93093cacbee4c@sentry.tools.element.io/47"
func start() {
guard !SentrySDK.isEnabled else { return }
MXLog.debug("[SentryMonitoringClient] Started")
SentrySDK.start { options in
options.dsn = Self.sentryDSN
options.tracesSampleRate = 1.0
options.beforeSend = { event in
MXLog.error("[SentryMonitoringClient] Issue detected: \(event)")
return event
}
options.onCrashedLastRun = { event in
MXLog.debug("[SentryMonitoringClient] Last run crashed: \(event)")
}
}
}
func stop() {
MXLog.debug("[SentryMonitoringClient] Stopped")
SentrySDK.close()
}
func reset() {
MXLog.debug("[SentryMonitoringClient] Reset")
SentrySDK.startSession()
}
func trackNonFatalIssue(_ issue: String, details: [String: Any]?) {
guard SentrySDK.isEnabled else { return }
let event = Event()
event.level = .error
event.message = .init(formatted: issue)
event.extra = details
SentrySDK.capture(event: event)
}
}