/// <summary> /// Выполняет запрос сервиса к дб /// </summary> /// <returns></returns> private async Task <System.Windows.Forms.TreeNode[]> LoadDepartmentStructure() { List <System.Windows.Forms.TreeNode> result = new List <System.Windows.Forms.TreeNode>(); try { _departmentStructure = (await _serviceManager.GetDepartmentStructureWithEmployees()).ToList(); foreach (var dep in _departmentStructure) { result.Add(GetSubNodes(dep)); } } catch (FaultException <DefaultFault> ex) // контролируемая ситуация на сервисе { // сообщение об ошибке для пользователя MessageBox.Show(ex.Detail.Message, ex.Action, MessageBoxButtons.OK, MessageBoxIcon.Error); } catch (FaultException) // непредвиденная проблема на сервисе, см лог на сервисе { // неизвестная ошибка на сервисе MessageBox.Show("Неизвестная ошибка сервиса. Операция не выполнена.", null, MessageBoxButtons.OK, MessageBoxIcon.Error); } catch (Exception ex) // что-то совсем пошло не так (включая CommunicationException и TimeOutException) { MessageBox.Show("Возникла ошибка: " + ex.Message, null, MessageBoxButtons.OK, MessageBoxIcon.Error); _logger.Error(ex, "Ошибка во время зарузки"); } return(result.ToArray()); }