public void RefreshToken() { _logger.Trace("Refreshing Token"); Settings.Validate().Filter("RefreshToken").ThrowOnError(); try { var response = _traktService.RefreshAuthToken(Settings.RefreshToken); if (response != null) { var token = response; Settings.AccessToken = token.AccessToken; Settings.Expires = DateTime.UtcNow.AddSeconds(token.ExpiresIn); Settings.RefreshToken = token.RefreshToken ?? Settings.RefreshToken; if (Definition.Id > 0) { _notificationRepository.UpdateSettings((NotificationDefinition)Definition); } } } catch (HttpException) { _logger.Warn($"Error refreshing trakt access token"); } }