|  | // Copyright 2012 The Chromium Authors | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ | 
|  | #define CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  |  | 
|  | #include "base/memory/weak_ptr.h" | 
|  | #include "content/public/browser/browser_thread.h" | 
|  | #include "content/public/browser/speech_recognition_event_listener.h" | 
|  | #include "media/mojo/mojom/speech_recognizer.mojom.h" | 
|  | #include "mojo/public/cpp/bindings/pending_receiver.h" | 
|  | #include "mojo/public/cpp/bindings/pending_remote.h" | 
|  | #include "mojo/public/cpp/bindings/remote.h" | 
|  |  | 
|  | namespace network { | 
|  | class PendingSharedURLLoaderFactory; | 
|  | } | 
|  |  | 
|  | namespace url { | 
|  | class Origin; | 
|  | } | 
|  |  | 
|  | namespace content { | 
|  |  | 
|  | class SpeechRecognitionManager; | 
|  | struct SpeechRecognitionSessionConfig; | 
|  | struct SpeechRecognitionAudioForwarderConfig; | 
|  |  | 
|  | // SpeechRecognitionDispatcherHost is an implementation of the SpeechRecognizer | 
|  | // interface that allows a RenderFrame to start a speech recognition session | 
|  | // in the browser process, by communicating with SpeechRecognitionManager. | 
|  | class SpeechRecognitionDispatcherHost : public media::mojom::SpeechRecognizer { | 
|  | public: | 
|  | SpeechRecognitionDispatcherHost(int render_process_id, int render_frame_id); | 
|  |  | 
|  | SpeechRecognitionDispatcherHost(const SpeechRecognitionDispatcherHost&) = | 
|  | delete; | 
|  | SpeechRecognitionDispatcherHost& operator=( | 
|  | const SpeechRecognitionDispatcherHost&) = delete; | 
|  |  | 
|  | ~SpeechRecognitionDispatcherHost() override; | 
|  | static void Create( | 
|  | int render_process_id, | 
|  | int render_frame_id, | 
|  | mojo::PendingReceiver<media::mojom::SpeechRecognizer> receiver); | 
|  | base::WeakPtr<SpeechRecognitionDispatcherHost> AsWeakPtr(); | 
|  |  | 
|  | // media::mojom::SpeechRecognizer implementation | 
|  | void Start( | 
|  | media::mojom::StartSpeechRecognitionRequestParamsPtr params) override; | 
|  |  | 
|  | private: | 
|  | static void StartRequestOnUI( | 
|  | base::WeakPtr<SpeechRecognitionDispatcherHost> | 
|  | speech_recognition_dispatcher_host, | 
|  | int render_process_id, | 
|  | int render_frame_id, | 
|  | media::mojom::StartSpeechRecognitionRequestParamsPtr params); | 
|  | void StartSessionOnIO( | 
|  | media::mojom::StartSpeechRecognitionRequestParamsPtr params, | 
|  | int embedder_render_process_id, | 
|  | int embedder_render_frame_id, | 
|  | const url::Origin& origin, | 
|  | std::unique_ptr<network::PendingSharedURLLoaderFactory> | 
|  | pending_shared_url_loader_factory, | 
|  | const std::string& language, | 
|  | bool can_render_frame_use_on_device, | 
|  | bool on_device_available); | 
|  |  | 
|  | int CreateSession( | 
|  | const SpeechRecognitionSessionConfig& config, | 
|  | mojo::PendingReceiver<media::mojom::SpeechRecognitionSession> | 
|  | session_receiver, | 
|  | mojo::PendingRemote<media::mojom::SpeechRecognitionSessionClient> | 
|  | client_remote, | 
|  | std::optional<SpeechRecognitionAudioForwarderConfig> | 
|  | audio_forwarder_config, | 
|  | bool can_render_frame_use_on_device); | 
|  |  | 
|  | const int render_process_id_; | 
|  | const int render_frame_id_; | 
|  |  | 
|  | // Used for posting asynchronous tasks (on the IO thread) without worrying | 
|  | // about this class being destroyed in the meanwhile (due to browser shutdown) | 
|  | // since tasks pending on a destroyed WeakPtr are automatically discarded. | 
|  | base::WeakPtrFactory<SpeechRecognitionDispatcherHost> weak_factory_{this}; | 
|  | }; | 
|  |  | 
|  | }  // namespace content | 
|  |  | 
|  | #endif  // CONTENT_BROWSER_SPEECH_SPEECH_RECOGNITION_DISPATCHER_HOST_H_ |