private async Task RunUserScripts(IList orders) { if (orders == null || orders.Count == 0) { return; } List <UserScript> scripts; using (var dbContext = _contextFactory.Get()) { scripts = dbContext.UserScripts.Where(x => x.Type == UserScriptType.OrderScript).ToList(); } foreach (var script in scripts) { try { await _scriptRunner.RunOrderScript(script, orders.Cast <Order>().ToList()).ConfigureAwait(false); } catch (Exception ex) { _logger.Log(LogLevel.Error, "User script {0} generated an exception: ", script.Name); _logger.Log(LogLevel.Error, ex); await DialogService.ShowMessageAsync(Parent, "Error", $"User script {script.Name} generated an exception: {ex.Message}. See log for more details."); } } }