Index: content/browser/renderer_host/media/audio_output_service_context.cc |
diff --git a/content/browser/renderer_host/media/audio_output_service_context.cc b/content/browser/renderer_host/media/audio_output_service_context.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..97a383747f92e50ea5402572d246534aeffafda2 |
--- /dev/null |
+++ b/content/browser/renderer_host/media/audio_output_service_context.cc |
@@ -0,0 +1,93 @@ |
+// Copyright 2017 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "content/browser/renderer_host/media/audio_output_service_context.h" |
+ |
+#include <algorithm> |
+#include <memory> |
+#include <utility> |
+ |
+#include "base/memory/ptr_util.h" |
+#include "content/browser/media/media_internals.h" |
+#include "content/browser/renderer_host/media/audio_output_impl.h" |
+#include "content/browser/renderer_host/media/audio_output_service_impl.h" |
+#include "content/public/browser/browser_thread.h" |
+#include "content/public/browser/content_browser_client.h" |
+#include "content/public/browser/render_frame_host.h" |
+#include "content/public/common/content_client.h" |
+#include "media/mojo/interfaces/audio_output.mojom.h" |
+ |
+namespace content { |
+ |
+AudioOutputServiceContext::AudioOutputServiceContext( |
+ int render_process_id, |
+ media::AudioManager* audio_manager, |
+ MediaStreamManager* media_stream_manager, |
+ AudioMirroringManager* mirroring_manager, |
+ const std::string& salt) |
+ : render_process_id_(render_process_id), |
+ audio_manager_(audio_manager), |
+ media_stream_manager_(media_stream_manager), |
+ mirroring_manager_(mirroring_manager), |
+ salt_(salt), |
+ authorization_handler_(audio_manager_, |
+ media_stream_manager_, |
+ render_process_id_, |
+ salt_), |
+ services_() {} |
+ |
+AudioOutputServiceContext::~AudioOutputServiceContext() { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+} |
+ |
+void AudioOutputServiceContext::ServiceHadConnectionError( |
+ AudioOutputServiceImpl* service) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ |
+ auto it = std::find_if( |
+ services_.begin(), services_.end(), |
+ [service](const std::unique_ptr<AudioOutputServiceImpl>& other_service) { |
+ return service == other_service.get(); |
+ }); |
+ if (it == services_.end()) |
+ return; |
+ std::swap(*it, services_.back()); |
+ services_.pop_back(); |
+} |
+ |
+void AudioOutputServiceContext::CreateService( |
+ int frame_host_id, |
+ mojo::InterfaceRequest<media::mojom::AudioOutputService> request) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ |
+ services_.push_back(base::MakeUnique<AudioOutputServiceImpl>( |
+ this, frame_host_id, |
+ base::Bind(&AudioOutputServiceContext::ServiceHadConnectionError, |
+ base::Unretained(this)), |
+ std::move(request))); |
+} |
+ |
+AudioOutputDelegate::UniquePtr AudioOutputServiceContext::CreateDelegate( |
+ const std::string& unique_device_id, |
+ int render_frame_id, |
+ AudioOutputDelegate::EventHandler* handler, |
+ const media::AudioParameters& params) { |
+ DCHECK_CURRENTLY_ON(BrowserThread::IO); |
+ int stream_id = next_stream_id_++; |
+ MediaObserver* const media_observer = |
+ GetContentClient()->browser()->GetMediaObserver(); |
+ |
+ MediaInternals* const media_internals = MediaInternals::GetInstance(); |
+ std::unique_ptr<media::AudioLog> audio_log = media_internals->CreateAudioLog( |
+ media::AudioLogFactory::AUDIO_OUTPUT_CONTROLLER); |
+ media_internals->SetWebContentsTitleForAudioLogEntry( |
+ stream_id, render_process_id_, render_frame_id, audio_log.get()); |
+ |
+ return AudioOutputDelegate::Create( |
+ handler, audio_manager_, std::move(audio_log), mirroring_manager_, |
+ media_observer, stream_id, render_frame_id, render_process_id_, params, |
+ unique_device_id); |
+} |
+ |
+} // namespace content |