// Copyright (c) 2010 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. #ifndef CHROME_PLUGIN_PLUGIN_CHANNEL_H_ #define CHROME_PLUGIN_PLUGIN_CHANNEL_H_ #pragma once #include #include "base/ref_counted.h" #include "base/scoped_handle.h" #include "build/build_config.h" #include "chrome/plugin/plugin_channel_base.h" #include "chrome/plugin/webplugin_delegate_stub.h" namespace base { class WaitableEvent; } // Encapsulates an IPC channel between the plugin process and one renderer // process. On the renderer side there's a corresponding PluginChannelHost. class PluginChannel : public PluginChannelBase { public: // Get a new PluginChannel object for the current process to talk to the // given renderer process. The renderer ID is an opaque unique ID generated // by the browser. static PluginChannel* GetPluginChannel(int renderer_id, MessageLoop* ipc_message_loop); // Send a message to all renderers that the process is going to shutdown. static void NotifyRenderersOfPendingShutdown(); ~PluginChannel(); virtual bool Send(IPC::Message* msg); virtual void OnMessageReceived(const IPC::Message& message); base::ProcessHandle renderer_handle() const { return renderer_handle_; } int renderer_id() { return renderer_id_; } int GenerateRouteID(); // Returns the event that's set when a call to the renderer causes a modal // dialog to come up. base::WaitableEvent* GetModalDialogEvent(gfx::NativeViewId containing_window); bool in_send() { return in_send_ != 0; } bool off_the_record() { return off_the_record_; } void set_off_the_record(bool value) { off_the_record_ = value; } #if defined(OS_POSIX) int renderer_fd() const { return renderer_fd_; } #endif protected: // IPC::Channel::Listener implementation: virtual void OnChannelConnected(int32 peer_pid); virtual void OnChannelError(); virtual void CleanUp(); // Overrides PluginChannelBase::Init. virtual bool Init(MessageLoop* ipc_message_loop, bool create_pipe_now); private: class MessageFilter; // Called on the plugin thread PluginChannel(); void OnControlMessageReceived(const IPC::Message& msg); static PluginChannelBase* ClassFactory() { return new PluginChannel(); } void OnCreateInstance(const std::string& mime_type, int* instance_id); void OnDestroyInstance(int instance_id, IPC::Message* reply_msg); void OnGenerateRouteID(int* route_id); #if defined(OS_POSIX) // Close the plugin process' copy of the renderer's side of the plugin // channel. This can be called after the renderer is known to have its own // copy of renderer_fd_. void CloseRendererFD(); #endif std::vector > plugin_stubs_; // Handle to the renderer process who is on the other side of the channel. base::ProcessHandle renderer_handle_; // The id of the renderer who is on the other side of the channel. int renderer_id_; #if defined(OS_POSIX) // FD for the renderer end of the socket. It is closed when the IPC layer // indicates that the channel is connected, proving that the renderer has // access to its side of the socket. int renderer_fd_; #endif int in_send_; // Tracks if we're in a Send call. bool log_messages_; // True if we should log sent and received messages. bool off_the_record_; // True if the renderer is in off the record mode. scoped_refptr filter_; // Handles the modal dialog events. DISALLOW_COPY_AND_ASSIGN(PluginChannel); }; #endif // CHROME_PLUGIN_PLUGIN_CHANNEL_H_