From b58fe89ce43caa6af55f916b920cb2575c691724 Mon Sep 17 00:00:00 2001 From: "kay.one" Date: Thu, 26 Jan 2012 22:10:15 -0800 Subject: [PATCH] analytics will not leak exceptions while in production. --- NzbDrone.Core/Providers/AnalyticsProvider.cs | 32 ++++++++++++++------ 1 file changed, 23 insertions(+), 9 deletions(-) diff --git a/NzbDrone.Core/Providers/AnalyticsProvider.cs b/NzbDrone.Core/Providers/AnalyticsProvider.cs index 3d550aad1..ef484992d 100644 --- a/NzbDrone.Core/Providers/AnalyticsProvider.cs +++ b/NzbDrone.Core/Providers/AnalyticsProvider.cs @@ -1,5 +1,7 @@ -using System.Linq; +using System; +using System.Linq; using DeskMetrics; +using NLog; using Ninject; using NzbDrone.Common; @@ -7,6 +9,8 @@ namespace NzbDrone.Core.Providers { public class AnalyticsProvider { + private static readonly Logger logger = LogManager.GetCurrentClassLogger(); + private readonly IDeskMetricsClient _deskMetricsClient; public const string DESKMETRICS_TEST_ID = "4ea8d347a14ad71442000002"; public const string DESKMETRICS_PRODUCTION_ID = "4f20b01ea14ad729b2000000"; @@ -24,17 +28,27 @@ namespace NzbDrone.Core.Providers public virtual void Checkpoint() { - if (EnviromentProvider.IsNewInstall) + try { - _deskMetricsClient.RegisterInstall(); - } + if (EnviromentProvider.IsNewInstall) + { + _deskMetricsClient.RegisterInstall(); + } - if (_deskMetricsClient.Started) - { - _deskMetricsClient.Stop(); + if (_deskMetricsClient.Started) + { + _deskMetricsClient.Stop(); + } + + _deskMetricsClient.Start(); + } + catch (Exception e) + { + if (!EnviromentProvider.IsProduction) + throw; + + logger.WarnException("Error while sending analytics data.", e); } - - _deskMetricsClient.Start(); } } }