summaryrefslogtreecommitdiffstats
path: root/content/plugin
diff options
context:
space:
mode:
authorjschuh@chromium.org <jschuh@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-10-05 02:44:14 +0000
committerjschuh@chromium.org <jschuh@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-10-05 02:44:14 +0000
commit1b89a68deb23e3f86d9a718ef5814e532f058af5 (patch)
tree7c1b2d8f1b746823121ec45847c29c06384eae30 /content/plugin
parent56b95eb48a08b498ca9a27b12ebfd915eee1c043 (diff)
downloadchromium_src-1b89a68deb23e3f86d9a718ef5814e532f058af5.zip
chromium_src-1b89a68deb23e3f86d9a718ef5814e532f058af5.tar.gz
chromium_src-1b89a68deb23e3f86d9a718ef5814e532f058af5.tar.bz2
Remove Legacy NPAPI Flash Sandbox support
BUG=153599 Review URL: https://chromiumcodereview.appspot.com/11049004 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@160310 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/plugin')
-rw-r--r--content/plugin/plugin_main.cc110
-rw-r--r--content/plugin/webplugin_proxy.cc10
-rw-r--r--content/plugin/webplugin_proxy.h2
3 files changed, 1 insertions, 121 deletions
diff --git a/content/plugin/plugin_main.cc b/content/plugin/plugin_main.cc
index d31f016..7bef97c 100644
--- a/content/plugin/plugin_main.cc
+++ b/content/plugin/plugin_main.cc
@@ -41,56 +41,6 @@ void InitializeChromeApplication();
void WorkaroundFlashLAHF();
#endif
-#if defined(OS_WIN)
-// This function is provided so that the built-in flash can lock down the
-// sandbox by calling DelayedLowerToken(0).
-extern "C" DWORD __declspec(dllexport) __stdcall DelayedLowerToken(void* ts) {
- // s_ts is only set the first time the function is called, which happens
- // in PluginMain.
- static sandbox::TargetServices* s_ts =
- reinterpret_cast<sandbox::TargetServices*>(ts);
- if (ts)
- return 0;
- s_ts->LowerToken();
- return 1;
-};
-
-// Returns true if the plugin to be loaded is the internal flash.
-bool IsPluginBuiltInFlash(const CommandLine& cmd_line) {
- FilePath path = cmd_line.GetSwitchValuePath(switches::kPluginPath);
- return (path.BaseName() == FilePath(L"gcswf32.dll"));
-}
-
-// Before we lock down the flash sandbox, we need to activate the IME machinery
-// and attach it to this process. (Windows attaches an IME machinery to this
-// process automatically while it creates its first top-level window.) After
-// lock down it seems it is unable to start. Note that we leak the IME context
-// on purpose.
-HWND g_ime_window = NULL;
-
-int PreloadIMEForFlash() {
- HIMC imc = ::ImmCreateContext();
- if (!imc)
- return 0;
- if (::ImmGetOpenStatus(imc))
- return 1;
- if (!g_ime_window) {
- g_ime_window = CreateWindowEx(WS_EX_TOOLWINDOW, L"EDIT", L"", WS_POPUP,
- 0, 0, 0, 0, NULL, NULL, GetModuleHandle(NULL), NULL);
- SetWindowLongPtr(g_ime_window, GWL_EXSTYLE, WS_EX_NOACTIVATE);
- }
- return 2;
-}
-
-void DestroyIMEForFlash() {
- if (g_ime_window) {
- DestroyWindow(g_ime_window);
- g_ime_window = NULL;
- }
-}
-
-#endif
-
// main() routine for running as the plugin process.
int PluginMain(const content::MainFunctionParams& parameters) {
// The main thread of the plugin services UI.
@@ -115,27 +65,9 @@ int PluginMain(const content::MainFunctionParams& parameters) {
#endif
#elif defined(OS_WIN)
- sandbox::TargetServices* target_services =
- parameters.sandbox_info->target_services;
-
base::win::ScopedCOMInitializer com_initializer;
-
- DVLOG(1) << "Started plugin with "
- << parsed_command_line.GetCommandLineString();
-
- HMODULE sandbox_test_module = NULL;
- bool no_sandbox = parsed_command_line.HasSwitch(switches::kNoSandbox);
-
- if (target_services && !no_sandbox) {
- // The command line might specify a test plugin to load.
- if (parsed_command_line.HasSwitch(switches::kTestSandbox)) {
- std::wstring test_plugin_name =
- parsed_command_line.GetSwitchValueNative(switches::kTestSandbox);
- sandbox_test_module = LoadLibrary(test_plugin_name.c_str());
- DCHECK(sandbox_test_module);
- }
- }
#endif
+
if (parsed_command_line.HasSwitch(switches::kPluginStartupDialog)) {
ChildProcess::WaitForDebugger("Plugin");
}
@@ -143,48 +75,8 @@ int PluginMain(const content::MainFunctionParams& parameters) {
{
ChildProcess plugin_process;
plugin_process.set_main_thread(new PluginThread());
-#if defined(OS_WIN)
- if (!no_sandbox && target_services) {
- // We are sandboxing the plugin. If it is a generic plug-in, we lock down
- // the sandbox right away, but if it is the built-in flash we let flash
- // start elevated and it will call DelayedLowerToken(0) when it's ready.
- if (IsPluginBuiltInFlash(parsed_command_line)) {
- DVLOG(1) << "Sandboxing flash";
-
- if (!PreloadIMEForFlash())
- DVLOG(1) << "IME preload failed";
- DelayedLowerToken(target_services);
- } else {
- target_services->LowerToken();
- }
- }
- if (sandbox_test_module) {
- RunPluginTests run_security_tests =
- reinterpret_cast<RunPluginTests>(GetProcAddress(sandbox_test_module,
- kPluginTestCall));
- DCHECK(run_security_tests);
- if (run_security_tests) {
- int test_count = 0;
- DVLOG(1) << "Running plugin security tests";
- BOOL result = run_security_tests(&test_count);
- DCHECK(result) << "Test number " << test_count << " has failed.";
- // If we are in release mode, crash or debug the process.
- if (!result) {
- __debugbreak();
- _exit(1);
- }
- }
-
- FreeLibrary(sandbox_test_module);
- }
-#endif
-
MessageLoop::current()->Run();
}
-#if defined(OS_WIN)
- DestroyIMEForFlash();
-#endif
-
return 0;
}
diff --git a/content/plugin/webplugin_proxy.cc b/content/plugin/webplugin_proxy.cc
index 937496e..3704bc7 100644
--- a/content/plugin/webplugin_proxy.cc
+++ b/content/plugin/webplugin_proxy.cc
@@ -148,16 +148,6 @@ void WebPluginProxy::SetWindowlessPumpEvent(HANDLE pump_messages_event) {
Send(new PluginHostMsg_SetWindowlessPumpEvent(
route_id_, pump_messages_event_for_renderer));
}
-
-void WebPluginProxy::ReparentPluginWindow(HWND window, HWND parent) {
- PluginThread::current()->Send(
- new PluginProcessHostMsg_ReparentPluginWindow(window, parent));
-}
-
-void WebPluginProxy::ReportExecutableMemory(size_t size) {
- PluginThread::current()->Send(
- new PluginProcessHostMsg_ReportExecutableMemory(size));
-}
#endif
void WebPluginProxy::CancelResource(unsigned long id) {
diff --git a/content/plugin/webplugin_proxy.h b/content/plugin/webplugin_proxy.h
index 9476bd1..d8ad48f 100644
--- a/content/plugin/webplugin_proxy.h
+++ b/content/plugin/webplugin_proxy.h
@@ -67,8 +67,6 @@ class WebPluginProxy : public webkit::npapi::WebPlugin {
virtual void WillDestroyWindow(gfx::PluginWindowHandle window) OVERRIDE;
#if defined(OS_WIN)
void SetWindowlessPumpEvent(HANDLE pump_messages_event);
- void ReparentPluginWindow(HWND window, HWND parent);
- void ReportExecutableMemory(size_t size);
#endif
virtual void CancelResource(unsigned long id) OVERRIDE;