diff options
author | thomasvl@chromium.org <thomasvl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-17 19:08:44 +0000 |
---|---|---|
committer | thomasvl@chromium.org <thomasvl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-17 19:08:44 +0000 |
commit | e8aa85cde74fd420944f97135361f81a958fe87c (patch) | |
tree | 7db7fa11203a0dd32f4c95a0165bd04b1270696a | |
parent | 1f0944969056e5fa1eb6caf35445439deb9e840f (diff) | |
download | chromium_src-e8aa85cde74fd420944f97135361f81a958fe87c.zip chromium_src-e8aa85cde74fd420944f97135361f81a958fe87c.tar.gz chromium_src-e8aa85cde74fd420944f97135361f81a958fe87c.tar.bz2 |
mac renderer sandbox cleanup:
- rename the mac platform delegate to be .mm so we can use cocoa in it.
- added the sandbox profile jeremy figured out.
- add the profile file to the project build.
- during renderer startup, check the process type and use our custom profile or
the pure compute profile based on if we're a renderer or a unittest.
Review URL: http://codereview.chromium.org/21419
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@9895 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/chrome.xcodeproj/project.pbxproj | 12 | ||||
-rw-r--r-- | chrome/renderer/renderer.sb | 15 | ||||
-rw-r--r-- | chrome/renderer/renderer_main_platform_delegate_mac.mm (renamed from chrome/renderer/renderer_main_platform_delegate_mac.cc) | 30 |
3 files changed, 47 insertions, 10 deletions
diff --git a/chrome/chrome.xcodeproj/project.pbxproj b/chrome/chrome.xcodeproj/project.pbxproj index c644006..817b271 100644 --- a/chrome/chrome.xcodeproj/project.pbxproj +++ b/chrome/chrome.xcodeproj/project.pbxproj @@ -322,7 +322,7 @@ B503E1030F017C1000547DC6 /* librenderer.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 4D640CEB0EAE86BD00EBCFC0 /* librenderer.a */; }; B507AC1F0F0048E10060FEE8 /* ipc_sync_message.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D7BFBBA0E9D4C9F009A6919 /* ipc_sync_message.cc */; }; B507AC440F004B610060FEE8 /* ipc_sync_message_unittest.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D7BFBBC0E9D4C9F009A6919 /* ipc_sync_message_unittest.cc */; }; - B51F6D150F37C4DC00152D66 /* renderer_main_platform_delegate_mac.cc in Sources */ = {isa = PBXBuildFile; fileRef = B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.cc */; }; + B51F6D150F37C4DC00152D66 /* renderer_main_platform_delegate_mac.mm in Sources */ = {isa = PBXBuildFile; fileRef = B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.mm */; }; B51F6D2E0F37D04200152D66 /* renderer_main.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D640CD90EAE868600EBCFC0 /* renderer_main.cc */; }; B52E29BE0F0AA333008AD1C8 /* l10n_util_unittest.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D7BFBCB0E9D4C9F009A6919 /* l10n_util_unittest.cc */; }; B54BD8FC0ED622C00093FD54 /* mach_message_source_mac.cc in Sources */ = {isa = PBXBuildFile; fileRef = B54BD8FA0ED622C00093FD54 /* mach_message_source_mac.cc */; }; @@ -581,6 +581,7 @@ E9104FE91402AE1783A22D93 /* alternate_nav_url_fetcher.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D7BF8240E9D4839009A6919 /* alternate_nav_url_fetcher.cc */; }; EA8058FD371756B46906B157 /* password_manager.cc in Sources */ = {isa = PBXBuildFile; fileRef = B5D16EB40F21445600861FAC /* password_manager.cc */; }; F081CEE97F8C75FEAF3D0FD2 /* jstemplate_builder.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D7BFBC70E9D4C9F009A6919 /* jstemplate_builder.cc */; }; + F4143C8C0F4B1D43008C8F73 /* renderer.sb in Resources */ = {isa = PBXBuildFile; fileRef = F4143C8B0F4B1D07008C8F73 /* renderer.sb */; }; F47CA1280F44AE0E00FFFAFB /* libnet.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 4D7B004E0E9D5464009A6919 /* libnet.a */; }; F47CA1290F44AE2800FFFAFB /* libglue.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 826850180F2FC82E009F6555 /* libglue.a */; }; F47CA12A0F44AE3500FFFAFB /* libwtf.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 826850240F2FC82E009F6555 /* libwtf.a */; }; @@ -2489,7 +2490,7 @@ B020A11D500D7519E54F2957 /* tab_restore_service.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = tab_restore_service.cc; path = sessions/tab_restore_service.cc; sourceTree = "<group>"; }; B51F6D110F37C4DC00152D66 /* renderer_main_platform_delegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = renderer_main_platform_delegate.h; sourceTree = "<group>"; }; B51F6D120F37C4DC00152D66 /* renderer_main_platform_delegate_win.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = renderer_main_platform_delegate_win.cc; sourceTree = "<group>"; }; - B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = renderer_main_platform_delegate_mac.cc; sourceTree = "<group>"; }; + B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.mm */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.objcpp; path = renderer_main_platform_delegate_mac.mm; sourceTree = "<group>"; }; B54BD8FA0ED622C00093FD54 /* mach_message_source_mac.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = mach_message_source_mac.cc; sourceTree = "<group>"; }; B54BD8FB0ED622C00093FD54 /* mach_message_source_mac.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = mach_message_source_mac.h; sourceTree = "<group>"; }; B555B2160F21504D00F751B9 /* metrics_service.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = metrics_service.h; path = metrics/metrics_service.h; sourceTree = "<group>"; }; @@ -2765,6 +2766,7 @@ E4F324790EE5D17E002533CE /* referrer.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = referrer.cc; sourceTree = "<group>"; }; EA72C084DB3FC0FC595E525E /* template_url_model.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = template_url_model.cc; sourceTree = "<group>"; }; EA72CF50C0AB4492A644C703 /* url_fetcher.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = url_fetcher.h; sourceTree = "<group>"; }; + F4143C8B0F4B1D07008C8F73 /* renderer.sb */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = renderer.sb; sourceTree = "<group>"; }; F60D7722C1302E1EC789B67A /* ssl_host_state.cc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = ssl_host_state.cc; path = ssl/ssl_host_state.cc; sourceTree = "<group>"; }; /* End PBXFileReference section */ @@ -3030,6 +3032,7 @@ 4D640CCF0EAE868600EBCFC0 /* render_process.cc */, 4D640CD00EAE868600EBCFC0 /* render_process.h */, 3380A9BF0F2FC61E004EF74F /* render_process_unittest.cc */, + F4143C8B0F4B1D07008C8F73 /* renderer.sb */, 4D640CD10EAE868600EBCFC0 /* render_thread.cc */, 4D640CD20EAE868600EBCFC0 /* render_thread.h */, 3380A6B50F2E9252004EF74F /* render_thread_unittest.cc */, @@ -3042,7 +3045,7 @@ 4D640CD80EAE868600EBCFC0 /* renderer_glue.cc */, 4D640CD90EAE868600EBCFC0 /* renderer_main.cc */, B51F6D110F37C4DC00152D66 /* renderer_main_platform_delegate.h */, - B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.cc */, + B51F6D130F37C4DC00152D66 /* renderer_main_platform_delegate_mac.mm */, B51F6D120F37C4DC00152D66 /* renderer_main_platform_delegate_win.cc */, B5D030EF0F3A3C43001238AB /* renderer_main_unittest.cc */, 4D640CDA0EAE868600EBCFC0 /* renderer_resources.h */, @@ -5164,6 +5167,7 @@ E43A7A070F1D192000ABD5D1 /* notAllowedCursor.png in Resources */, E43A7A080F1D192000ABD5D1 /* progressCursor.png in Resources */, E46C50560F291C1E00B393B8 /* reload.pdf in Resources */, + F4143C8C0F4B1D43008C8F73 /* renderer.sb in Resources */, 824FC14F0F44C56A000299E5 /* sadtab.png in Resources */, E43A7A090F1D192000ABD5D1 /* southEastResizeCursor.png in Resources */, E43A7A0A0F1D192000ABD5D1 /* southResizeCursor.png in Resources */, @@ -5331,7 +5335,7 @@ A7A20E650F3A1E1C00F62B4D /* render_view.cc in Sources */, B503E0F00F0175FD00547DC6 /* user_script_slave.cc in Sources */, B51F6D2E0F37D04200152D66 /* renderer_main.cc in Sources */, - B51F6D150F37C4DC00152D66 /* renderer_main_platform_delegate_mac.cc in Sources */, + B51F6D150F37C4DC00152D66 /* renderer_main_platform_delegate_mac.mm in Sources */, 4D640CF50EAE86EF00EBCFC0 /* visitedlink_slave.cc in Sources */, ); runOnlyForDeploymentPostprocessing = 0; diff --git a/chrome/renderer/renderer.sb b/chrome/renderer/renderer.sb new file mode 100644 index 0000000..3b2a1fc --- /dev/null +++ b/chrome/renderer/renderer.sb @@ -0,0 +1,15 @@ +;; +;; Copyright (c) 2009 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. +;; +(version 1) +(deny default) + +; Allow following symlinks +(allow file-read-metadata) +; Allow reading files out of /System/Library +(allow file-read-data (regex #"^/System/Library")) + +; Needed for Fonts +(allow mach-lookup (global-name "com.apple.FontObjectsServer")) diff --git a/chrome/renderer/renderer_main_platform_delegate_mac.cc b/chrome/renderer/renderer_main_platform_delegate_mac.mm index bf61141..388305d 100644 --- a/chrome/renderer/renderer_main_platform_delegate_mac.cc +++ b/chrome/renderer/renderer_main_platform_delegate_mac.mm @@ -6,12 +6,14 @@ #include "base/debug_util.h" -#include <ApplicationServices/ApplicationServices.h> +#import <Foundation/Foundation.h> +#import <ApplicationServices/ApplicationServices.h> extern "C" { #include <sandbox.h> } #include "base/sys_info.h" +#include "chrome/common/chrome_switches.h" #include "third_party/WebKit/WebKit/mac/WebCoreSupport/WebSystemInterface.h" RendererMainPlatformDelegate::RendererMainPlatformDelegate( @@ -50,10 +52,6 @@ bool RendererMainPlatformDelegate::InitSandboxTests(bool no_sandbox) { bool RendererMainPlatformDelegate::EnableSandbox() { - // TODO(port): hack - // With the sandbox on we don't have fonts in WebKit! - return true; - // This call doesn't work when the sandbox is enabled, the implementation // caches it's return value so we call it here and then future calls will // succeed. @@ -63,8 +61,28 @@ bool RendererMainPlatformDelegate::EnableSandbox() { // with the Sandbox enabled. base::SysInfo::CacheSysInfo(); + // For the renderer, we give it a custom sandbox to lock down as tight as + // possible, but still be able to draw. If we're not a renderer process, it + // usually means we're a unittest, so we use a pure compute sandbox instead. + + const char *sandbox_profile = kSBXProfilePureComputation; + uint64_t sandbox_flags = SANDBOX_NAMED; + + if (parameters_.sandbox_info_.ProcessType() == switches::kRendererProcess) { + NSString* sandbox_profile_path = + [[NSBundle mainBundle] pathForResource:@"renderer" ofType:@"sb"]; + BOOL is_dir = NO; + if (![[NSFileManager defaultManager] fileExistsAtPath:sandbox_profile_path + isDirectory:&is_dir] || is_dir) { + LOG(ERROR) << "Failed to find the sandbox profile on disk"; + return false; + } + sandbox_profile = [sandbox_profile_path fileSystemRepresentation]; + sandbox_flags = SANDBOX_NAMED_EXTERNAL; + } + char* error_buff = NULL; - int error = sandbox_init(kSBXProfilePureComputation, SANDBOX_NAMED, + int error = sandbox_init(sandbox_profile, sandbox_flags, &error_buff); bool success = (error == 0 && error_buff == NULL); if (error == -1) { |