/// <summary> /// Начать запись разговора /// </summary> protected async Task StartCallRecording(string initialChannelId, Guid initialCallId, string extension, ChannelRoleType role, string mainBridgeId, Guid?lineId = null) { if (!_asteriskOptions.RecordingEnabled) { return; } var recordsBridgeId = GetCommonRecordingBridgeId(mainBridgeId); var fullAudioRecord = new AudioRecord { FileName = $"{recordsBridgeId}", LineId = lineId, CallId = null }; await AudioRecordRepository.AddAudioRecord(fullAudioRecord); await AriClient.CreateBridge(recordsBridgeId); await AddChannelToCommonRecordingBridge(initialChannelId, extension, role, mainBridgeId, initialCallId, lineId); var result = await AriClient.StartRecordingBridge(recordsBridgeId); if (result.IsFailure) { Logger.Warning($"StartCallRecording. Failed to start call recording. MainBridgeId: {mainBridgeId}"); return; } await CreateSnoopChannelForRecording(initialChannelId, extension, role, false, initialCallId, lineId); Logger.Information($"StartRecordingBridge. Bridge recording started. {mainBridgeId}"); }