mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Add plugin placeholder and policy support (issue #1708)
- Default plugin loading policy can be specified using the new `--plugin-policy=[allow|block|detect]` command-line flag. - Move CefRequestHandler::OnBeforePluginLoad to CefRequestContextHandler and add a new policy argument that supports different actions (allow, block, detect, disable) on a per-plugin-instance basis. - Add CefContextMenuHandler::RunContextMenu for providing a custom context menu implementation. - Add CefResourceBundleHandler::GetDataResourceForScale for returning scaled resources (issue #1272). - Add CefResourceBundle for retrieving resources from the resource bundle (*.pak) files loaded by CEF during startup or via the CefResourceBundleHandler. - Linux: Fix Debug build IO access warning with CefGetMimeType. - cef_unittests: Move the refcounting implementation from TestHandler to subclasses in order to support interface inheritance from subclasses.
This commit is contained in:
		
							
								
								
									
										31
									
								
								cef.gyp
									
									
									
									
									
								
							
							
						
						
									
										31
									
								
								cef.gyp
									
									
									
									
									
								
							| @@ -409,6 +409,8 @@ | |||||||
|         'tests/cefclient/renderer/client_app_renderer.cc', |         'tests/cefclient/renderer/client_app_renderer.cc', | ||||||
|         'tests/cefclient/renderer/client_app_renderer.h', |         'tests/cefclient/renderer/client_app_renderer.h', | ||||||
|         'tests/cefclient/resources/osr_test.html', |         'tests/cefclient/resources/osr_test.html', | ||||||
|  |         'tests/cefclient/resources/pdf.html', | ||||||
|  |         'tests/cefclient/resources/pdf.pdf', | ||||||
|         'tests/unittests/browser_info_map_unittest.cc', |         'tests/unittests/browser_info_map_unittest.cc', | ||||||
|         'tests/unittests/command_line_unittest.cc', |         'tests/unittests/command_line_unittest.cc', | ||||||
|         'tests/unittests/cookie_unittest.cc', |         'tests/unittests/cookie_unittest.cc', | ||||||
| @@ -425,6 +427,7 @@ | |||||||
|         'tests/unittests/navigation_unittest.cc', |         'tests/unittests/navigation_unittest.cc', | ||||||
|         'tests/unittests/os_rendering_unittest.cc', |         'tests/unittests/os_rendering_unittest.cc', | ||||||
|         'tests/unittests/parser_unittest.cc', |         'tests/unittests/parser_unittest.cc', | ||||||
|  |         'tests/unittests/plugin_unittest.cc', | ||||||
|         'tests/unittests/print_unittest.cc', |         'tests/unittests/print_unittest.cc', | ||||||
|         'tests/unittests/process_message_unittest.cc', |         'tests/unittests/process_message_unittest.cc', | ||||||
|         'tests/unittests/request_context_unittest.cc', |         'tests/unittests/request_context_unittest.cc', | ||||||
| @@ -457,6 +460,8 @@ | |||||||
|       ], |       ], | ||||||
|       'mac_bundle_resources': [ |       'mac_bundle_resources': [ | ||||||
|         'tests/cefclient/resources/osr_test.html', |         'tests/cefclient/resources/osr_test.html', | ||||||
|  |         'tests/cefclient/resources/pdf.html', | ||||||
|  |         'tests/cefclient/resources/pdf.pdf', | ||||||
|         'tests/unittests/mac/unittests.icns', |         'tests/unittests/mac/unittests.icns', | ||||||
|         'tests/unittests/mac/English.lproj/InfoPlist.strings', |         'tests/unittests/mac/English.lproj/InfoPlist.strings', | ||||||
|         'tests/unittests/mac/English.lproj/MainMenu.xib', |         'tests/unittests/mac/English.lproj/MainMenu.xib', | ||||||
| @@ -595,6 +600,8 @@ | |||||||
|               'destination': '<(PRODUCT_DIR)/files', |               'destination': '<(PRODUCT_DIR)/files', | ||||||
|               'files': [ |               'files': [ | ||||||
|                 'tests/cefclient/resources/osr_test.html', |                 'tests/cefclient/resources/osr_test.html', | ||||||
|  |                 'tests/cefclient/resources/pdf.html', | ||||||
|  |                 'tests/cefclient/resources/pdf.pdf', | ||||||
|               ], |               ], | ||||||
|             }, |             }, | ||||||
|           ], |           ], | ||||||
| @@ -921,6 +928,7 @@ | |||||||
|         '<(DEPTH)/third_party/WebKit/public/web', |         '<(DEPTH)/third_party/WebKit/public/web', | ||||||
|         # CEF grit resource includes |         # CEF grit resource includes | ||||||
|         '<(DEPTH)/cef/libcef/resources/grit_stub', |         '<(DEPTH)/cef/libcef/resources/grit_stub', | ||||||
|  |         '<(DEPTH)/cef/libcef/resources/grit_stub/chrome', | ||||||
|         '<(grit_out_dir)', |         '<(grit_out_dir)', | ||||||
|         '<(SHARED_INTERMEDIATE_DIR)/ui/resources', |         '<(SHARED_INTERMEDIATE_DIR)/ui/resources', | ||||||
|         '<(SHARED_INTERMEDIATE_DIR)/ui/strings', |         '<(SHARED_INTERMEDIATE_DIR)/ui/strings', | ||||||
| @@ -938,6 +946,8 @@ | |||||||
|         '<(DEPTH)/chrome/chrome.gyp:safe_browsing_proto', |         '<(DEPTH)/chrome/chrome.gyp:safe_browsing_proto', | ||||||
|         '<(DEPTH)/components/components.gyp:cdm_renderer', |         '<(DEPTH)/components/components.gyp:cdm_renderer', | ||||||
|         '<(DEPTH)/components/components.gyp:component_updater', |         '<(DEPTH)/components/components.gyp:component_updater', | ||||||
|  |         '<(DEPTH)/components/components.gyp:content_settings_core_browser', | ||||||
|  |         '<(DEPTH)/components/components.gyp:content_settings_core_common', | ||||||
|         '<(DEPTH)/components/components.gyp:crash_component_breakpad_mac_to_be_deleted', |         '<(DEPTH)/components/components.gyp:crash_component_breakpad_mac_to_be_deleted', | ||||||
|         '<(DEPTH)/components/components.gyp:crx_file', |         '<(DEPTH)/components/components.gyp:crx_file', | ||||||
|         '<(DEPTH)/components/components.gyp:devtools_discovery', |         '<(DEPTH)/components/components.gyp:devtools_discovery', | ||||||
| @@ -1079,8 +1089,6 @@ | |||||||
|         'libcef/browser/extensions/pdf_extension_util.h', |         'libcef/browser/extensions/pdf_extension_util.h', | ||||||
|         'libcef/browser/extensions/pdf_web_contents_helper_client.cc', |         'libcef/browser/extensions/pdf_web_contents_helper_client.cc', | ||||||
|         'libcef/browser/extensions/pdf_web_contents_helper_client.h', |         'libcef/browser/extensions/pdf_web_contents_helper_client.h', | ||||||
|         'libcef/browser/extensions/plugin_info_message_filter.cc', |  | ||||||
|         'libcef/browser/extensions/plugin_info_message_filter.h', |  | ||||||
|         'libcef/browser/extensions/url_request_util.cc', |         'libcef/browser/extensions/url_request_util.cc', | ||||||
|         'libcef/browser/extensions/url_request_util.h', |         'libcef/browser/extensions/url_request_util.h', | ||||||
|         'libcef/browser/frame_host_impl.cc', |         'libcef/browser/frame_host_impl.cc', | ||||||
| @@ -1113,6 +1121,8 @@ | |||||||
|         'libcef/browser/pepper/device_id_fetcher.cc', |         'libcef/browser/pepper/device_id_fetcher.cc', | ||||||
|         'libcef/browser/permission_manager.cc', |         'libcef/browser/permission_manager.cc', | ||||||
|         'libcef/browser/permission_manager.h', |         'libcef/browser/permission_manager.h', | ||||||
|  |         'libcef/browser/plugins/plugin_info_message_filter.cc', | ||||||
|  |         'libcef/browser/plugins/plugin_info_message_filter.h', | ||||||
|         'libcef/browser/print_settings_impl.cc', |         'libcef/browser/print_settings_impl.cc', | ||||||
|         'libcef/browser/print_settings_impl.h', |         'libcef/browser/print_settings_impl.h', | ||||||
|         'libcef/browser/printing/printing_message_filter.cc', |         'libcef/browser/printing/printing_message_filter.cc', | ||||||
| @@ -1209,6 +1219,8 @@ | |||||||
|         'libcef/common/process_message_impl.h', |         'libcef/common/process_message_impl.h', | ||||||
|         'libcef/common/request_impl.cc', |         'libcef/common/request_impl.cc', | ||||||
|         'libcef/common/request_impl.h', |         'libcef/common/request_impl.h', | ||||||
|  |         'libcef/common/resource_bundle_impl.cc', | ||||||
|  |         'libcef/common/resource_bundle_impl.h', | ||||||
|         'libcef/common/response_impl.cc', |         'libcef/common/response_impl.cc', | ||||||
|         'libcef/common/response_impl.h', |         'libcef/common/response_impl.h', | ||||||
|         'libcef/common/response_manager.cc', |         'libcef/common/response_manager.cc', | ||||||
| @@ -1259,6 +1271,10 @@ | |||||||
|         'libcef/renderer/pepper/pepper_uma_host.cc', |         'libcef/renderer/pepper/pepper_uma_host.cc', | ||||||
|         'libcef/renderer/pepper/renderer_pepper_host_factory.cc', |         'libcef/renderer/pepper/renderer_pepper_host_factory.cc', | ||||||
|         'libcef/renderer/pepper/renderer_pepper_host_factory.h', |         'libcef/renderer/pepper/renderer_pepper_host_factory.h', | ||||||
|  |         'libcef/renderer/plugins/cef_plugin_placeholder.cc', | ||||||
|  |         'libcef/renderer/plugins/cef_plugin_placeholder.h', | ||||||
|  |         'libcef/renderer/plugins/plugin_preroller.cc', | ||||||
|  |         'libcef/renderer/plugins/plugin_preroller.h', | ||||||
|         'libcef/renderer/render_frame_observer.cc', |         'libcef/renderer/render_frame_observer.cc', | ||||||
|         'libcef/renderer/render_frame_observer.h', |         'libcef/renderer/render_frame_observer.h', | ||||||
|         'libcef/renderer/render_message_filter.cc', |         'libcef/renderer/render_message_filter.cc', | ||||||
| @@ -1400,6 +1416,13 @@ | |||||||
|         # Include sources for widevine support. |         # Include sources for widevine support. | ||||||
|         '<(DEPTH)/chrome/common/widevine_cdm_constants.cc', |         '<(DEPTH)/chrome/common/widevine_cdm_constants.cc', | ||||||
|         '<(DEPTH)/chrome/common/widevine_cdm_constants.h', |         '<(DEPTH)/chrome/common/widevine_cdm_constants.h', | ||||||
|  |         # Include sources for plugin placeholder support. | ||||||
|  |         '<(DEPTH)/chrome/browser/plugins/plugin_finder.cc', | ||||||
|  |         '<(DEPTH)/chrome/browser/plugins/plugin_finder.h', | ||||||
|  |         '<(DEPTH)/chrome/browser/plugins/plugin_metadata.cc', | ||||||
|  |         '<(DEPTH)/chrome/browser/plugins/plugin_metadata.h', | ||||||
|  |         '<(DEPTH)/components/nacl/common/nacl_constants.cc', | ||||||
|  |         '<(DEPTH)/components/nacl/common/nacl_constants.h', | ||||||
|       ], |       ], | ||||||
|       'conditions': [ |       'conditions': [ | ||||||
|         ['OS=="win"', { |         ['OS=="win"', { | ||||||
| @@ -1746,6 +1769,9 @@ | |||||||
|           'sources': [ |           'sources': [ | ||||||
|             'tests/cefclient/browser/client_app_browser.cc', |             'tests/cefclient/browser/client_app_browser.cc', | ||||||
|             'tests/cefclient/browser/client_app_browser.h', |             'tests/cefclient/browser/client_app_browser.h', | ||||||
|  |             'tests/cefclient/browser/resource_util.h', | ||||||
|  |             'tests/cefclient/browser/resource_util_mac.mm', | ||||||
|  |             'tests/cefclient/browser/resource_util_posix.cc', | ||||||
|             'tests/cefclient/common/client_app.cc', |             'tests/cefclient/common/client_app.cc', | ||||||
|             'tests/cefclient/common/client_app.h', |             'tests/cefclient/common/client_app.h', | ||||||
|             'tests/cefclient/common/client_app_other.cc', |             'tests/cefclient/common/client_app_other.cc', | ||||||
| @@ -1761,6 +1787,7 @@ | |||||||
|             'tests/unittests/frame_unittest.cc', |             'tests/unittests/frame_unittest.cc', | ||||||
|             'tests/unittests/message_router_unittest.cc', |             'tests/unittests/message_router_unittest.cc', | ||||||
|             'tests/unittests/navigation_unittest.cc', |             'tests/unittests/navigation_unittest.cc', | ||||||
|  |             'tests/unittests/plugin_unittest.cc', | ||||||
|             'tests/unittests/process_message_unittest.cc', |             'tests/unittests/process_message_unittest.cc', | ||||||
|             'tests/unittests/request_handler_unittest.cc', |             'tests/unittests/request_handler_unittest.cc', | ||||||
|             'tests/unittests/request_unittest.cc', |             'tests/unittests/request_unittest.cc', | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								cef.gypi
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								cef.gypi
									
									
									
									
									
								
							| @@ -11,6 +11,8 @@ | |||||||
|     'enable_print_preview': 0, |     'enable_print_preview': 0, | ||||||
|     # Enable support for Widevine CDM. |     # Enable support for Widevine CDM. | ||||||
|     'enable_widevine': 1, |     'enable_widevine': 1, | ||||||
|  |     # Disable support for plugin installation. | ||||||
|  |     'enable_plugin_installation': 0, | ||||||
|     'conditions': [ |     'conditions': [ | ||||||
|       # Directory for CEF source files. |       # Directory for CEF source files. | ||||||
|       [ 'OS=="win"', { |       [ 'OS=="win"', { | ||||||
|   | |||||||
| @@ -52,6 +52,7 @@ | |||||||
|       'include/cef_request_context.h', |       'include/cef_request_context.h', | ||||||
|       'include/cef_request_context_handler.h', |       'include/cef_request_context_handler.h', | ||||||
|       'include/cef_request_handler.h', |       'include/cef_request_handler.h', | ||||||
|  |       'include/cef_resource_bundle.h', | ||||||
|       'include/cef_resource_bundle_handler.h', |       'include/cef_resource_bundle_handler.h', | ||||||
|       'include/cef_resource_handler.h', |       'include/cef_resource_handler.h', | ||||||
|       'include/cef_response.h', |       'include/cef_response.h', | ||||||
| @@ -110,6 +111,7 @@ | |||||||
|       'include/capi/cef_request_context_capi.h', |       'include/capi/cef_request_context_capi.h', | ||||||
|       'include/capi/cef_request_context_handler_capi.h', |       'include/capi/cef_request_context_handler_capi.h', | ||||||
|       'include/capi/cef_request_handler_capi.h', |       'include/capi/cef_request_handler_capi.h', | ||||||
|  |       'include/capi/cef_resource_bundle_capi.h', | ||||||
|       'include/capi/cef_resource_bundle_handler_capi.h', |       'include/capi/cef_resource_bundle_handler_capi.h', | ||||||
|       'include/capi/cef_resource_handler_capi.h', |       'include/capi/cef_resource_handler_capi.h', | ||||||
|       'include/capi/cef_response_capi.h', |       'include/capi/cef_response_capi.h', | ||||||
| @@ -248,12 +250,16 @@ | |||||||
|       'libcef_dll/ctocpp/request_context_handler_ctocpp.h', |       'libcef_dll/ctocpp/request_context_handler_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/request_handler_ctocpp.cc', |       'libcef_dll/ctocpp/request_handler_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/request_handler_ctocpp.h', |       'libcef_dll/ctocpp/request_handler_ctocpp.h', | ||||||
|  |       'libcef_dll/cpptoc/resource_bundle_cpptoc.cc', | ||||||
|  |       'libcef_dll/cpptoc/resource_bundle_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/resource_bundle_handler_ctocpp.cc', |       'libcef_dll/ctocpp/resource_bundle_handler_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/resource_bundle_handler_ctocpp.h', |       'libcef_dll/ctocpp/resource_bundle_handler_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/resource_handler_ctocpp.cc', |       'libcef_dll/ctocpp/resource_handler_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/resource_handler_ctocpp.h', |       'libcef_dll/ctocpp/resource_handler_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/response_cpptoc.cc', |       'libcef_dll/cpptoc/response_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/response_cpptoc.h', |       'libcef_dll/cpptoc/response_cpptoc.h', | ||||||
|  |       'libcef_dll/cpptoc/run_context_menu_callback_cpptoc.cc', | ||||||
|  |       'libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/run_file_dialog_callback_ctocpp.cc', |       'libcef_dll/ctocpp/run_file_dialog_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/run_file_dialog_callback_ctocpp.h', |       'libcef_dll/ctocpp/run_file_dialog_callback_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/sslcert_principal_cpptoc.cc', |       'libcef_dll/cpptoc/sslcert_principal_cpptoc.cc', | ||||||
| @@ -442,12 +448,16 @@ | |||||||
|       'libcef_dll/cpptoc/request_context_handler_cpptoc.h', |       'libcef_dll/cpptoc/request_context_handler_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/request_handler_cpptoc.cc', |       'libcef_dll/cpptoc/request_handler_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/request_handler_cpptoc.h', |       'libcef_dll/cpptoc/request_handler_cpptoc.h', | ||||||
|  |       'libcef_dll/ctocpp/resource_bundle_ctocpp.cc', | ||||||
|  |       'libcef_dll/ctocpp/resource_bundle_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/resource_bundle_handler_cpptoc.cc', |       'libcef_dll/cpptoc/resource_bundle_handler_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/resource_bundle_handler_cpptoc.h', |       'libcef_dll/cpptoc/resource_bundle_handler_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/resource_handler_cpptoc.cc', |       'libcef_dll/cpptoc/resource_handler_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/resource_handler_cpptoc.h', |       'libcef_dll/cpptoc/resource_handler_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/response_ctocpp.cc', |       'libcef_dll/ctocpp/response_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/response_ctocpp.h', |       'libcef_dll/ctocpp/response_ctocpp.h', | ||||||
|  |       'libcef_dll/ctocpp/run_context_menu_callback_ctocpp.cc', | ||||||
|  |       'libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/run_file_dialog_callback_cpptoc.cc', |       'libcef_dll/cpptoc/run_file_dialog_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/run_file_dialog_callback_cpptoc.h', |       'libcef_dll/cpptoc/run_file_dialog_callback_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/sslcert_principal_ctocpp.cc', |       'libcef_dll/ctocpp/sslcert_principal_ctocpp.cc', | ||||||
|   | |||||||
| @@ -49,6 +49,29 @@ extern "C" { | |||||||
|  |  | ||||||
| struct _cef_context_menu_params_t; | struct _cef_context_menu_params_t; | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Callback structure used for continuation of custom context menu display. | ||||||
|  | /// | ||||||
|  | typedef struct _cef_run_context_menu_callback_t { | ||||||
|  |   /// | ||||||
|  |   // Base structure. | ||||||
|  |   /// | ||||||
|  |   cef_base_t base; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Complete context menu display by selecting the specified |command_id| and | ||||||
|  |   // |event_flags|. | ||||||
|  |   /// | ||||||
|  |   void (CEF_CALLBACK *cont)(struct _cef_run_context_menu_callback_t* self, | ||||||
|  |       int command_id, cef_event_flags_t event_flags); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Cancel context menu display. | ||||||
|  |   /// | ||||||
|  |   void (CEF_CALLBACK *cancel)(struct _cef_run_context_menu_callback_t* self); | ||||||
|  | } cef_run_context_menu_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle context menu events. The functions of this | // Implement this structure to handle context menu events. The functions of this | ||||||
| // structure will be called on the UI thread. | // structure will be called on the UI thread. | ||||||
| @@ -71,6 +94,20 @@ typedef struct _cef_context_menu_handler_t { | |||||||
|       struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, |       struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, | ||||||
|       struct _cef_menu_model_t* model); |       struct _cef_menu_model_t* model); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called to allow custom display of the context menu. |params| provides | ||||||
|  |   // information about the context menu state. |model| contains the context menu | ||||||
|  |   // model resulting from OnBeforeContextMenu. For custom display return true | ||||||
|  |   // (1) and execute |callback| either synchronously or asynchronously with the | ||||||
|  |   // selected command ID. For default display return false (0). Do not keep | ||||||
|  |   // references to |params| or |model| outside of this callback. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *run_context_menu)(struct _cef_context_menu_handler_t* self, | ||||||
|  |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|  |       struct _cef_context_menu_params_t* params, | ||||||
|  |       struct _cef_menu_model_t* model, | ||||||
|  |       struct _cef_run_context_menu_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to execute a command selected from the context menu. Return true (1) |   // Called to execute a command selected from the context menu. Return true (1) | ||||||
|   // if the command was handled or false (0) for the default implementation. See |   // if the command was handled or false (0) for the default implementation. See | ||||||
| @@ -232,6 +269,18 @@ typedef struct _cef_context_menu_params_t { | |||||||
|   /// |   /// | ||||||
|   cef_context_menu_edit_state_flags_t (CEF_CALLBACK *get_edit_state_flags)( |   cef_context_menu_edit_state_flags_t (CEF_CALLBACK *get_edit_state_flags)( | ||||||
|       struct _cef_context_menu_params_t* self); |       struct _cef_context_menu_params_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns true (1) if the context menu contains items specified by the | ||||||
|  |   // renderer process (for example, plugin placeholder or pepper plugin menu | ||||||
|  |   // items). | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *is_custom_menu)(struct _cef_context_menu_params_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns true (1) if the context menu was invoked from a pepper plugin. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *is_pepper_menu)(struct _cef_context_menu_params_t* self); | ||||||
| } cef_context_menu_params_t; | } cef_context_menu_params_t; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,6 +40,7 @@ | |||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
| #include "include/capi/cef_cookie_capi.h" | #include "include/capi/cef_cookie_capi.h" | ||||||
|  | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| @@ -58,12 +59,30 @@ typedef struct _cef_request_context_handler_t { | |||||||
|   cef_base_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread to retrieve the cookie manager. If this function |   // Called on the browser process IO thread to retrieve the cookie manager. If | ||||||
|   // returns NULL the default cookie manager retrievable via |   // this function returns NULL the default cookie manager retrievable via | ||||||
|   // cef_request_tContext::get_default_cookie_manager() will be used. |   // cef_request_tContext::get_default_cookie_manager() will be used. | ||||||
|   /// |   /// | ||||||
|   struct _cef_cookie_manager_t* (CEF_CALLBACK *get_cookie_manager)( |   struct _cef_cookie_manager_t* (CEF_CALLBACK *get_cookie_manager)( | ||||||
|       struct _cef_request_context_handler_t* self); |       struct _cef_request_context_handler_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called on the browser process IO thread before a plugin instance is loaded. | ||||||
|  |   // |mime_type| is the mime type of the plugin that will be loaded. | ||||||
|  |   // |plugin_url| is the content URL that the plugin will load and may be NULL. | ||||||
|  |   // |top_origin_url| is the URL for the top-level frame that contains the | ||||||
|  |   // plugin. |plugin_info| includes additional information about the plugin that | ||||||
|  |   // will be loaded. |plugin_policy| is the recommended policy. Modify | ||||||
|  |   // |plugin_policy| and return true (1) to change the policy. Return false (0) | ||||||
|  |   // to use the recommended policy. The default plugin policy can be set at | ||||||
|  |   // runtime using the `--plugin-policy=[allow|detect|block]` command-line flag. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *on_before_plugin_load)( | ||||||
|  |       struct _cef_request_context_handler_t* self, | ||||||
|  |       const cef_string_t* mime_type, const cef_string_t* plugin_url, | ||||||
|  |       const cef_string_t* top_origin_url, | ||||||
|  |       struct _cef_web_plugin_info_t* plugin_info, | ||||||
|  |       cef_plugin_policy_t* plugin_policy); | ||||||
| } cef_request_context_handler_t; | } cef_request_context_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -46,7 +46,6 @@ | |||||||
| #include "include/capi/cef_resource_handler_capi.h" | #include "include/capi/cef_resource_handler_capi.h" | ||||||
| #include "include/capi/cef_response_capi.h" | #include "include/capi/cef_response_capi.h" | ||||||
| #include "include/capi/cef_ssl_info_capi.h" | #include "include/capi/cef_ssl_info_capi.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| @@ -214,14 +213,6 @@ typedef struct _cef_request_handler_t { | |||||||
|       const cef_string_t* request_url, struct _cef_sslinfo_t* ssl_info, |       const cef_string_t* request_url, struct _cef_sslinfo_t* ssl_info, | ||||||
|       struct _cef_request_callback_t* callback); |       struct _cef_request_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on the browser process IO thread before a plugin is loaded. Return |  | ||||||
|   // true (1) to block loading of the plugin. |  | ||||||
|   /// |  | ||||||
|   int (CEF_CALLBACK *on_before_plugin_load)(struct _cef_request_handler_t* self, |  | ||||||
|       struct _cef_browser_t* browser, const cef_string_t* url, |  | ||||||
|       const cef_string_t* policy_url, struct _cef_web_plugin_info_t* info); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the browser process UI thread when a plugin has crashed. |   // Called on the browser process UI thread when a plugin has crashed. | ||||||
|   // |plugin_path| is the path of the plugin that crashed. |   // |plugin_path| is the path of the plugin that crashed. | ||||||
|   | |||||||
							
								
								
									
										107
									
								
								include/capi/cef_resource_bundle_capi.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										107
									
								
								include/capi/cef_resource_bundle_capi.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,107 @@ | |||||||
|  | // Copyright (c) 2015 Marshall A. Greenblatt. All rights reserved. | ||||||
|  | // | ||||||
|  | // Redistribution and use in source and binary forms, with or without | ||||||
|  | // modification, are permitted provided that the following conditions are | ||||||
|  | // met: | ||||||
|  | // | ||||||
|  | //    * Redistributions of source code must retain the above copyright | ||||||
|  | // notice, this list of conditions and the following disclaimer. | ||||||
|  | //    * Redistributions in binary form must reproduce the above | ||||||
|  | // copyright notice, this list of conditions and the following disclaimer | ||||||
|  | // in the documentation and/or other materials provided with the | ||||||
|  | // distribution. | ||||||
|  | //    * Neither the name of Google Inc. nor the name Chromium Embedded | ||||||
|  | // Framework nor the names of its contributors may be used to endorse | ||||||
|  | // or promote products derived from this software without specific prior | ||||||
|  | // written permission. | ||||||
|  | // | ||||||
|  | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||||
|  | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||||
|  | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||||
|  | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||||
|  | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||||
|  | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||||
|  | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||||
|  | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||||
|  | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||||
|  | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||||
|  | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool and should not edited | ||||||
|  | // by hand. See the translator.README.txt file in the tools directory for | ||||||
|  | // more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | ||||||
|  | #define CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "include/capi/cef_base_capi.h" | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | extern "C" { | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Structure used for retrieving resources from the resource bundle (*.pak) | ||||||
|  | // files loaded by CEF during startup or via the cef_resource_bundle_tHandler | ||||||
|  | // returned from cef_app_t::GetResourceBundleHandler. See CefSettings for | ||||||
|  | // additional options related to resource bundle loading. The functions of this | ||||||
|  | // structure may be called on any thread unless otherwise indicated. | ||||||
|  | /// | ||||||
|  | typedef struct _cef_resource_bundle_t { | ||||||
|  |   /// | ||||||
|  |   // Base structure. | ||||||
|  |   /// | ||||||
|  |   cef_base_t base; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns the localized string for the specified |string_id| or an NULL | ||||||
|  |   // string if the value is not found. Include cef_pack_strings.h for a listing | ||||||
|  |   // of valid string ID values. | ||||||
|  |   /// | ||||||
|  |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|  |   cef_string_userfree_t (CEF_CALLBACK *get_localized_string)( | ||||||
|  |       struct _cef_resource_bundle_t* self, int string_id); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Retrieves the contents of the specified scale independent |resource_id|. If | ||||||
|  |   // the value is found then |data| and |data_size| will be populated and this | ||||||
|  |   // function will return true (1). If the value is not found then this function | ||||||
|  |   // will return false (0). The returned |data| pointer will remain resident in | ||||||
|  |   // memory and should not be freed. Include cef_pack_resources.h for a listing | ||||||
|  |   // of valid resource ID values. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *get_data_resource)(struct _cef_resource_bundle_t* self, | ||||||
|  |       int resource_id, void** data, size_t* data_size); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Retrieves the contents of the specified |resource_id| nearest the scale | ||||||
|  |   // factor |scale_factor|. Use a |scale_factor| value of SCALE_FACTOR_NONE for | ||||||
|  |   // scale independent resources or call GetDataResource instead. If the value | ||||||
|  |   // is found then |data| and |data_size| will be populated and this function | ||||||
|  |   // will return true (1). If the value is not found then this function will | ||||||
|  |   // return false (0). The returned |data| pointer will remain resident in | ||||||
|  |   // memory and should not be freed. Include cef_pack_resources.h for a listing | ||||||
|  |   // of valid resource ID values. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *get_data_resource_for_scale)( | ||||||
|  |       struct _cef_resource_bundle_t* self, int resource_id, | ||||||
|  |       cef_scale_factor_t scale_factor, void** data, size_t* data_size); | ||||||
|  | } cef_resource_bundle_t; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Returns the global resource bundle instance. | ||||||
|  | /// | ||||||
|  | CEF_EXPORT cef_resource_bundle_t* cef_resource_bundle_get_global(); | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #ifdef __cplusplus | ||||||
|  | } | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #endif  // CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | ||||||
| @@ -46,8 +46,9 @@ extern "C" { | |||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to implement a custom resource bundle structure. The functions | // Structure used to implement a custom resource bundle structure. See | ||||||
| // of this structure may be called on multiple threads. | // CefSettings for additional options related to resource bundle loading. The | ||||||
|  | // functions of this structure may be called on multiple threads. | ||||||
| /// | /// | ||||||
| typedef struct _cef_resource_bundle_handler_t { | typedef struct _cef_resource_bundle_handler_t { | ||||||
|   /// |   /// | ||||||
| @@ -56,26 +57,38 @@ typedef struct _cef_resource_bundle_handler_t { | |||||||
|   cef_base_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve a localized translation for the string specified by |   // Called to retrieve a localized translation for the specified |string_id|. | ||||||
|   // |message_id|. To provide the translation set |string| to the translation |   // To provide the translation set |string| to the translation string and | ||||||
|   // string and return true (1). To use the default translation return false |   // return true (1). To use the default translation return false (0). Include | ||||||
|   // (0). Supported message IDs are listed in cef_pack_strings.h. |   // cef_pack_strings.h for a listing of valid string ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_localized_string)( |   int (CEF_CALLBACK *get_localized_string)( | ||||||
|       struct _cef_resource_bundle_handler_t* self, int message_id, |       struct _cef_resource_bundle_handler_t* self, int string_id, | ||||||
|       cef_string_t* string); |       cef_string_t* string); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve data for the resource specified by |resource_id|. To |   // Called to retrieve data for the specified scale independent |resource_id|. | ||||||
|   // provide the resource data set |data| and |data_size| to the data pointer |   // To provide the resource data set |data| and |data_size| to the data pointer | ||||||
|   // and size respectively and return true (1). To use the default resource data |   // and size respectively and return true (1). To use the default resource data | ||||||
|   // return false (0). The resource data will not be copied and must remain |   // return false (0). The resource data will not be copied and must remain | ||||||
|   // resident in memory. Supported resource IDs are listed in |   // resident in memory. Include cef_pack_resources.h for a listing of valid | ||||||
|   // cef_pack_resources.h. |   // resource ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_data_resource)( |   int (CEF_CALLBACK *get_data_resource)( | ||||||
|       struct _cef_resource_bundle_handler_t* self, int resource_id, void** data, |       struct _cef_resource_bundle_handler_t* self, int resource_id, void** data, | ||||||
|       size_t* data_size); |       size_t* data_size); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called to retrieve data for the specified |resource_id| nearest the scale | ||||||
|  |   // factor |scale_factor|. To provide the resource data set |data| and | ||||||
|  |   // |data_size| to the data pointer and size respectively and return true (1). | ||||||
|  |   // To use the default resource data return false (0). The resource data will | ||||||
|  |   // not be copied and must remain resident in memory. Include | ||||||
|  |   // cef_pack_resources.h for a listing of valid resource ID values. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *get_data_resource_for_scale)( | ||||||
|  |       struct _cef_resource_bundle_handler_t* self, int resource_id, | ||||||
|  |       cef_scale_factor_t scale_factor, void** data, size_t* data_size); | ||||||
| } cef_resource_bundle_handler_t; | } cef_resource_bundle_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -39,12 +39,12 @@ | |||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
| #include "include/capi/cef_browser_capi.h" |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | struct _cef_browser_t; | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Information about a specific web plugin. | // Information about a specific web plugin. | ||||||
|   | |||||||
| @@ -45,6 +45,30 @@ | |||||||
|  |  | ||||||
| class CefContextMenuParams; | class CefContextMenuParams; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Callback interface used for continuation of custom context menu display. | ||||||
|  | /// | ||||||
|  | /*--cef(source=library)--*/ | ||||||
|  | class CefRunContextMenuCallback : public virtual CefBase { | ||||||
|  |  public: | ||||||
|  |   typedef cef_event_flags_t EventFlags; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Complete context menu display by selecting the specified |command_id| and | ||||||
|  |   // |event_flags|. | ||||||
|  |   /// | ||||||
|  |   /*--cef(capi_name=cont)--*/ | ||||||
|  |   virtual void Continue(int command_id, EventFlags event_flags) =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Cancel context menu display. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual void Cancel() =0; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this interface to handle context menu events. The methods of this | // Implement this interface to handle context menu events. The methods of this | ||||||
| // class will be called on the UI thread. | // class will be called on the UI thread. | ||||||
| @@ -67,6 +91,23 @@ class CefContextMenuHandler : public virtual CefBase { | |||||||
|                                    CefRefPtr<CefContextMenuParams> params, |                                    CefRefPtr<CefContextMenuParams> params, | ||||||
|                                    CefRefPtr<CefMenuModel> model) {} |                                    CefRefPtr<CefMenuModel> model) {} | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called to allow custom display of the context menu. |params| provides | ||||||
|  |   // information about the context menu state. |model| contains the context menu | ||||||
|  |   // model resulting from OnBeforeContextMenu. For custom display return true | ||||||
|  |   // and execute |callback| either synchronously or asynchronously with the | ||||||
|  |   // selected command ID. For default display return false. Do not keep | ||||||
|  |   // references to |params| or |model| outside of this callback. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool RunContextMenu(CefRefPtr<CefBrowser> browser, | ||||||
|  |                               CefRefPtr<CefFrame> frame, | ||||||
|  |                               CefRefPtr<CefContextMenuParams> params, | ||||||
|  |                               CefRefPtr<CefMenuModel> model, | ||||||
|  |                               CefRefPtr<CefRunContextMenuCallback> callback) { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to execute a command selected from the context menu. Return true if |   // Called to execute a command selected from the context menu. Return true if | ||||||
|   // the command was handled or false for the default implementation. See |   // the command was handled or false for the default implementation. See | ||||||
| @@ -226,6 +267,19 @@ class CefContextMenuParams : public virtual CefBase { | |||||||
|   /// |   /// | ||||||
|   /*--cef(default_retval=CM_EDITFLAG_NONE)--*/ |   /*--cef(default_retval=CM_EDITFLAG_NONE)--*/ | ||||||
|   virtual EditStateFlags GetEditStateFlags() =0; |   virtual EditStateFlags GetEditStateFlags() =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns true if the context menu contains items specified by the renderer | ||||||
|  |   // process (for example, plugin placeholder or pepper plugin menu items). | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool IsCustomMenu() =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns true if the context menu was invoked from a pepper plugin. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool IsPepperMenu() =0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CEF_CONTEXT_MENU_HANDLER_H_ | #endif  // CEF_INCLUDE_CEF_CONTEXT_MENU_HANDLER_H_ | ||||||
|   | |||||||
| @@ -40,6 +40,7 @@ | |||||||
|  |  | ||||||
| #include "include/cef_base.h" | #include "include/cef_base.h" | ||||||
| #include "include/cef_cookie.h" | #include "include/cef_cookie.h" | ||||||
|  | #include "include/cef_web_plugin.h" | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this interface to provide handler implementations. The handler | // Implement this interface to provide handler implementations. The handler | ||||||
| @@ -49,13 +50,35 @@ | |||||||
| /*--cef(source=client,no_debugct_check)--*/ | /*--cef(source=client,no_debugct_check)--*/ | ||||||
| class CefRequestContextHandler : public virtual CefBase { | class CefRequestContextHandler : public virtual CefBase { | ||||||
|  public: |  public: | ||||||
|  |   typedef cef_plugin_policy_t PluginPolicy; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread to retrieve the cookie manager. If this method |   // Called on the browser process IO thread to retrieve the cookie manager. If | ||||||
|   // returns NULL the default cookie manager retrievable via |   // this method returns NULL the default cookie manager retrievable via | ||||||
|   // CefRequestContext::GetDefaultCookieManager() will be used. |   // CefRequestContext::GetDefaultCookieManager() will be used. | ||||||
|   /// |   /// | ||||||
|   /*--cef()--*/ |   /*--cef()--*/ | ||||||
|   virtual CefRefPtr<CefCookieManager> GetCookieManager() { return NULL; } |   virtual CefRefPtr<CefCookieManager> GetCookieManager() { return NULL; } | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called on the browser process IO thread before a plugin instance is loaded.  | ||||||
|  |   // |mime_type| is the mime type of the plugin that will be loaded. | ||||||
|  |   // |plugin_url| is the content URL that the plugin will load and may be empty. | ||||||
|  |   // |top_origin_url| is the URL for the top-level frame that contains the | ||||||
|  |   // plugin. |plugin_info| includes additional information about the plugin that | ||||||
|  |   // will be loaded. |plugin_policy| is the recommended policy. Modify | ||||||
|  |   // |plugin_policy| and return true to change the policy. Return false to use | ||||||
|  |   // the recommended policy. The default plugin policy can be set at runtime | ||||||
|  |   // using the `--plugin-policy=[allow|detect|block]` command-line flag. | ||||||
|  |   /// | ||||||
|  |   /*--cef(optional_param=plugin_url)--*/ | ||||||
|  |   virtual bool OnBeforePluginLoad(const CefString& mime_type, | ||||||
|  |                                   const CefString& plugin_url, | ||||||
|  |                                   const CefString& top_origin_url, | ||||||
|  |                                   CefRefPtr<CefWebPluginInfo> plugin_info, | ||||||
|  |                                   PluginPolicy* plugin_policy) { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CEF_REQUEST_CONTEXT_HANDLER_H_ | #endif  // CEF_INCLUDE_CEF_REQUEST_CONTEXT_HANDLER_H_ | ||||||
|   | |||||||
| @@ -46,7 +46,6 @@ | |||||||
| #include "include/cef_response.h" | #include "include/cef_response.h" | ||||||
| #include "include/cef_request.h" | #include "include/cef_request.h" | ||||||
| #include "include/cef_ssl_info.h" | #include "include/cef_ssl_info.h" | ||||||
| #include "include/cef_web_plugin.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| @@ -248,18 +247,6 @@ class CefRequestHandler : public virtual CefBase { | |||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on the browser process IO thread before a plugin is loaded. Return |  | ||||||
|   // true to block loading of the plugin. |  | ||||||
|   /// |  | ||||||
|   /*--cef(optional_param=url,optional_param=policy_url)--*/ |  | ||||||
|   virtual bool OnBeforePluginLoad(CefRefPtr<CefBrowser> browser, |  | ||||||
|                                   const CefString& url, |  | ||||||
|                                   const CefString& policy_url, |  | ||||||
|                                   CefRefPtr<CefWebPluginInfo> info) { |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the browser process UI thread when a plugin has crashed. |   // Called on the browser process UI thread when a plugin has crashed. | ||||||
|   // |plugin_path| is the path of the plugin that crashed. |   // |plugin_path| is the path of the plugin that crashed. | ||||||
|   | |||||||
							
								
								
									
										99
									
								
								include/cef_resource_bundle.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								include/cef_resource_bundle.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | |||||||
|  | // Copyright (c) 2015 Marshall A. Greenblatt. All rights reserved. | ||||||
|  | // | ||||||
|  | // Redistribution and use in source and binary forms, with or without | ||||||
|  | // modification, are permitted provided that the following conditions are | ||||||
|  | // met: | ||||||
|  | // | ||||||
|  | //    * Redistributions of source code must retain the above copyright | ||||||
|  | // notice, this list of conditions and the following disclaimer. | ||||||
|  | //    * Redistributions in binary form must reproduce the above | ||||||
|  | // copyright notice, this list of conditions and the following disclaimer | ||||||
|  | // in the documentation and/or other materials provided with the | ||||||
|  | // distribution. | ||||||
|  | //    * Neither the name of Google Inc. nor the name Chromium Embedded | ||||||
|  | // Framework nor the names of its contributors may be used to endorse | ||||||
|  | // or promote products derived from this software without specific prior | ||||||
|  | // written permission. | ||||||
|  | // | ||||||
|  | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||||||
|  | // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||||||
|  | // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||||||
|  | // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||||||
|  | // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||||||
|  | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||||||
|  | // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||||||
|  | // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||||||
|  | // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||||||
|  | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||||
|  | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // The contents of this file must follow a specific format in order to | ||||||
|  | // support the CEF translator tool. See the translator.README.txt file in the | ||||||
|  | // tools directory for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_INCLUDE_CEF_RESOURCE_BUNDLE_H_ | ||||||
|  | #define CEF_INCLUDE_CEF_RESOURCE_BUNDLE_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "include/cef_base.h" | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Class used for retrieving resources from the resource bundle (*.pak) files | ||||||
|  | // loaded by CEF during startup or via the CefResourceBundleHandler returned | ||||||
|  | // from CefApp::GetResourceBundleHandler. See CefSettings for additional options | ||||||
|  | // related to resource bundle loading. The methods of this class may be called | ||||||
|  | // on any thread unless otherwise indicated. | ||||||
|  | /// | ||||||
|  | /*--cef(source=library,no_debugct_check)--*/ | ||||||
|  | class CefResourceBundle : public virtual CefBase { | ||||||
|  |  public: | ||||||
|  |   typedef cef_scale_factor_t ScaleFactor; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns the global resource bundle instance. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   static CefRefPtr<CefResourceBundle> GetGlobal(); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Returns the localized string for the specified |string_id| or an empty | ||||||
|  |   // string if the value is not found. Include cef_pack_strings.h for a listing | ||||||
|  |   // of valid string ID values. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual CefString GetLocalizedString(int string_id) =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Retrieves the contents of the specified scale independent |resource_id|. | ||||||
|  |   // If the value is found then |data| and |data_size| will be populated and | ||||||
|  |   // this method will return true. If the value is not found then this method | ||||||
|  |   // will return false. The returned |data| pointer will remain resident in | ||||||
|  |   // memory and should not be freed. Include cef_pack_resources.h for a listing | ||||||
|  |   // of valid resource ID values. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool GetDataResource(int resource_id, | ||||||
|  |                                void*& data, | ||||||
|  |                                size_t& data_size) =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Retrieves the contents of the specified |resource_id| nearest the scale | ||||||
|  |   // factor |scale_factor|. Use a |scale_factor| value of SCALE_FACTOR_NONE for | ||||||
|  |   // scale independent resources or call GetDataResource instead. If the value | ||||||
|  |   // is found then |data| and |data_size| will be populated and this method will | ||||||
|  |   // return true. If the value is not found then this method will return false. | ||||||
|  |   // The returned |data| pointer will remain resident in memory and should not | ||||||
|  |   // be freed. Include cef_pack_resources.h for a listing of valid resource ID | ||||||
|  |   // values. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool GetDataResourceForScale(int resource_id, | ||||||
|  |                                        ScaleFactor scale_factor, | ||||||
|  |                                        void*& data, | ||||||
|  |                                        size_t& data_size) =0; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // CEF_INCLUDE_CEF_RESOURCE_BUNDLE_H_ | ||||||
| @@ -41,33 +41,51 @@ | |||||||
| #include "include/cef_base.h" | #include "include/cef_base.h" | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Class used to implement a custom resource bundle interface. The methods of | // Class used to implement a custom resource bundle interface. See CefSettings | ||||||
|  | // for additional options related to resource bundle loading. The methods of | ||||||
| // this class may be called on multiple threads. | // this class may be called on multiple threads. | ||||||
| /// | /// | ||||||
| /*--cef(source=client)--*/ | /*--cef(source=client)--*/ | ||||||
| class CefResourceBundleHandler : public virtual CefBase { | class CefResourceBundleHandler : public virtual CefBase { | ||||||
|  public: |  public: | ||||||
|  |   typedef cef_scale_factor_t ScaleFactor; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve a localized translation for the string specified by |   // Called to retrieve a localized translation for the specified |string_id|. | ||||||
|   // |message_id|. To provide the translation set |string| to the translation |   // To provide the translation set |string| to the translation string and | ||||||
|   // string and return true. To use the default translation return false. |   // return true. To use the default translation return false. Include | ||||||
|   // Supported message IDs are listed in cef_pack_strings.h. |   // cef_pack_strings.h for a listing of valid string ID values. | ||||||
|   /// |   /// | ||||||
|   /*--cef()--*/ |   /*--cef()--*/ | ||||||
|   virtual bool GetLocalizedString(int message_id, |   virtual bool GetLocalizedString(int string_id, | ||||||
|                                   CefString& string) =0; |                                   CefString& string) =0; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve data for the resource specified by |resource_id|. To |   // Called to retrieve data for the specified scale independent |resource_id|. | ||||||
|   // provide the resource data set |data| and |data_size| to the data pointer |   // To provide the resource data set |data| and |data_size| to the data pointer | ||||||
|   // and size respectively and return true. To use the default resource data |   // and size respectively and return true. To use the default resource data | ||||||
|   // return false. The resource data will not be copied and must remain resident |   // return false. The resource data will not be copied and must remain resident | ||||||
|   // in memory. Supported resource IDs are listed in cef_pack_resources.h. |   // in memory. Include cef_pack_resources.h for a listing of valid resource ID | ||||||
|  |   // values. | ||||||
|   /// |   /// | ||||||
|   /*--cef()--*/ |   /*--cef()--*/ | ||||||
|   virtual bool GetDataResource(int resource_id, |   virtual bool GetDataResource(int resource_id, | ||||||
|                                void*& data, |                                void*& data, | ||||||
|                                size_t& data_size) =0; |                                size_t& data_size) =0; | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called to retrieve data for the specified |resource_id| nearest the scale | ||||||
|  |   // factor |scale_factor|. To provide the resource data set |data| and | ||||||
|  |   // |data_size| to the data pointer and size respectively and return true. To | ||||||
|  |   // use the default resource data return false. The resource data will not be | ||||||
|  |   // copied and must remain resident in memory. Include cef_pack_resources.h for | ||||||
|  |   // a listing of valid resource ID values. | ||||||
|  |   /// | ||||||
|  |   /*--cef()--*/ | ||||||
|  |   virtual bool GetDataResourceForScale(int resource_id, | ||||||
|  |                                        ScaleFactor scale_factor, | ||||||
|  |                                        void*& data, | ||||||
|  |                                        size_t& data_size) =0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CEF_RESOURCE_BUNDLE_HANDLER_H_ | #endif  // CEF_INCLUDE_CEF_RESOURCE_BUNDLE_HANDLER_H_ | ||||||
|   | |||||||
| @@ -38,7 +38,8 @@ | |||||||
| #define CEF_INCLUDE_CEF_WEB_PLUGIN_H_ | #define CEF_INCLUDE_CEF_WEB_PLUGIN_H_ | ||||||
|  |  | ||||||
| #include "include/cef_base.h" | #include "include/cef_base.h" | ||||||
| #include "include/cef_browser.h" |  | ||||||
|  | class CefBrowser; | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Information about a specific web plugin. | // Information about a specific web plugin. | ||||||
|   | |||||||
| @@ -1423,6 +1423,11 @@ typedef enum { | |||||||
|   MENU_ID_NO_SPELLING_SUGGESTIONS        = 205, |   MENU_ID_NO_SPELLING_SUGGESTIONS        = 205, | ||||||
|   MENU_ID_ADD_TO_DICTIONARY              = 206, |   MENU_ID_ADD_TO_DICTIONARY              = 206, | ||||||
|  |  | ||||||
|  |   // Custom menu items originating from the renderer process. For example, | ||||||
|  |   // plugin placeholder menu items or Flash menu items. | ||||||
|  |   MENU_ID_CUSTOM_FIRST        = 220, | ||||||
|  |   MENU_ID_CUSTOM_LAST         = 250, | ||||||
|  |  | ||||||
|   // All user-defined menu IDs should come between MENU_ID_USER_FIRST and |   // All user-defined menu IDs should come between MENU_ID_USER_FIRST and | ||||||
|   // MENU_ID_USER_LAST to avoid overlapping the Chromium and CEF ID ranges |   // MENU_ID_USER_LAST to avoid overlapping the Chromium and CEF ID ranges | ||||||
|   // defined in the tools/gritsettings/resource_ids file. |   // defined in the tools/gritsettings/resource_ids file. | ||||||
| @@ -2241,6 +2246,50 @@ typedef struct _cef_pdf_print_settings_t { | |||||||
|  |  | ||||||
| } cef_pdf_print_settings_t; | } cef_pdf_print_settings_t; | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Supported UI scale factors for the platform. SCALE_FACTOR_NONE is used for | ||||||
|  | // density independent resources such as string, html/js files or an image that | ||||||
|  | // can be used for any scale factors (such as wallpapers). | ||||||
|  | /// | ||||||
|  | typedef enum { | ||||||
|  |   SCALE_FACTOR_NONE = 0, | ||||||
|  |   SCALE_FACTOR_100P, | ||||||
|  |   SCALE_FACTOR_125P, | ||||||
|  |   SCALE_FACTOR_133P, | ||||||
|  |   SCALE_FACTOR_140P, | ||||||
|  |   SCALE_FACTOR_150P, | ||||||
|  |   SCALE_FACTOR_180P, | ||||||
|  |   SCALE_FACTOR_200P, | ||||||
|  |   SCALE_FACTOR_250P, | ||||||
|  |   SCALE_FACTOR_300P, | ||||||
|  | } cef_scale_factor_t; | ||||||
|  |  | ||||||
|  | /// | ||||||
|  | // Plugin policies supported by CefRequestContextHandler::OnBeforePluginLoad. | ||||||
|  | /// | ||||||
|  | typedef enum { | ||||||
|  |   /// | ||||||
|  |   // Allow the content. | ||||||
|  |   /// | ||||||
|  |   PLUGIN_POLICY_ALLOW, | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Allow important content and block unimportant content based on heuristics. | ||||||
|  |   // The user can manually load blocked content. | ||||||
|  |   /// | ||||||
|  |   PLUGIN_POLICY_DETECT_IMPORTANT, | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Block the content. The user can manually load blocked content. | ||||||
|  |   /// | ||||||
|  |   PLUGIN_POLICY_BLOCK, | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Disable the content. The user cannot load disabled content. | ||||||
|  |   /// | ||||||
|  |   PLUGIN_POLICY_DISABLE, | ||||||
|  | } cef_plugin_policy_t; | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -59,7 +59,7 @@ void CefBrowserContext::Initialize() { | |||||||
|  |  | ||||||
|   // Spell checking support and possibly other subsystems retrieve the |   // Spell checking support and possibly other subsystems retrieve the | ||||||
|   // PrefService associated with a BrowserContext via UserPrefs::Get(). |   // PrefService associated with a BrowserContext via UserPrefs::Get(). | ||||||
|   PrefService* pref_service = CefContentBrowserClient::Get()->pref_service(); |   PrefService* pref_service = GetPrefs(); | ||||||
|   DCHECK(pref_service); |   DCHECK(pref_service); | ||||||
|   user_prefs::UserPrefs::Set(this, pref_service); |   user_prefs::UserPrefs::Set(this, pref_service); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -104,6 +104,9 @@ | |||||||
| //    CefURLRequestContextGetter* destruction.  | //    CefURLRequestContextGetter* destruction.  | ||||||
| */ | */ | ||||||
|  |  | ||||||
|  | class HostContentSettingsMap; | ||||||
|  | class PrefService; | ||||||
|  |  | ||||||
| namespace extensions { | namespace extensions { | ||||||
| class CefExtensionSystem; | class CefExtensionSystem; | ||||||
| } | } | ||||||
| @@ -142,6 +145,12 @@ class CefBrowserContext | |||||||
|       content::ProtocolHandlerMap* protocol_handlers, |       content::ProtocolHandlerMap* protocol_handlers, | ||||||
|       content::URLRequestInterceptorScopedVector request_interceptors) = 0; |       content::URLRequestInterceptorScopedVector request_interceptors) = 0; | ||||||
|  |  | ||||||
|  |   // Settings for plugins and extensions. | ||||||
|  |   virtual HostContentSettingsMap* GetHostContentSettingsMap() = 0; | ||||||
|  |  | ||||||
|  |   // Preferences. | ||||||
|  |   virtual PrefService* GetPrefs() = 0; | ||||||
|  |  | ||||||
|   CefResourceContext* resource_context() const { |   CefResourceContext* resource_context() const { | ||||||
|     return resource_context_.get(); |     return resource_context_.get(); | ||||||
|   } |   } | ||||||
|   | |||||||
| @@ -13,13 +13,17 @@ | |||||||
| #include "libcef/browser/permission_manager.h" | #include "libcef/browser/permission_manager.h" | ||||||
| #include "libcef/browser/ssl_host_state_delegate.h" | #include "libcef/browser/ssl_host_state_delegate.h" | ||||||
| #include "libcef/browser/thread_util.h" | #include "libcef/browser/thread_util.h" | ||||||
|  | #include "libcef/common/cef_switches.h" | ||||||
| #include "libcef/common/extensions/extensions_util.h" | #include "libcef/common/extensions/extensions_util.h" | ||||||
|  |  | ||||||
|  | #include "base/command_line.h" | ||||||
| #include "base/files/file_util.h" | #include "base/files/file_util.h" | ||||||
| #include "base/lazy_instance.h" | #include "base/lazy_instance.h" | ||||||
| #include "base/logging.h" | #include "base/logging.h" | ||||||
|  | #include "base/strings/string_util.h" | ||||||
| #include "base/threading/thread_restrictions.h" | #include "base/threading/thread_restrictions.h" | ||||||
| #include "chrome/browser/net/proxy_service_factory.h" | #include "chrome/browser/net/proxy_service_factory.h" | ||||||
|  | #include "components/content_settings/core/browser/host_content_settings_map.h" | ||||||
| #include "components/guest_view/browser/guest_view_manager.h" | #include "components/guest_view/browser/guest_view_manager.h" | ||||||
| #include "content/public/browser/download_manager.h" | #include "content/public/browser/download_manager.h" | ||||||
| #include "content/public/browser/browser_thread.h" | #include "content/public/browser/browser_thread.h" | ||||||
| @@ -129,6 +133,9 @@ CefBrowserContextImpl::CefBrowserContextImpl( | |||||||
| CefBrowserContextImpl::~CefBrowserContextImpl() { | CefBrowserContextImpl::~CefBrowserContextImpl() { | ||||||
|   pref_proxy_config_tracker_->DetachFromPrefService(); |   pref_proxy_config_tracker_->DetachFromPrefService(); | ||||||
|  |  | ||||||
|  |   if (host_content_settings_map_.get()) | ||||||
|  |     host_content_settings_map_->ShutdownOnUIThread(); | ||||||
|  |  | ||||||
|   // Delete the download manager delegate here because otherwise we'll crash |   // Delete the download manager delegate here because otherwise we'll crash | ||||||
|   // when it's accessed from the content::BrowserContext destructor. |   // when it's accessed from the content::BrowserContext destructor. | ||||||
|   if (download_manager_delegate_.get()) |   if (download_manager_delegate_.get()) | ||||||
| @@ -164,7 +171,7 @@ void CefBrowserContextImpl::Initialize() { | |||||||
|   // Initialize proxy configuration tracker. |   // Initialize proxy configuration tracker. | ||||||
|   pref_proxy_config_tracker_.reset( |   pref_proxy_config_tracker_.reset( | ||||||
|       ProxyServiceFactory::CreatePrefProxyConfigTrackerOfLocalState( |       ProxyServiceFactory::CreatePrefProxyConfigTrackerOfLocalState( | ||||||
|           CefContentBrowserClient::Get()->pref_service())); |           GetPrefs())); | ||||||
|  |  | ||||||
|   // Create the CefURLRequestContextGetterImpl via an indirect call to |   // Create the CefURLRequestContextGetterImpl via an indirect call to | ||||||
|   // CreateRequestContext. Triggers a call to CefURLRequestContextGetterImpl:: |   // CreateRequestContext. Triggers a call to CefURLRequestContextGetterImpl:: | ||||||
| @@ -340,3 +347,37 @@ net::URLRequestContextGetter* | |||||||
|         content::URLRequestInterceptorScopedVector request_interceptors) { |         content::URLRequestInterceptorScopedVector request_interceptors) { | ||||||
|   return NULL; |   return NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | HostContentSettingsMap* CefBrowserContextImpl::GetHostContentSettingsMap() { | ||||||
|  |   DCHECK_CURRENTLY_ON(BrowserThread::UI); | ||||||
|  |   if (!host_content_settings_map_.get()) { | ||||||
|  |     // The |incognito| argument is intentionally set to false as it otherwise | ||||||
|  |     // limits the types of values that can be stored in the settings map (for | ||||||
|  |     // example, default values set via DefaultProvider::SetWebsiteSetting). | ||||||
|  |     host_content_settings_map_ = new HostContentSettingsMap(GetPrefs(), false); | ||||||
|  |  | ||||||
|  |     // Change the default plugin policy. | ||||||
|  |     const base::CommandLine* command_line = | ||||||
|  |         base::CommandLine::ForCurrentProcess(); | ||||||
|  |     const std::string& plugin_policy_str = | ||||||
|  |       command_line->GetSwitchValueASCII(switches::kPluginPolicy); | ||||||
|  |     if (!plugin_policy_str.empty()) { | ||||||
|  |       ContentSetting plugin_policy = CONTENT_SETTING_ALLOW; | ||||||
|  |       if (base::LowerCaseEqualsASCII(plugin_policy_str, | ||||||
|  |                                      switches::kPluginPolicy_Detect)) { | ||||||
|  |         plugin_policy = CONTENT_SETTING_DETECT_IMPORTANT_CONTENT; | ||||||
|  |       } else if (base::LowerCaseEqualsASCII(plugin_policy_str, | ||||||
|  |                                             switches::kPluginPolicy_Block)) { | ||||||
|  |         plugin_policy = CONTENT_SETTING_BLOCK; | ||||||
|  |       } | ||||||
|  |       host_content_settings_map_->SetDefaultContentSetting( | ||||||
|  |           CONTENT_SETTINGS_TYPE_PLUGINS, plugin_policy); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return host_content_settings_map_.get(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | PrefService* CefBrowserContextImpl::GetPrefs() { | ||||||
|  |   // TODO(cef): Perhaps use per-context settings. | ||||||
|  |   return CefContentBrowserClient::Get()->pref_service(); | ||||||
|  | } | ||||||
|   | |||||||
| @@ -87,6 +87,8 @@ class CefBrowserContextImpl : public CefBrowserContext { | |||||||
|       content::ProtocolHandlerMap* protocol_handlers, |       content::ProtocolHandlerMap* protocol_handlers, | ||||||
|       content::URLRequestInterceptorScopedVector request_interceptors) |       content::URLRequestInterceptorScopedVector request_interceptors) | ||||||
|       override; |       override; | ||||||
|  |   HostContentSettingsMap* GetHostContentSettingsMap() override; | ||||||
|  |   PrefService* GetPrefs() override; | ||||||
|  |  | ||||||
|   // Guaranteed to exist once this object has been initialized. |   // Guaranteed to exist once this object has been initialized. | ||||||
|   scoped_refptr<CefURLRequestContextGetterImpl> request_context() const { |   scoped_refptr<CefURLRequestContextGetterImpl> request_context() const { | ||||||
| @@ -115,6 +117,7 @@ class CefBrowserContextImpl : public CefBrowserContext { | |||||||
|   scoped_refptr<CefURLRequestContextGetterImpl> url_request_getter_; |   scoped_refptr<CefURLRequestContextGetterImpl> url_request_getter_; | ||||||
|   scoped_ptr<content::PermissionManager> permission_manager_; |   scoped_ptr<content::PermissionManager> permission_manager_; | ||||||
|   scoped_ptr<CefSSLHostStateDelegate> ssl_host_state_delegate_; |   scoped_ptr<CefSSLHostStateDelegate> ssl_host_state_delegate_; | ||||||
|  |   scoped_refptr<HostContentSettingsMap> host_content_settings_map_; | ||||||
|  |  | ||||||
|   DISALLOW_COPY_AND_ASSIGN(CefBrowserContextImpl); |   DISALLOW_COPY_AND_ASSIGN(CefBrowserContextImpl); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -169,3 +169,11 @@ net::URLRequestContextGetter* | |||||||
|         content::URLRequestInterceptorScopedVector request_interceptors) { |         content::URLRequestInterceptorScopedVector request_interceptors) { | ||||||
|   return NULL; |   return NULL; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | HostContentSettingsMap* CefBrowserContextProxy::GetHostContentSettingsMap() { | ||||||
|  |   return parent_->GetHostContentSettingsMap(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | PrefService* CefBrowserContextProxy::GetPrefs() { | ||||||
|  |   return parent_->GetPrefs(); | ||||||
|  | } | ||||||
|   | |||||||
| @@ -69,6 +69,8 @@ class CefBrowserContextProxy : public CefBrowserContext { | |||||||
|       content::ProtocolHandlerMap* protocol_handlers, |       content::ProtocolHandlerMap* protocol_handlers, | ||||||
|       content::URLRequestInterceptorScopedVector request_interceptors) |       content::URLRequestInterceptorScopedVector request_interceptors) | ||||||
|       override; |       override; | ||||||
|  |   HostContentSettingsMap* GetHostContentSettingsMap() override; | ||||||
|  |   PrefService* GetPrefs() override; | ||||||
|  |  | ||||||
|   scoped_refptr<CefBrowserContextImpl> parent() const { |   scoped_refptr<CefBrowserContextImpl> parent() const { | ||||||
|     return parent_; |     return parent_; | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ | |||||||
| #include "base/command_line.h" | #include "base/command_line.h" | ||||||
| #include "base/message_loop/message_loop.h" | #include "base/message_loop/message_loop.h" | ||||||
| #include "base/strings/string_number_conversions.h" | #include "base/strings/string_number_conversions.h" | ||||||
|  | #include "chrome/browser/plugins/plugin_finder.h" | ||||||
| #include "content/browser/webui/content_web_ui_controller_factory.h" | #include "content/browser/webui/content_web_ui_controller_factory.h" | ||||||
| #include "content/public/browser/child_process_security_policy.h" | #include "content/public/browser/child_process_security_policy.h" | ||||||
| #include "content/public/browser/gpu_data_manager.h" | #include "content/public/browser/gpu_data_manager.h" | ||||||
| @@ -165,6 +166,9 @@ void CefBrowserMainParts::PreMainMessageLoopRun() { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   // Triggers initialization of the singleton instance on UI thread. | ||||||
|  |   PluginFinder::GetInstance()->Init(); | ||||||
|  |  | ||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
|   PlatformPreMainMessageLoopRun(); |   PlatformPreMainMessageLoopRun(); | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -17,6 +17,7 @@ | |||||||
| #include "chrome/browser/prefs/command_line_pref_store.h" | #include "chrome/browser/prefs/command_line_pref_store.h" | ||||||
| #include "chrome/common/chrome_switches.h" | #include "chrome/common/chrome_switches.h" | ||||||
| #include "chrome/common/pref_names.h" | #include "chrome/common/pref_names.h" | ||||||
|  | #include "components/content_settings/core/browser/host_content_settings_map.h" | ||||||
| #include "components/pref_registry/pref_registry_syncable.h" | #include "components/pref_registry/pref_registry_syncable.h" | ||||||
| #include "components/proxy_config/proxy_config_dictionary.h" | #include "components/proxy_config/proxy_config_dictionary.h" | ||||||
| #include "extensions/browser/extension_prefs.h" | #include "extensions/browser/extension_prefs.h" | ||||||
| @@ -84,13 +85,14 @@ scoped_ptr<PrefService> CefBrowserPrefStore::CreateService() { | |||||||
|       new CommandLinePrefStore(command_line)); |       new CommandLinePrefStore(command_line)); | ||||||
|   factory.set_user_prefs(this); |   factory.set_user_prefs(this); | ||||||
|  |  | ||||||
|   scoped_refptr< user_prefs::PrefRegistrySyncable> registry( |   scoped_refptr<user_prefs::PrefRegistrySyncable> registry( | ||||||
|       new user_prefs::PrefRegistrySyncable()); |       new user_prefs::PrefRegistrySyncable()); | ||||||
|  |  | ||||||
|   // Default settings. |   // Default settings. | ||||||
|   CefMediaCaptureDevicesDispatcher::RegisterPrefs(registry.get()); |   CefMediaCaptureDevicesDispatcher::RegisterPrefs(registry.get()); | ||||||
|   PrefProxyConfigTrackerImpl::RegisterPrefs(registry.get()); |   PrefProxyConfigTrackerImpl::RegisterPrefs(registry.get()); | ||||||
|   extensions::ExtensionPrefs::RegisterProfilePrefs(registry.get()); |   extensions::ExtensionPrefs::RegisterProfilePrefs(registry.get()); | ||||||
|  |   HostContentSettingsMap::RegisterProfilePrefs(registry.get()); | ||||||
|  |  | ||||||
|   // Print settings. |   // Print settings. | ||||||
|   registry->RegisterBooleanPref(prefs::kPrintingEnabled, true); |   registry->RegisterBooleanPref(prefs::kPrintingEnabled, true); | ||||||
| @@ -122,6 +124,11 @@ scoped_ptr<PrefService> CefBrowserPrefStore::CreateService() { | |||||||
|   registry->RegisterBooleanPref(prefs::kEnableDRM, false); |   registry->RegisterBooleanPref(prefs::kEnableDRM, false); | ||||||
|   registry->RegisterStringPref(prefs::kDRMSalt, ""); |   registry->RegisterStringPref(prefs::kDRMSalt, ""); | ||||||
|  |  | ||||||
|  |   // Plugin settings. | ||||||
|  |   // Based on chrome::RegisterBrowserUserPrefs. | ||||||
|  |   registry->RegisterBooleanPref(prefs::kPluginsAllowOutdated, false); | ||||||
|  |   registry->RegisterBooleanPref(prefs::kPluginsAlwaysAuthorize, false); | ||||||
|  |  | ||||||
|   return factory.Create(registry.get()); |   return factory.Create(registry.get()); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -16,9 +16,9 @@ | |||||||
| #include "libcef/browser/devtools_delegate.h" | #include "libcef/browser/devtools_delegate.h" | ||||||
| #include "libcef/browser/extensions/browser_extensions_util.h" | #include "libcef/browser/extensions/browser_extensions_util.h" | ||||||
| #include "libcef/browser/extensions/extension_system.h" | #include "libcef/browser/extensions/extension_system.h" | ||||||
| #include "libcef/browser/extensions/plugin_info_message_filter.h" |  | ||||||
| #include "libcef/browser/media_capture_devices_dispatcher.h" | #include "libcef/browser/media_capture_devices_dispatcher.h" | ||||||
| #include "libcef/browser/pepper/browser_pepper_host_factory.h" | #include "libcef/browser/pepper/browser_pepper_host_factory.h" | ||||||
|  | #include "libcef/browser/plugins/plugin_info_message_filter.h" | ||||||
| #include "libcef/browser/printing/printing_message_filter.h" | #include "libcef/browser/printing/printing_message_filter.h" | ||||||
| #include "libcef/browser/resource_dispatcher_host_delegate.h" | #include "libcef/browser/resource_dispatcher_host_delegate.h" | ||||||
| #include "libcef/browser/speech_recognition_manager_delegate.h" | #include "libcef/browser/speech_recognition_manager_delegate.h" | ||||||
| @@ -38,14 +38,14 @@ | |||||||
| #include "base/path_service.h" | #include "base/path_service.h" | ||||||
| #include "chrome/browser/spellchecker/spellcheck_message_filter.h" | #include "chrome/browser/spellchecker/spellcheck_message_filter.h" | ||||||
| #include "chrome/common/chrome_switches.h" | #include "chrome/common/chrome_switches.h" | ||||||
| #include "content/browser/plugin_service_impl.h" |  | ||||||
| #include "content/public/browser/access_token_store.h" | #include "content/public/browser/access_token_store.h" | ||||||
|  | #include "content/public/browser/browser_ppapi_host.h" | ||||||
| #include "content/public/browser/browser_url_handler.h" | #include "content/public/browser/browser_url_handler.h" | ||||||
| #include "content/public/browser/child_process_security_policy.h" | #include "content/public/browser/child_process_security_policy.h" | ||||||
| #include "content/public/browser/client_certificate_delegate.h" | #include "content/public/browser/client_certificate_delegate.h" | ||||||
| #include "content/public/browser/plugin_service_filter.h" |  | ||||||
| #include "content/public/browser/quota_permission_context.h" | #include "content/public/browser/quota_permission_context.h" | ||||||
| #include "content/public/browser/render_process_host.h" | #include "content/public/browser/render_process_host.h" | ||||||
|  | #include "content/public/browser/render_view_host.h" | ||||||
| #include "content/public/browser/render_widget_host_view.h" | #include "content/public/browser/render_widget_host_view.h" | ||||||
| #include "content/public/browser/resource_dispatcher_host.h" | #include "content/public/browser/resource_dispatcher_host.h" | ||||||
| #include "content/public/common/content_switches.h" | #include "content/public/common/content_switches.h" | ||||||
| @@ -58,6 +58,7 @@ | |||||||
| #include "extensions/browser/io_thread_extension_message_filter.h" | #include "extensions/browser/io_thread_extension_message_filter.h" | ||||||
| #include "extensions/common/constants.h" | #include "extensions/common/constants.h" | ||||||
| #include "net/ssl/ssl_cert_request_info.h" | #include "net/ssl/ssl_cert_request_info.h" | ||||||
|  | #include "ppapi/host/ppapi_host.h" | ||||||
| #include "third_party/WebKit/public/web/WebWindowFeatures.h" | #include "third_party/WebKit/public/web/WebWindowFeatures.h" | ||||||
| #include "ui/base/ui_base_switches.h" | #include "ui/base/ui_base_switches.h" | ||||||
| #include "url/gurl.h" | #include "url/gurl.h" | ||||||
| @@ -265,48 +266,6 @@ class CefQuotaPermissionContext : public content::QuotaPermissionContext { | |||||||
|   DISALLOW_COPY_AND_ASSIGN(CefQuotaPermissionContext); |   DISALLOW_COPY_AND_ASSIGN(CefQuotaPermissionContext); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| class CefPluginServiceFilter : public content::PluginServiceFilter { |  | ||||||
|  public: |  | ||||||
|   CefPluginServiceFilter() {} |  | ||||||
|  |  | ||||||
|   bool IsPluginAvailable(int render_process_id, |  | ||||||
|                          int render_frame_id, |  | ||||||
|                          const void* context, |  | ||||||
|                          const GURL& url, |  | ||||||
|                          const GURL& policy_url, |  | ||||||
|                          content::WebPluginInfo* plugin) override { |  | ||||||
|     bool allowed = true; |  | ||||||
|  |  | ||||||
|     CefRefPtr<CefBrowserHostImpl> browser = |  | ||||||
|         CefBrowserHostImpl::GetBrowserForFrame(render_process_id, |  | ||||||
|                                                render_frame_id); |  | ||||||
|     if (browser.get()) { |  | ||||||
|       CefRefPtr<CefClient> client = browser->GetClient(); |  | ||||||
|       if (client.get()) { |  | ||||||
|         CefRefPtr<CefRequestHandler> handler = client->GetRequestHandler(); |  | ||||||
|         if (handler.get()) { |  | ||||||
|           CefRefPtr<CefWebPluginInfoImpl> pluginInfo( |  | ||||||
|               new CefWebPluginInfoImpl(*plugin)); |  | ||||||
|           allowed = |  | ||||||
|               !handler->OnBeforePluginLoad(browser.get(), |  | ||||||
|                                            url.possibly_invalid_spec(), |  | ||||||
|                                            policy_url.possibly_invalid_spec(), |  | ||||||
|                                            pluginInfo.get()); |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     return allowed; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   bool CanLoadPlugin(int render_process_id, |  | ||||||
|                      const base::FilePath& path) override { |  | ||||||
|     return true; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   DISALLOW_COPY_AND_ASSIGN(CefPluginServiceFilter); |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| void TranslatePopupFeatures(const blink::WebWindowFeatures& webKitFeatures, | void TranslatePopupFeatures(const blink::WebWindowFeatures& webKitFeatures, | ||||||
|                             CefPopupFeatures& features) { |                             CefPopupFeatures& features) { | ||||||
|   features.x = static_cast<int>(webKitFeatures.x); |   features.x = static_cast<int>(webKitFeatures.x); | ||||||
| @@ -399,10 +358,6 @@ int GetCrashSignalFD(const base::CommandLine& command_line) { | |||||||
| CefContentBrowserClient::CefContentBrowserClient() | CefContentBrowserClient::CefContentBrowserClient() | ||||||
|     : browser_main_parts_(NULL), |     : browser_main_parts_(NULL), | ||||||
|       next_browser_id_(0) { |       next_browser_id_(0) { | ||||||
|   plugin_service_filter_.reset(new CefPluginServiceFilter); |  | ||||||
|   content::PluginServiceImpl::GetInstance()->SetFilter( |  | ||||||
|       plugin_service_filter_.get()); |  | ||||||
|  |  | ||||||
|   last_create_window_params_.opener_process_id = MSG_ROUTING_NONE; |   last_create_window_params_.opener_process_id = MSG_ROUTING_NONE; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -574,9 +529,10 @@ void CefContentBrowserClient::RenderProcessWillLaunch( | |||||||
|  |  | ||||||
|   content::BrowserContext* browser_context = host->GetBrowserContext(); |   content::BrowserContext* browser_context = host->GetBrowserContext(); | ||||||
|  |  | ||||||
|  |   host->AddFilter(new CefPluginInfoMessageFilter(id, | ||||||
|  |       static_cast<CefBrowserContext*>(browser_context))); | ||||||
|  |  | ||||||
|   if (extensions::ExtensionsEnabled()) { |   if (extensions::ExtensionsEnabled()) { | ||||||
|     host->AddFilter( |  | ||||||
|         new extensions::CefPluginInfoMessageFilter(id, browser_context)); |  | ||||||
|     host->AddFilter( |     host->AddFilter( | ||||||
|         new extensions::ExtensionMessageFilter(id, browser_context)); |         new extensions::ExtensionMessageFilter(id, browser_context)); | ||||||
|     host->AddFilter( |     host->AddFilter( | ||||||
|   | |||||||
| @@ -32,7 +32,6 @@ class CefResourceDispatcherHostDelegate; | |||||||
| class PrefService; | class PrefService; | ||||||
|  |  | ||||||
| namespace content { | namespace content { | ||||||
| class PluginServiceFilter; |  | ||||||
| class SiteInstance; | class SiteInstance; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -173,7 +172,6 @@ class CefContentBrowserClient : public content::ContentBrowserClient { | |||||||
|  |  | ||||||
|   CefBrowserMainParts* browser_main_parts_; |   CefBrowserMainParts* browser_main_parts_; | ||||||
|  |  | ||||||
|   scoped_ptr<content::PluginServiceFilter> plugin_service_filter_; |  | ||||||
|   scoped_ptr<CefResourceDispatcherHostDelegate> |   scoped_ptr<CefResourceDispatcherHostDelegate> | ||||||
|       resource_dispatcher_host_delegate_; |       resource_dispatcher_host_delegate_; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -133,3 +133,13 @@ CefContextMenuParamsImpl::EditStateFlags | |||||||
|   CEF_VALUE_VERIFY_RETURN(false, CM_EDITFLAG_NONE); |   CEF_VALUE_VERIFY_RETURN(false, CM_EDITFLAG_NONE); | ||||||
|   return static_cast<EditStateFlags>(const_value().edit_flags); |   return static_cast<EditStateFlags>(const_value().edit_flags); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefContextMenuParamsImpl::IsCustomMenu() { | ||||||
|  |   CEF_VALUE_VERIFY_RETURN(false, false); | ||||||
|  |   return !const_value().custom_items.empty(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefContextMenuParamsImpl::IsPepperMenu() { | ||||||
|  |   CEF_VALUE_VERIFY_RETURN(false, false); | ||||||
|  |   return const_value().custom_context.is_pepper_menu; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -37,6 +37,8 @@ class CefContextMenuParamsImpl | |||||||
|   bool IsEditable() override; |   bool IsEditable() override; | ||||||
|   bool IsSpellCheckEnabled() override; |   bool IsSpellCheckEnabled() override; | ||||||
|   EditStateFlags GetEditStateFlags() override; |   EditStateFlags GetEditStateFlags() override; | ||||||
|  |   bool IsCustomMenu() override; | ||||||
|  |   bool IsPepperMenu() override; | ||||||
|  |  | ||||||
|   DISALLOW_COPY_AND_ASSIGN(CefContextMenuParamsImpl); |   DISALLOW_COPY_AND_ASSIGN(CefContextMenuParamsImpl); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| #include "libcef/browser/extensions/extensions_browser_client.h" | #include "libcef/browser/extensions/extensions_browser_client.h" | ||||||
|  |  | ||||||
| #include "libcef/browser/content_browser_client.h" | #include "libcef/browser/browser_context_impl.h" | ||||||
| #include "libcef/browser/extensions/component_extension_resource_manager.h" | #include "libcef/browser/extensions/component_extension_resource_manager.h" | ||||||
| #include "libcef/browser/extensions/extension_system_factory.h" | #include "libcef/browser/extensions/extension_system_factory.h" | ||||||
| #include "libcef/browser/extensions/extension_web_contents_observer.h" | #include "libcef/browser/extensions/extension_web_contents_observer.h" | ||||||
| @@ -125,8 +125,7 @@ bool CefExtensionsBrowserClient::AllowCrossRendererResourceLoad( | |||||||
|  |  | ||||||
| PrefService* CefExtensionsBrowserClient::GetPrefServiceForContext( | PrefService* CefExtensionsBrowserClient::GetPrefServiceForContext( | ||||||
|     BrowserContext* context) { |     BrowserContext* context) { | ||||||
|   // TODO(extensions): Do we need a per-context PrefService? |   return CefBrowserContextImpl::GetForContext(context)->GetPrefs(); | ||||||
|   return CefContentBrowserClient::Get()->pref_service(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| void CefExtensionsBrowserClient::GetEarlyExtensionPrefsObservers( | void CefExtensionsBrowserClient::GetEarlyExtensionPrefsObservers( | ||||||
|   | |||||||
| @@ -1,245 +0,0 @@ | |||||||
| // Copyright 2015 The Chromium Embedded Framework Authors. |  | ||||||
| // Portions copyright 2012 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 "libcef/browser/extensions/plugin_info_message_filter.h" |  | ||||||
|  |  | ||||||
| #include "libcef/common/cef_messages.h" |  | ||||||
|  |  | ||||||
| #include "base/bind.h" |  | ||||||
| #include "base/memory/scoped_ptr.h" |  | ||||||
| #include "base/strings/utf_string_conversions.h" |  | ||||||
| #include "base/thread_task_runner_handle.h" |  | ||||||
| #include "content/public/browser/browser_context.h" |  | ||||||
| #include "content/public/browser/browser_thread.h" |  | ||||||
| #include "content/public/browser/plugin_service.h" |  | ||||||
| #include "content/public/browser/plugin_service_filter.h" |  | ||||||
| #include "content/public/common/content_constants.h" |  | ||||||
| #include "content/public/common/webplugininfo.h" |  | ||||||
| #include "extensions/browser/guest_view/web_view/web_view_renderer_state.h" |  | ||||||
| #include "extensions/common/constants.h" |  | ||||||
| #include "extensions/common/extension.h" |  | ||||||
| #include "url/gurl.h" |  | ||||||
|  |  | ||||||
| using content::PluginService; |  | ||||||
| using content::WebPluginInfo; |  | ||||||
|  |  | ||||||
| namespace extensions { |  | ||||||
|  |  | ||||||
| namespace { |  | ||||||
|  |  | ||||||
| #if defined(OS_WIN) || defined(OS_MACOSX) |  | ||||||
| // These are the mime-types of plugins which are known to have PPAPI versions. |  | ||||||
| const char* kPepperPluginMimeTypes[] = { |  | ||||||
|     "application/pdf", |  | ||||||
|     "application/x-google-chrome-pdf", |  | ||||||
|     "application/x-nacl", |  | ||||||
|     "application/x-pnacl", |  | ||||||
|     "application/vnd.chromium.remoting-viewer", |  | ||||||
|     "application/x-shockwave-flash", |  | ||||||
|     "application/futuresplash", |  | ||||||
| }; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| }  // namespace |  | ||||||
|  |  | ||||||
| CefPluginInfoMessageFilter::Context::Context( |  | ||||||
|     int render_process_id, |  | ||||||
|     content::BrowserContext* browser_context) |  | ||||||
|     : render_process_id_(render_process_id), |  | ||||||
|       resource_context_(browser_context->GetResourceContext()) { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| CefPluginInfoMessageFilter::Context::~Context() { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| CefPluginInfoMessageFilter::CefPluginInfoMessageFilter( |  | ||||||
|     int render_process_id, |  | ||||||
|     content::BrowserContext* browser_context) |  | ||||||
|     : BrowserMessageFilter(ExtensionMsgStart), |  | ||||||
|       context_(render_process_id, browser_context), |  | ||||||
|       main_thread_task_runner_(base::ThreadTaskRunnerHandle::Get()), |  | ||||||
|       weak_ptr_factory_(this) { |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool CefPluginInfoMessageFilter::OnMessageReceived(const IPC::Message& message) { |  | ||||||
|   IPC_BEGIN_MESSAGE_MAP(CefPluginInfoMessageFilter, message) |  | ||||||
|     IPC_MESSAGE_HANDLER_DELAY_REPLY(CefViewHostMsg_GetPluginInfo, |  | ||||||
|                                     OnGetPluginInfo) |  | ||||||
|     IPC_MESSAGE_HANDLER(CefViewHostMsg_IsInternalPluginAvailableForMimeType, |  | ||||||
|                         OnIsInternalPluginAvailableForMimeType) |  | ||||||
|     IPC_MESSAGE_UNHANDLED(return false) |  | ||||||
|   IPC_END_MESSAGE_MAP() |  | ||||||
|   return true; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CefPluginInfoMessageFilter::OnDestruct() const { |  | ||||||
|   const_cast<CefPluginInfoMessageFilter*>(this)-> |  | ||||||
|       weak_ptr_factory_.InvalidateWeakPtrs(); |  | ||||||
|  |  | ||||||
|   // Destroy on the UI thread because we contain a |PrefMember|. |  | ||||||
|   content::BrowserThread::DeleteOnUIThread::Destruct(this); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| CefPluginInfoMessageFilter::~CefPluginInfoMessageFilter() {} |  | ||||||
|  |  | ||||||
| struct CefPluginInfoMessageFilter::GetPluginInfo_Params { |  | ||||||
|   int render_frame_id; |  | ||||||
|   GURL url; |  | ||||||
|   GURL top_origin_url; |  | ||||||
|   std::string mime_type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| void CefPluginInfoMessageFilter::OnGetPluginInfo( |  | ||||||
|     int render_frame_id, |  | ||||||
|     const GURL& url, |  | ||||||
|     const GURL& top_origin_url, |  | ||||||
|     const std::string& mime_type, |  | ||||||
|     IPC::Message* reply_msg) { |  | ||||||
|   GetPluginInfo_Params params = { |  | ||||||
|     render_frame_id, |  | ||||||
|     url, |  | ||||||
|     top_origin_url, |  | ||||||
|     mime_type |  | ||||||
|   }; |  | ||||||
|   PluginService::GetInstance()->GetPlugins( |  | ||||||
|       base::Bind(&CefPluginInfoMessageFilter::PluginsLoaded, |  | ||||||
|                  weak_ptr_factory_.GetWeakPtr(), |  | ||||||
|                  params, reply_msg)); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CefPluginInfoMessageFilter::PluginsLoaded( |  | ||||||
|     const GetPluginInfo_Params& params, |  | ||||||
|     IPC::Message* reply_msg, |  | ||||||
|     const std::vector<WebPluginInfo>& plugins) { |  | ||||||
|   CefViewHostMsg_GetPluginInfo_Output output; |  | ||||||
|   // This also fills in |actual_mime_type|. |  | ||||||
|   if (context_.FindEnabledPlugin(params.render_frame_id, params.url, |  | ||||||
|                                  params.top_origin_url, params.mime_type, |  | ||||||
|                                  &output.status, &output.plugin, |  | ||||||
|                                  &output.actual_mime_type)) { |  | ||||||
|     context_.DecidePluginStatus(params, output.plugin, &output.status); |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   CefViewHostMsg_GetPluginInfo::WriteReplyParams(reply_msg, output); |  | ||||||
|   Send(reply_msg); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CefPluginInfoMessageFilter::Context::DecidePluginStatus( |  | ||||||
|     const GetPluginInfo_Params& params, |  | ||||||
|     const WebPluginInfo& plugin, |  | ||||||
|     CefViewHostMsg_GetPluginInfo_Status* status) const { |  | ||||||
|   if (plugin.type == WebPluginInfo::PLUGIN_TYPE_NPAPI) { |  | ||||||
|     CHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); |  | ||||||
|     // NPAPI plugins are not supported inside <webview> guests. |  | ||||||
|     if (extensions::WebViewRendererState::GetInstance()->IsGuest( |  | ||||||
|         render_process_id_)) { |  | ||||||
|       *status = CefViewHostMsg_GetPluginInfo_Status::kNPAPINotSupported; |  | ||||||
|       return; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // Check if the plugin is crashing too much. |  | ||||||
|   if (PluginService::GetInstance()->IsPluginUnstable(plugin.path)) { |  | ||||||
|     *status = CefViewHostMsg_GetPluginInfo_Status::kUnauthorized; |  | ||||||
|     return; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if (*status == CefViewHostMsg_GetPluginInfo_Status::kAllowed) { |  | ||||||
|     // Allow an embedder of <webview> to block a plugin from being loaded inside |  | ||||||
|     // the guest. In order to do this, set the status to 'Unauthorized' here, |  | ||||||
|     // and update the status as appropriate depending on the response from the |  | ||||||
|     // embedder. |  | ||||||
|     if (extensions::WebViewRendererState::GetInstance()->IsGuest( |  | ||||||
|         render_process_id_)) { |  | ||||||
|       *status = CefViewHostMsg_GetPluginInfo_Status::kUnauthorized; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool CefPluginInfoMessageFilter::Context::FindEnabledPlugin( |  | ||||||
|     int render_frame_id, |  | ||||||
|     const GURL& url, |  | ||||||
|     const GURL& top_origin_url, |  | ||||||
|     const std::string& mime_type, |  | ||||||
|     CefViewHostMsg_GetPluginInfo_Status* status, |  | ||||||
|     WebPluginInfo* plugin, |  | ||||||
|     std::string* actual_mime_type) const { |  | ||||||
|   *status = CefViewHostMsg_GetPluginInfo_Status::kAllowed; |  | ||||||
|  |  | ||||||
|   bool allow_wildcard = true; |  | ||||||
|   std::vector<WebPluginInfo> matching_plugins; |  | ||||||
|   std::vector<std::string> mime_types; |  | ||||||
|   PluginService::GetInstance()->GetPluginInfoArray( |  | ||||||
|       url, mime_type, allow_wildcard, &matching_plugins, &mime_types); |  | ||||||
|   if (matching_plugins.empty()) { |  | ||||||
|     *status = CefViewHostMsg_GetPluginInfo_Status::kNotFound; |  | ||||||
| #if defined(OS_WIN) || defined(OS_MACOSX) |  | ||||||
|     if (!PluginService::GetInstance()->NPAPIPluginsSupported()) { |  | ||||||
|       // At this point it is not known for sure this is an NPAPI plugin as it |  | ||||||
|       // could be a not-yet-installed Pepper plugin. To avoid notifying on |  | ||||||
|       // these types, bail early based on a blacklist of pepper mime types. |  | ||||||
|       for (auto pepper_mime_type : kPepperPluginMimeTypes) |  | ||||||
|         if (pepper_mime_type == mime_type) |  | ||||||
|           return false; |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   content::PluginServiceFilter* filter = |  | ||||||
|       PluginService::GetInstance()->GetFilter(); |  | ||||||
|   size_t i = 0; |  | ||||||
|   for (; i < matching_plugins.size(); ++i) { |  | ||||||
|     if (!filter || filter->IsPluginAvailable(render_process_id_, |  | ||||||
|                                              render_frame_id, |  | ||||||
|                                              resource_context_, |  | ||||||
|                                              url, |  | ||||||
|                                              top_origin_url, |  | ||||||
|                                              &matching_plugins[i])) { |  | ||||||
|       break; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   // If we broke out of the loop, we have found an enabled plugin. |  | ||||||
|   bool enabled = i < matching_plugins.size(); |  | ||||||
|   if (!enabled) { |  | ||||||
|     // Otherwise, we only found disabled plugins, so we take the first one. |  | ||||||
|     i = 0; |  | ||||||
|     *status = CefViewHostMsg_GetPluginInfo_Status::kDisabled; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   *plugin = matching_plugins[i]; |  | ||||||
|   *actual_mime_type = mime_types[i]; |  | ||||||
|  |  | ||||||
|   return enabled; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CefPluginInfoMessageFilter::OnIsInternalPluginAvailableForMimeType( |  | ||||||
|     const std::string& mime_type, |  | ||||||
|     bool* is_available, |  | ||||||
|     std::vector<base::string16>* additional_param_names, |  | ||||||
|     std::vector<base::string16>* additional_param_values) { |  | ||||||
|   std::vector<WebPluginInfo> plugins; |  | ||||||
|   PluginService::GetInstance()->GetInternalPlugins(&plugins); |  | ||||||
|  |  | ||||||
|   for (size_t i = 0; i < plugins.size(); ++i) { |  | ||||||
|     const WebPluginInfo& plugin = plugins[i]; |  | ||||||
|     const std::vector<content::WebPluginMimeType>& mime_types = |  | ||||||
|         plugin.mime_types; |  | ||||||
|     for (size_t j = 0; j < mime_types.size(); ++j) { |  | ||||||
|       if (mime_types[j].mime_type == mime_type) { |  | ||||||
|         // TODO(cef): Maybe allow plugins to be disabled here. |  | ||||||
|         *is_available = true; |  | ||||||
|         *additional_param_names = mime_types[j].additional_param_names; |  | ||||||
|         *additional_param_values = mime_types[j].additional_param_values; |  | ||||||
|         return; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   *is_available = false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| }  // namespace extensions |  | ||||||
| @@ -5,6 +5,7 @@ | |||||||
| #include "libcef/browser/menu_creator.h" | #include "libcef/browser/menu_creator.h" | ||||||
| #include "libcef/browser/browser_host_impl.h" | #include "libcef/browser/browser_host_impl.h" | ||||||
| #include "libcef/browser/context_menu_params_impl.h" | #include "libcef/browser/context_menu_params_impl.h" | ||||||
|  | #include "libcef/browser/thread_util.h" | ||||||
| #include "libcef/common/content_client.h" | #include "libcef/common/content_client.h" | ||||||
|  |  | ||||||
| #include "base/compiler_specific.h" | #include "base/compiler_specific.h" | ||||||
| @@ -31,12 +32,73 @@ CefString GetLabel(int message_id) { | |||||||
|   return label; |   return label; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | const int kInvalidCommandId = -1; | ||||||
|  | const cef_event_flags_t kEmptyEventFlags = static_cast<cef_event_flags_t>(0); | ||||||
|  |  | ||||||
|  | class CefRunContextMenuCallbackImpl : public CefRunContextMenuCallback { | ||||||
|  |  public: | ||||||
|  |   typedef base::Callback<void(int,cef_event_flags_t)> Callback; | ||||||
|  |  | ||||||
|  |   explicit CefRunContextMenuCallbackImpl(const Callback& callback) | ||||||
|  |       : callback_(callback) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   ~CefRunContextMenuCallbackImpl() { | ||||||
|  |     if (!callback_.is_null()) { | ||||||
|  |       // The callback is still pending. Cancel it now. | ||||||
|  |       if (CEF_CURRENTLY_ON_UIT()) { | ||||||
|  |         RunNow(callback_, kInvalidCommandId, kEmptyEventFlags); | ||||||
|  |       } else { | ||||||
|  |         CEF_POST_TASK(CEF_UIT, | ||||||
|  |             base::Bind(&CefRunContextMenuCallbackImpl::RunNow, callback_, | ||||||
|  |                        kInvalidCommandId, kEmptyEventFlags)); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   void Continue(int command_id, cef_event_flags_t event_flags) override { | ||||||
|  |     if (CEF_CURRENTLY_ON_UIT()) { | ||||||
|  |       if (!callback_.is_null()) { | ||||||
|  |         RunNow(callback_, command_id, event_flags); | ||||||
|  |         callback_.Reset(); | ||||||
|  |       } | ||||||
|  |     } else { | ||||||
|  |       CEF_POST_TASK(CEF_UIT, | ||||||
|  |           base::Bind(&CefRunContextMenuCallbackImpl::Continue, this, | ||||||
|  |                      command_id, event_flags)); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   void Cancel() override { | ||||||
|  |     Continue(kInvalidCommandId, kEmptyEventFlags); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   void Disconnect() { | ||||||
|  |     callback_.Reset(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   static void RunNow(const Callback& callback, | ||||||
|  |                      int command_id, | ||||||
|  |                      cef_event_flags_t event_flags) { | ||||||
|  |     CEF_REQUIRE_UIT(); | ||||||
|  |     callback.Run(command_id, event_flags); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   Callback callback_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(CefRunContextMenuCallbackImpl); | ||||||
|  |   DISALLOW_COPY_AND_ASSIGN(CefRunContextMenuCallbackImpl); | ||||||
|  | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|  |  | ||||||
| CefMenuCreator::CefMenuCreator(content::WebContents* web_contents, | CefMenuCreator::CefMenuCreator(content::WebContents* web_contents, | ||||||
|                                CefBrowserHostImpl* browser) |                                CefBrowserHostImpl* browser) | ||||||
|   : content::WebContentsObserver(web_contents), |   : content::WebContentsObserver(web_contents), | ||||||
|     browser_(browser) { |     browser_(browser), | ||||||
|  |     custom_menu_callback_(NULL), | ||||||
|  |     weak_ptr_factory_(this) { | ||||||
|   DCHECK(web_contents); |   DCHECK(web_contents); | ||||||
|   DCHECK(browser_); |   DCHECK(browser_); | ||||||
|   model_ = new CefMenuModelImpl(this); |   model_ = new CefMenuModelImpl(this); | ||||||
| @@ -77,39 +139,75 @@ bool CefMenuCreator::CreateContextMenu( | |||||||
|   // Create the default menu model. |   // Create the default menu model. | ||||||
|   CreateDefaultModel(); |   CreateDefaultModel(); | ||||||
|  |  | ||||||
|  |   bool custom_menu = false; | ||||||
|  |   DCHECK(!custom_menu_callback_); | ||||||
|  |  | ||||||
|   // Give the client a chance to modify the model. |   // Give the client a chance to modify the model. | ||||||
|   CefRefPtr<CefClient> client = browser_->GetClient(); |   CefRefPtr<CefClient> client = browser_->GetClient(); | ||||||
|   if (client.get()) { |   if (client.get()) { | ||||||
|       CefRefPtr<CefContextMenuHandler> handler = |     CefRefPtr<CefContextMenuHandler> handler = | ||||||
|           client->GetContextMenuHandler(); |         client->GetContextMenuHandler(); | ||||||
|       if (handler.get()) { |     if (handler.get()) { | ||||||
|         CefRefPtr<CefContextMenuParamsImpl> paramsPtr( |       CefRefPtr<CefContextMenuParamsImpl> paramsPtr( | ||||||
|             new CefContextMenuParamsImpl(¶ms_)); |           new CefContextMenuParamsImpl(¶ms_)); | ||||||
|  |       CefRefPtr<CefFrame> frame = browser_->GetFocusedFrame(); | ||||||
|  |  | ||||||
|         handler->OnBeforeContextMenu(browser_, |       handler->OnBeforeContextMenu(browser_, | ||||||
|                                      browser_->GetFocusedFrame(), |                                     frame, | ||||||
|                                      paramsPtr.get(), |                                     paramsPtr.get(), | ||||||
|                                      model_.get()); |                                     model_.get()); | ||||||
|  |  | ||||||
|         // Do not keep references to the parameters in the callback. |       MenuWillShow(model_); | ||||||
|         paramsPtr->Detach(NULL); |  | ||||||
|         DCHECK(paramsPtr->HasOneRef()); |  | ||||||
|         DCHECK(model_->VerifyRefCount()); |  | ||||||
|  |  | ||||||
|         // Menu is empty so notify the client and return. |       if (model_->GetCount() > 0) { | ||||||
|         if (model_->GetCount() == 0) { |         CefRefPtr<CefRunContextMenuCallbackImpl> callbackImpl( | ||||||
|           MenuClosed(model_); |             new CefRunContextMenuCallbackImpl( | ||||||
|           return true; |                 base::Bind(&CefMenuCreator::ExecuteCommandCallback, | ||||||
|  |                             weak_ptr_factory_.GetWeakPtr()))); | ||||||
|  |  | ||||||
|  |         // This reference will be cleared when the callback is executed or | ||||||
|  |         // the callback object is deleted. | ||||||
|  |         custom_menu_callback_ = callbackImpl.get(); | ||||||
|  |  | ||||||
|  |         if (handler->RunContextMenu(browser_, | ||||||
|  |                                     frame, | ||||||
|  |                                     paramsPtr.get(), | ||||||
|  |                                     model_.get(), | ||||||
|  |                                     callbackImpl.get())) { | ||||||
|  |           custom_menu = true; | ||||||
|  |         } else { | ||||||
|  |           // Callback should not be executed if the handler returns false. | ||||||
|  |           DCHECK(custom_menu_callback_); | ||||||
|  |           custom_menu_callback_ = NULL; | ||||||
|  |           callbackImpl->Disconnect(); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       // Do not keep references to the parameters in the callback. | ||||||
|  |       paramsPtr->Detach(NULL); | ||||||
|  |       DCHECK(paramsPtr->HasOneRef()); | ||||||
|  |       DCHECK(model_->VerifyRefCount()); | ||||||
|  |  | ||||||
|  |       // Menu is empty so notify the client and return. | ||||||
|  |       if (model_->GetCount() == 0 && !custom_menu) { | ||||||
|  |         MenuClosed(model_); | ||||||
|  |         return true; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   if (custom_menu) | ||||||
|  |     return true; | ||||||
|   return runner_->RunContextMenu(this); |   return runner_->RunContextMenu(this); | ||||||
| } | } | ||||||
|  |  | ||||||
| void CefMenuCreator::CancelContextMenu() { | void CefMenuCreator::CancelContextMenu() { | ||||||
|   if (IsShowingContextMenu()) |   if (IsShowingContextMenu()) { | ||||||
|     runner_->CancelContextMenu(); |     if (custom_menu_callback_) | ||||||
|  |       custom_menu_callback_->Cancel(); | ||||||
|  |     else | ||||||
|  |       runner_->CancelContextMenu(); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| bool CefMenuCreator::CreateRunner() { | bool CefMenuCreator::CreateRunner() { | ||||||
| @@ -135,26 +233,26 @@ void CefMenuCreator::ExecuteCommand(CefRefPtr<CefMenuModelImpl> source, | |||||||
|   // Give the client a chance to handle the command. |   // Give the client a chance to handle the command. | ||||||
|   CefRefPtr<CefClient> client = browser_->GetClient(); |   CefRefPtr<CefClient> client = browser_->GetClient(); | ||||||
|   if (client.get()) { |   if (client.get()) { | ||||||
|       CefRefPtr<CefContextMenuHandler> handler = |     CefRefPtr<CefContextMenuHandler> handler = | ||||||
|           client->GetContextMenuHandler(); |         client->GetContextMenuHandler(); | ||||||
|       if (handler.get()) { |     if (handler.get()) { | ||||||
|         CefRefPtr<CefContextMenuParamsImpl> paramsPtr( |       CefRefPtr<CefContextMenuParamsImpl> paramsPtr( | ||||||
|             new CefContextMenuParamsImpl(¶ms_)); |           new CefContextMenuParamsImpl(¶ms_)); | ||||||
|  |  | ||||||
|         bool handled = handler->OnContextMenuCommand( |       bool handled = handler->OnContextMenuCommand( | ||||||
|             browser_, |           browser_, | ||||||
|             browser_->GetFocusedFrame(), |           browser_->GetFocusedFrame(), | ||||||
|             paramsPtr.get(), |           paramsPtr.get(), | ||||||
|             command_id, |           command_id, | ||||||
|             event_flags); |           event_flags); | ||||||
|  |  | ||||||
|         // Do not keep references to the parameters in the callback. |       // Do not keep references to the parameters in the callback. | ||||||
|         paramsPtr->Detach(NULL); |       paramsPtr->Detach(NULL); | ||||||
|         DCHECK(paramsPtr->HasOneRef()); |       DCHECK(paramsPtr->HasOneRef()); | ||||||
|  |  | ||||||
|         if (handled) |       if (handled) | ||||||
|           return; |         return; | ||||||
|       } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Execute the default command handling. |   // Execute the default command handling. | ||||||
| @@ -169,6 +267,10 @@ void CefMenuCreator::MenuWillShow(CefRefPtr<CefMenuModelImpl> source) { | |||||||
|   if (!web_contents()) |   if (!web_contents()) | ||||||
|     return; |     return; | ||||||
|  |  | ||||||
|  |   // May be called multiple times. | ||||||
|  |   if (IsShowingContextMenu()) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|   // Notify the host before showing the context menu. |   // Notify the host before showing the context menu. | ||||||
|   content::RenderWidgetHostView* view = |   content::RenderWidgetHostView* view = | ||||||
|       web_contents()->GetRenderWidgetHostView(); |       web_contents()->GetRenderWidgetHostView(); | ||||||
| @@ -181,31 +283,56 @@ void CefMenuCreator::MenuClosed(CefRefPtr<CefMenuModelImpl> source) { | |||||||
|   if (source.get() != model_.get()) |   if (source.get() != model_.get()) | ||||||
|     return; |     return; | ||||||
|  |  | ||||||
|  |   if (!web_contents()) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   DCHECK(IsShowingContextMenu()); | ||||||
|  |  | ||||||
|   // Notify the client. |   // Notify the client. | ||||||
|   CefRefPtr<CefClient> client = browser_->GetClient(); |   CefRefPtr<CefClient> client = browser_->GetClient(); | ||||||
|   if (client.get()) { |   if (client.get()) { | ||||||
|       CefRefPtr<CefContextMenuHandler> handler = |     CefRefPtr<CefContextMenuHandler> handler = | ||||||
|           client->GetContextMenuHandler(); |         client->GetContextMenuHandler(); | ||||||
|       if (handler.get()) { |     if (handler.get()) { | ||||||
|         handler->OnContextMenuDismissed(browser_, browser_->GetFocusedFrame()); |       handler->OnContextMenuDismissed(browser_, browser_->GetFocusedFrame()); | ||||||
|       } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (IsShowingContextMenu() && web_contents()) { |   // Notify the host after closing the context menu. | ||||||
|     // Notify the host after closing the context menu. |   content::RenderWidgetHostView* view = | ||||||
|     content::RenderWidgetHostView* view = |       web_contents()->GetRenderWidgetHostView(); | ||||||
|         web_contents()->GetRenderWidgetHostView(); |   if (view) | ||||||
|     if (view) |     view->SetShowingContextMenu(false); | ||||||
|       view->SetShowingContextMenu(false); |   web_contents()->NotifyContextMenuClosed(params_.custom_context); | ||||||
|     web_contents()->NotifyContextMenuClosed(params_.custom_context); |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| bool CefMenuCreator::FormatLabel(base::string16& label) { | bool CefMenuCreator::FormatLabel(base::string16& label) { | ||||||
|   return runner_->FormatLabel(label); |   return runner_->FormatLabel(label); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void CefMenuCreator::ExecuteCommandCallback(int command_id, | ||||||
|  |                                             cef_event_flags_t event_flags) { | ||||||
|  |   DCHECK(IsShowingContextMenu()); | ||||||
|  |   DCHECK(custom_menu_callback_); | ||||||
|  |   if (command_id != kInvalidCommandId) | ||||||
|  |     ExecuteCommand(model_, command_id, event_flags); | ||||||
|  |   MenuClosed(model_); | ||||||
|  |   custom_menu_callback_ = NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
| void CefMenuCreator::CreateDefaultModel() { | void CefMenuCreator::CreateDefaultModel() { | ||||||
|  |   if (!params_.custom_items.empty()) { | ||||||
|  |     // Custom menu items originating from the renderer process. For example, | ||||||
|  |     // plugin placeholder menu items or Flash menu items. | ||||||
|  |     for (size_t i = 0; i < params_.custom_items.size(); ++i) { | ||||||
|  |       content::MenuItem menu_item = params_.custom_items[i]; | ||||||
|  |       menu_item.action += MENU_ID_CUSTOM_FIRST; | ||||||
|  |       DCHECK_LE(static_cast<int>(menu_item.action), MENU_ID_CUSTOM_LAST); | ||||||
|  |       model_->AddMenuItem(menu_item); | ||||||
|  |     } | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   if (params_.is_editable) { |   if (params_.is_editable) { | ||||||
|     // Editable node. |     // Editable node. | ||||||
|     model_->AddItem(MENU_ID_UNDO, GetLabel(IDS_MENU_UNDO)); |     model_->AddItem(MENU_ID_UNDO, GetLabel(IDS_MENU_UNDO)); | ||||||
| @@ -284,6 +411,14 @@ void CefMenuCreator::CreateDefaultModel() { | |||||||
| } | } | ||||||
|  |  | ||||||
| void CefMenuCreator::ExecuteDefaultCommand(int command_id) { | void CefMenuCreator::ExecuteDefaultCommand(int command_id) { | ||||||
|  |   if (IsCustomContextMenuCommand(command_id)) { | ||||||
|  |     if (web_contents()) { | ||||||
|  |       web_contents()->ExecuteCustomContextMenuCommand( | ||||||
|  |           command_id - MENU_ID_CUSTOM_FIRST, params_.custom_context); | ||||||
|  |     } | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // If the user chose a replacement word for a misspelling, replace it here. |   // If the user chose a replacement word for a misspelling, replace it here. | ||||||
|   if (command_id >= MENU_ID_SPELLCHECK_SUGGESTION_0 && |   if (command_id >= MENU_ID_SPELLCHECK_SUGGESTION_0 && | ||||||
|       command_id <= MENU_ID_SPELLCHECK_SUGGESTION_LAST) { |       command_id <= MENU_ID_SPELLCHECK_SUGGESTION_LAST) { | ||||||
| @@ -358,3 +493,20 @@ void CefMenuCreator::ExecuteDefaultCommand(int command_id) { | |||||||
|     break; |     break; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefMenuCreator::IsCustomContextMenuCommand(int command_id) { | ||||||
|  |   // Verify that the command ID is in the correct range. | ||||||
|  |   if (command_id < MENU_ID_CUSTOM_FIRST || command_id > MENU_ID_CUSTOM_LAST) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   command_id -= MENU_ID_CUSTOM_FIRST; | ||||||
|  |  | ||||||
|  |   // Verify that the specific command ID was passed from the renderer process. | ||||||
|  |   if (!params_.custom_items.empty()) { | ||||||
|  |     for (size_t i = 0; i < params_.custom_items.size(); ++i) { | ||||||
|  |       if (static_cast<int>(params_.custom_items[i].action) == command_id) | ||||||
|  |         return true; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return false; | ||||||
|  | } | ||||||
|   | |||||||
| @@ -9,6 +9,7 @@ | |||||||
| #include "libcef/browser/menu_model_impl.h" | #include "libcef/browser/menu_model_impl.h" | ||||||
|  |  | ||||||
| #include "base/memory/scoped_ptr.h" | #include "base/memory/scoped_ptr.h" | ||||||
|  | #include "base/memory/weak_ptr.h" | ||||||
| #include "content/public/browser/web_contents_observer.h" | #include "content/public/browser/web_contents_observer.h" | ||||||
| #include "content/public/common/context_menu_params.h" | #include "content/public/common/context_menu_params.h" | ||||||
|  |  | ||||||
| @@ -17,6 +18,7 @@ class RenderFrameHost; | |||||||
| class WebContents; | class WebContents; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | class CefRunContextMenuCallback; | ||||||
| class CefBrowserHostImpl; | class CefBrowserHostImpl; | ||||||
|  |  | ||||||
| class CefMenuCreator : public CefMenuModelImpl::Delegate, | class CefMenuCreator : public CefMenuModelImpl::Delegate, | ||||||
| @@ -58,11 +60,17 @@ class CefMenuCreator : public CefMenuModelImpl::Delegate, | |||||||
|   void MenuClosed(CefRefPtr<CefMenuModelImpl> source) override; |   void MenuClosed(CefRefPtr<CefMenuModelImpl> source) override; | ||||||
|   bool FormatLabel(base::string16& label) override; |   bool FormatLabel(base::string16& label) override; | ||||||
|  |  | ||||||
|  |   void ExecuteCommandCallback(int command_id, | ||||||
|  |                               cef_event_flags_t event_flags); | ||||||
|  |  | ||||||
|   // Create the default menu model. |   // Create the default menu model. | ||||||
|   void CreateDefaultModel(); |   void CreateDefaultModel(); | ||||||
|   // Execute the default command handling. |   // Execute the default command handling. | ||||||
|   void ExecuteDefaultCommand(int command_id); |   void ExecuteDefaultCommand(int command_id); | ||||||
|  |  | ||||||
|  |   // Returns true if the specified id is a custom context menu command. | ||||||
|  |   bool IsCustomContextMenuCommand(int command_id); | ||||||
|  |  | ||||||
|   // CefBrowserHostImpl pointer is guaranteed to outlive this object. |   // CefBrowserHostImpl pointer is guaranteed to outlive this object. | ||||||
|   CefBrowserHostImpl* browser_; |   CefBrowserHostImpl* browser_; | ||||||
|  |  | ||||||
| @@ -70,6 +78,12 @@ class CefMenuCreator : public CefMenuModelImpl::Delegate, | |||||||
|   content::ContextMenuParams params_; |   content::ContextMenuParams params_; | ||||||
|   scoped_ptr<Runner> runner_; |   scoped_ptr<Runner> runner_; | ||||||
|  |  | ||||||
|  |   // Not owned by this class. | ||||||
|  |   CefRunContextMenuCallback* custom_menu_callback_; | ||||||
|  |  | ||||||
|  |   // Must be the last member. | ||||||
|  |   base::WeakPtrFactory<CefMenuCreator> weak_ptr_factory_; | ||||||
|  |  | ||||||
|   DISALLOW_COPY_AND_ASSIGN(CefMenuCreator); |   DISALLOW_COPY_AND_ASSIGN(CefMenuCreator); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ | |||||||
| #include "base/bind.h" | #include "base/bind.h" | ||||||
| #include "base/logging.h" | #include "base/logging.h" | ||||||
| #include "base/message_loop/message_loop.h" | #include "base/message_loop/message_loop.h" | ||||||
|  | #include "content/public/common/menu_item.h" | ||||||
| #include "ui/base/accelerators/accelerator.h" | #include "ui/base/accelerators/accelerator.h" | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
| @@ -661,6 +662,41 @@ bool CefMenuModelImpl::VerifyRefCount() { | |||||||
|   return true; |   return true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | void CefMenuModelImpl::AddMenuItem(const content::MenuItem& menu_item) { | ||||||
|  |   const int command_id = static_cast<int>(menu_item.action); | ||||||
|  |  | ||||||
|  |   switch (menu_item.type) { | ||||||
|  |     case content::MenuItem::OPTION: | ||||||
|  |       AddItem(command_id, menu_item.label); | ||||||
|  |       break; | ||||||
|  |     case content::MenuItem::CHECKABLE_OPTION: | ||||||
|  |       AddCheckItem(command_id, menu_item.label); | ||||||
|  |       break; | ||||||
|  |     case content::MenuItem::GROUP: | ||||||
|  |       AddRadioItem(command_id, menu_item.label, 0); | ||||||
|  |       break; | ||||||
|  |     case content::MenuItem::SEPARATOR: | ||||||
|  |       AddSeparator(); | ||||||
|  |       break; | ||||||
|  |     case content::MenuItem::SUBMENU: { | ||||||
|  |       CefRefPtr<CefMenuModelImpl> sub_menu = static_cast<CefMenuModelImpl*>( | ||||||
|  |           AddSubMenu(command_id, menu_item.label).get()); | ||||||
|  |       for (size_t i = 0; i < menu_item.submenu.size(); ++i) | ||||||
|  |         sub_menu->AddMenuItem(menu_item.submenu[i]); | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (!menu_item.enabled && menu_item.type != content::MenuItem::SEPARATOR) | ||||||
|  |     SetEnabled(command_id, false); | ||||||
|  |  | ||||||
|  |   if (menu_item.checked && | ||||||
|  |       (menu_item.type == content::MenuItem::CHECKABLE_OPTION || | ||||||
|  |        menu_item.type == content::MenuItem::GROUP)) { | ||||||
|  |     SetChecked(command_id, true); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
| void CefMenuModelImpl::AppendItem(const Item& item) { | void CefMenuModelImpl::AppendItem(const Item& item) { | ||||||
|   ValidateItem(item); |   ValidateItem(item); | ||||||
|   items_.push_back(item); |   items_.push_back(item); | ||||||
|   | |||||||
| @@ -15,6 +15,10 @@ | |||||||
| #include "base/threading/platform_thread.h" | #include "base/threading/platform_thread.h" | ||||||
| #include "ui/base/models/menu_model.h" | #include "ui/base/models/menu_model.h" | ||||||
|  |  | ||||||
|  | namespace content { | ||||||
|  | struct MenuItem; | ||||||
|  | } | ||||||
|  |  | ||||||
| class CefMenuModelImpl : public CefMenuModel { | class CefMenuModelImpl : public CefMenuModel { | ||||||
|  public: |  public: | ||||||
|   class Delegate { |   class Delegate { | ||||||
| @@ -112,6 +116,9 @@ class CefMenuModelImpl : public CefMenuModel { | |||||||
|   // Verify that only a single reference exists to all CefMenuModelImpl objects. |   // Verify that only a single reference exists to all CefMenuModelImpl objects. | ||||||
|   bool VerifyRefCount(); |   bool VerifyRefCount(); | ||||||
|  |  | ||||||
|  |   // Helper for adding custom menu items originating from the renderer process. | ||||||
|  |   void AddMenuItem(const content::MenuItem& menu_item); | ||||||
|  |  | ||||||
|   ui::MenuModel* model() { return model_.get(); } |   ui::MenuModel* model() { return model_.get(); } | ||||||
|   Delegate* delegate() { return delegate_; } |   Delegate* delegate() { return delegate_; } | ||||||
|   void set_delegate(Delegate* delegate) { delegate_ = NULL; } |   void set_delegate(Delegate* delegate) { delegate_ = NULL; } | ||||||
|   | |||||||
							
								
								
									
										615
									
								
								libcef/browser/plugins/plugin_info_message_filter.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										615
									
								
								libcef/browser/plugins/plugin_info_message_filter.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,615 @@ | |||||||
|  | // Copyright 2015 The Chromium Embedded Framework Authors. | ||||||
|  | // Portions copyright 2012 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 "libcef/browser/plugins/plugin_info_message_filter.h" | ||||||
|  |  | ||||||
|  | #include "libcef/browser/browser_context.h" | ||||||
|  | #include "libcef/browser/web_plugin_impl.h" | ||||||
|  | #include "libcef/common/cef_messages.h" | ||||||
|  | #include "libcef/common/content_client.h" | ||||||
|  |  | ||||||
|  | #include "base/bind.h" | ||||||
|  | #include "base/memory/scoped_ptr.h" | ||||||
|  | #include "base/metrics/histogram_macros.h" | ||||||
|  | #include "base/strings/utf_string_conversions.h" | ||||||
|  | #include "base/thread_task_runner_handle.h" | ||||||
|  | #include "chrome/browser/plugins/plugin_finder.h" | ||||||
|  | #include "chrome/common/pref_names.h" | ||||||
|  | #include "components/content_settings/core/browser/content_settings_utils.h" | ||||||
|  | #include "components/content_settings/core/browser/plugins_field_trial.h" | ||||||
|  | #include "content/public/browser/browser_context.h" | ||||||
|  | #include "content/public/browser/browser_thread.h" | ||||||
|  | #include "content/public/browser/plugin_service.h" | ||||||
|  | #include "content/public/browser/plugin_service_filter.h" | ||||||
|  | #include "content/public/common/content_constants.h" | ||||||
|  | #include "content/public/common/webplugininfo.h" | ||||||
|  | #include "extensions/browser/extension_registry.h" | ||||||
|  | #include "extensions/browser/guest_view/web_view/web_view_renderer_state.h" | ||||||
|  | #include "extensions/common/constants.h" | ||||||
|  | #include "extensions/common/extension.h" | ||||||
|  | #include "extensions/common/manifest_constants.h" | ||||||
|  | #include "extensions/common/manifest_handlers/webview_info.h" | ||||||
|  | #include "url/gurl.h" | ||||||
|  |  | ||||||
|  | #include "widevine_cdm_version.h"  // In SHARED_INTERMEDIATE_DIR. | ||||||
|  |  | ||||||
|  | #if defined(OS_WIN) | ||||||
|  | #include "base/win/metro.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if !defined(DISABLE_NACL) | ||||||
|  | #include "components/nacl/common/nacl_constants.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | using content::PluginService; | ||||||
|  | using content::WebPluginInfo; | ||||||
|  |  | ||||||
|  | namespace { | ||||||
|  |  | ||||||
|  | #if defined(OS_WIN) || defined(OS_MACOSX) | ||||||
|  | // These are the mime-types of plugins which are known to have PPAPI versions. | ||||||
|  | const char* kPepperPluginMimeTypes[] = { | ||||||
|  |     "application/pdf", | ||||||
|  |     "application/x-google-chrome-pdf", | ||||||
|  |     "application/x-nacl", | ||||||
|  |     "application/x-pnacl", | ||||||
|  |     "application/vnd.chromium.remoting-viewer", | ||||||
|  |     "application/x-shockwave-flash", | ||||||
|  |     "application/futuresplash", | ||||||
|  | }; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | // For certain sandboxed Pepper plugins, use the JavaScript Content Settings. | ||||||
|  | bool ShouldUseJavaScriptSettingForPlugin(const WebPluginInfo& plugin) { | ||||||
|  |   if (plugin.type != WebPluginInfo::PLUGIN_TYPE_PEPPER_IN_PROCESS && | ||||||
|  |       plugin.type != WebPluginInfo::PLUGIN_TYPE_PEPPER_OUT_OF_PROCESS) { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | #if !defined(DISABLE_NACL) | ||||||
|  |   // Treat Native Client invocations like JavaScript. | ||||||
|  |   if (plugin.name == base::ASCIIToUTF16(nacl::kNaClPluginName)) | ||||||
|  |     return true; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #if defined(WIDEVINE_CDM_AVAILABLE) && defined(ENABLE_PEPPER_CDMS) | ||||||
|  |   // Treat CDM invocations like JavaScript. | ||||||
|  |   if (plugin.name == base::ASCIIToUTF16(kWidevineCdmDisplayName)) { | ||||||
|  |     DCHECK(plugin.type == WebPluginInfo::PLUGIN_TYPE_PEPPER_OUT_OF_PROCESS); | ||||||
|  |     return true; | ||||||
|  |   } | ||||||
|  | #endif  // defined(WIDEVINE_CDM_AVAILABLE) && defined(ENABLE_PEPPER_CDMS) | ||||||
|  |  | ||||||
|  |   return false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if defined(ENABLE_PEPPER_CDMS) | ||||||
|  |  | ||||||
|  | enum PluginAvailabilityStatusForUMA { | ||||||
|  |   PLUGIN_NOT_REGISTERED, | ||||||
|  |   PLUGIN_AVAILABLE, | ||||||
|  |   PLUGIN_DISABLED, | ||||||
|  |   PLUGIN_AVAILABILITY_STATUS_MAX | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | static void SendPluginAvailabilityUMA(const std::string& mime_type, | ||||||
|  |                                       PluginAvailabilityStatusForUMA status) { | ||||||
|  | #if defined(WIDEVINE_CDM_AVAILABLE) | ||||||
|  |   // Only report results for Widevine CDM. | ||||||
|  |   if (mime_type != kWidevineCdmPluginMimeType) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   UMA_HISTOGRAM_ENUMERATION("Plugin.AvailabilityStatus.WidevineCdm", | ||||||
|  |                             status, PLUGIN_AVAILABILITY_STATUS_MAX); | ||||||
|  | #endif  // defined(WIDEVINE_CDM_AVAILABLE) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif  // defined(ENABLE_PEPPER_CDMS) | ||||||
|  |  | ||||||
|  | void ReportMetrics(const std::string& mime_type, | ||||||
|  |                    const GURL& url, | ||||||
|  |                    const GURL& origin_url) { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  | // Returns whether a request from a plugin to load |resource| from a renderer | ||||||
|  | // with process id |process_id| is a request for an internal resource by an app | ||||||
|  | // listed in |accessible_resources| in its manifest. | ||||||
|  | bool IsPluginLoadingAccessibleResourceInWebView( | ||||||
|  |     extensions::ExtensionRegistry* extension_registry, | ||||||
|  |     int process_id, | ||||||
|  |     const GURL& resource) { | ||||||
|  |   extensions::WebViewRendererState* renderer_state = | ||||||
|  |       extensions::WebViewRendererState::GetInstance(); | ||||||
|  |   std::string partition_id; | ||||||
|  |   if (!renderer_state->IsGuest(process_id) || | ||||||
|  |       !renderer_state->GetPartitionID(process_id, &partition_id)) { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const std::string extension_id = resource.host(); | ||||||
|  |   const extensions::Extension* extension = | ||||||
|  |       extension_registry->GetExtensionById(extension_id, | ||||||
|  |                              extensions::ExtensionRegistry::ENABLED); | ||||||
|  |   if (!extension) | ||||||
|  |     return false; | ||||||
|  |   const extensions::WebviewInfo* webview_info = | ||||||
|  |       static_cast<const extensions::WebviewInfo*>(extension->GetManifestData( | ||||||
|  |           extensions::manifest_keys::kWebviewAccessibleResources)); | ||||||
|  |   if (!webview_info || | ||||||
|  |       !webview_info->IsResourceWebviewAccessible(extension, partition_id, | ||||||
|  |                                                  resource.path())) { | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // Make sure the renderer making the request actually belongs to the | ||||||
|  |   // same extension. | ||||||
|  |   std::string owner_extension; | ||||||
|  |   return renderer_state->GetOwnerInfo(process_id, nullptr, &owner_extension) && | ||||||
|  |          owner_extension == extension_id; | ||||||
|  | } | ||||||
|  | #endif  // defined(ENABLE_EXTENSIONS) | ||||||
|  |  | ||||||
|  | }  // namespace | ||||||
|  |  | ||||||
|  | CefPluginInfoMessageFilter::Context::Context( | ||||||
|  |     int render_process_id, | ||||||
|  |     CefBrowserContext* profile) | ||||||
|  |     : render_process_id_(render_process_id), | ||||||
|  |       resource_context_(profile->GetResourceContext()), | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  |       extension_registry_(extensions::ExtensionRegistry::Get(profile)), | ||||||
|  | #endif | ||||||
|  |       host_content_settings_map_(profile->GetHostContentSettingsMap()) { | ||||||
|  |   allow_outdated_plugins_.Init(prefs::kPluginsAllowOutdated, | ||||||
|  |                                profile->GetPrefs()); | ||||||
|  |   allow_outdated_plugins_.MoveToThread( | ||||||
|  |       content::BrowserThread::GetMessageLoopProxyForThread( | ||||||
|  |           content::BrowserThread::IO)); | ||||||
|  |   always_authorize_plugins_.Init(prefs::kPluginsAlwaysAuthorize, | ||||||
|  |                                  profile->GetPrefs()); | ||||||
|  |   always_authorize_plugins_.MoveToThread( | ||||||
|  |       content::BrowserThread::GetMessageLoopProxyForThread( | ||||||
|  |           content::BrowserThread::IO)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefPluginInfoMessageFilter::Context::~Context() { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefPluginInfoMessageFilter::CefPluginInfoMessageFilter( | ||||||
|  |     int render_process_id, | ||||||
|  |     CefBrowserContext* profile) | ||||||
|  |     : BrowserMessageFilter(ExtensionMsgStart), | ||||||
|  |       context_(render_process_id, profile), | ||||||
|  |       browser_context_(profile), | ||||||
|  |       main_thread_task_runner_(base::ThreadTaskRunnerHandle::Get()), | ||||||
|  |       weak_ptr_factory_(this) { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefPluginInfoMessageFilter::OnMessageReceived( | ||||||
|  |     const IPC::Message& message) { | ||||||
|  |   IPC_BEGIN_MESSAGE_MAP(CefPluginInfoMessageFilter, message) | ||||||
|  |     IPC_MESSAGE_HANDLER_DELAY_REPLY(CefViewHostMsg_GetPluginInfo, | ||||||
|  |                                     OnGetPluginInfo) | ||||||
|  | #if defined(ENABLE_PEPPER_CDMS) | ||||||
|  |     IPC_MESSAGE_HANDLER( | ||||||
|  |         CefViewHostMsg_IsInternalPluginAvailableForMimeType, | ||||||
|  |         OnIsInternalPluginAvailableForMimeType) | ||||||
|  | #endif | ||||||
|  |     IPC_MESSAGE_UNHANDLED(return false) | ||||||
|  |   IPC_END_MESSAGE_MAP() | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::OnDestruct() const { | ||||||
|  |   const_cast<CefPluginInfoMessageFilter*>(this)-> | ||||||
|  |       weak_ptr_factory_.InvalidateWeakPtrs(); | ||||||
|  |  | ||||||
|  |   // Destroy on the UI thread because we contain a |PrefMember|. | ||||||
|  |   content::BrowserThread::DeleteOnUIThread::Destruct(this); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefPluginInfoMessageFilter::~CefPluginInfoMessageFilter() {} | ||||||
|  |  | ||||||
|  | struct CefPluginInfoMessageFilter::GetPluginInfo_Params { | ||||||
|  |   int render_frame_id; | ||||||
|  |   GURL url; | ||||||
|  |   GURL top_origin_url; | ||||||
|  |   std::string mime_type; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::OnGetPluginInfo( | ||||||
|  |     int render_frame_id, | ||||||
|  |     const GURL& url, | ||||||
|  |     const GURL& top_origin_url, | ||||||
|  |     const std::string& mime_type, | ||||||
|  |     IPC::Message* reply_msg) { | ||||||
|  |   GetPluginInfo_Params params = { | ||||||
|  |     render_frame_id, | ||||||
|  |     url, | ||||||
|  |     top_origin_url, | ||||||
|  |     mime_type | ||||||
|  |   }; | ||||||
|  |   PluginService::GetInstance()->GetPlugins( | ||||||
|  |       base::Bind(&CefPluginInfoMessageFilter::PluginsLoaded, | ||||||
|  |                  weak_ptr_factory_.GetWeakPtr(), | ||||||
|  |                  params, reply_msg)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::PluginsLoaded( | ||||||
|  |     const GetPluginInfo_Params& params, | ||||||
|  |     IPC::Message* reply_msg, | ||||||
|  |     const std::vector<WebPluginInfo>& plugins) { | ||||||
|  |   CefViewHostMsg_GetPluginInfo_Output output; | ||||||
|  |   // This also fills in |actual_mime_type|. | ||||||
|  |   scoped_ptr<PluginMetadata> plugin_metadata; | ||||||
|  |   if (context_.FindEnabledPlugin(params.render_frame_id, params.url, | ||||||
|  |                                  params.top_origin_url, params.mime_type, | ||||||
|  |                                  &output.status, &output.plugin, | ||||||
|  |                                  &output.actual_mime_type, | ||||||
|  |                                  &plugin_metadata)) { | ||||||
|  |     context_.DecidePluginStatus(params, output.plugin, plugin_metadata.get(), | ||||||
|  |                                 &output.status); | ||||||
|  |  | ||||||
|  |     const bool is_found = | ||||||
|  |       output.status != CefViewHostMsg_GetPluginInfo_Status::kNotFound && | ||||||
|  |       output.status != CefViewHostMsg_GetPluginInfo_Status::kNPAPINotSupported; | ||||||
|  |  | ||||||
|  |     const bool is_internal_pdf_plugin = | ||||||
|  |         is_found && | ||||||
|  |         (output.plugin.path == CefString(CefContentClient::kPDFPluginPath)); | ||||||
|  |     if (is_internal_pdf_plugin && | ||||||
|  |         output.status != CefViewHostMsg_GetPluginInfo_Status::kAllowed) { | ||||||
|  |       // Always allow the internal PDF plugin to load if it exists. | ||||||
|  |       output.status = CefViewHostMsg_GetPluginInfo_Status::kAllowed; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // Give the handler an opportunity to modify the policy. | ||||||
|  |     CefRefPtr<CefRequestContextHandler> handler = | ||||||
|  |         browser_context_->GetHandler(); | ||||||
|  |     if (handler.get() && | ||||||
|  |         is_found && | ||||||
|  |         !is_internal_pdf_plugin) { | ||||||
|  |       cef_plugin_policy_t plugin_policy = PLUGIN_POLICY_DISABLE; | ||||||
|  |       switch (output.status) { | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kAllowed: | ||||||
|  |           plugin_policy = PLUGIN_POLICY_ALLOW; | ||||||
|  |           break; | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kBlocked: | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kBlockedByPolicy: | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kOutdatedBlocked: | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kOutdatedDisallowed: | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kUnauthorized: | ||||||
|  |           plugin_policy = PLUGIN_POLICY_BLOCK; | ||||||
|  |           break; | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kDisabled: | ||||||
|  |           plugin_policy = PLUGIN_POLICY_DISABLE; | ||||||
|  |           break; | ||||||
|  |         case CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent: | ||||||
|  |           plugin_policy = PLUGIN_POLICY_DETECT_IMPORTANT; | ||||||
|  |           break; | ||||||
|  |         default: | ||||||
|  |           NOTREACHED(); | ||||||
|  |           break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       CefRefPtr<CefWebPluginInfoImpl> pluginInfo( | ||||||
|  |           new CefWebPluginInfoImpl(output.plugin)); | ||||||
|  |       if (handler->OnBeforePluginLoad(output.actual_mime_type, | ||||||
|  |                                       params.url.spec(), | ||||||
|  |                                       params.top_origin_url.spec(), | ||||||
|  |                                       pluginInfo.get(), | ||||||
|  |                                       &plugin_policy)) { | ||||||
|  |         switch (plugin_policy) { | ||||||
|  |           case PLUGIN_POLICY_ALLOW: | ||||||
|  |             output.status = CefViewHostMsg_GetPluginInfo_Status::kAllowed; | ||||||
|  |             break; | ||||||
|  |           case PLUGIN_POLICY_DETECT_IMPORTANT: | ||||||
|  |             output.status = | ||||||
|  |                 CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent; | ||||||
|  |             break; | ||||||
|  |           case PLUGIN_POLICY_BLOCK: | ||||||
|  |             output.status = CefViewHostMsg_GetPluginInfo_Status::kBlocked; | ||||||
|  |             break; | ||||||
|  |           case PLUGIN_POLICY_DISABLE: | ||||||
|  |             output.status = CefViewHostMsg_GetPluginInfo_Status::kDisabled; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (plugin_metadata) { | ||||||
|  |     output.group_identifier = plugin_metadata->identifier(); | ||||||
|  |     output.group_name = plugin_metadata->name(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CefViewHostMsg_GetPluginInfo::WriteReplyParams(reply_msg, output); | ||||||
|  |   Send(reply_msg); | ||||||
|  |   if (output.status != | ||||||
|  |       CefViewHostMsg_GetPluginInfo_Status::kNotFound) { | ||||||
|  |     main_thread_task_runner_->PostTask( | ||||||
|  |         FROM_HERE, base::Bind(&ReportMetrics, output.actual_mime_type, | ||||||
|  |                               params.url, params.top_origin_url)); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #if defined(ENABLE_PEPPER_CDMS) | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::OnIsInternalPluginAvailableForMimeType( | ||||||
|  |     const std::string& mime_type, | ||||||
|  |     bool* is_available, | ||||||
|  |     std::vector<base::string16>* additional_param_names, | ||||||
|  |     std::vector<base::string16>* additional_param_values) { | ||||||
|  |   std::vector<WebPluginInfo> plugins; | ||||||
|  |   PluginService::GetInstance()->GetInternalPlugins(&plugins); | ||||||
|  |  | ||||||
|  |   bool is_plugin_disabled = false; | ||||||
|  |   for (size_t i = 0; i < plugins.size(); ++i) { | ||||||
|  |     const WebPluginInfo& plugin = plugins[i]; | ||||||
|  |     const std::vector<content::WebPluginMimeType>& mime_types = | ||||||
|  |         plugin.mime_types; | ||||||
|  |     for (size_t j = 0; j < mime_types.size(); ++j) { | ||||||
|  |       if (mime_types[j].mime_type == mime_type) { | ||||||
|  |         if (!context_.IsPluginEnabled(plugin)) { | ||||||
|  |           is_plugin_disabled = true; | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         *is_available = true; | ||||||
|  |         *additional_param_names = mime_types[j].additional_param_names; | ||||||
|  |         *additional_param_values = mime_types[j].additional_param_values; | ||||||
|  |         SendPluginAvailabilityUMA(mime_type, PLUGIN_AVAILABLE); | ||||||
|  |         return; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   *is_available = false; | ||||||
|  |   SendPluginAvailabilityUMA( | ||||||
|  |       mime_type, is_plugin_disabled ? PLUGIN_DISABLED : PLUGIN_NOT_REGISTERED); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif // defined(ENABLE_PEPPER_CDMS) | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::Context::DecidePluginStatus( | ||||||
|  |     const GetPluginInfo_Params& params, | ||||||
|  |     const WebPluginInfo& plugin, | ||||||
|  |     const PluginMetadata* plugin_metadata, | ||||||
|  |     CefViewHostMsg_GetPluginInfo_Status* status) const { | ||||||
|  | #if defined(OS_WIN) | ||||||
|  |   if (plugin.type == WebPluginInfo::PLUGIN_TYPE_NPAPI && | ||||||
|  |       base::win::IsMetroProcess()) { | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kNPAPINotSupported; | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  |   if (plugin.type == WebPluginInfo::PLUGIN_TYPE_NPAPI) { | ||||||
|  |     CHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::IO)); | ||||||
|  |     // NPAPI plugins are not supported inside <webview> guests. | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  |     if (extensions::WebViewRendererState::GetInstance()->IsGuest( | ||||||
|  |         render_process_id_)) { | ||||||
|  |       *status = CefViewHostMsg_GetPluginInfo_Status::kNPAPINotSupported; | ||||||
|  |       return; | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   ContentSetting plugin_setting = CONTENT_SETTING_DEFAULT; | ||||||
|  |   bool uses_default_content_setting = true; | ||||||
|  |   bool is_managed = false; | ||||||
|  |   // Check plugin content settings. The primary URL is the top origin URL and | ||||||
|  |   // the secondary URL is the plugin URL. | ||||||
|  |   GetPluginContentSetting(plugin, params.top_origin_url, params.url, | ||||||
|  |                           plugin_metadata->identifier(), &plugin_setting, | ||||||
|  |                           &uses_default_content_setting, &is_managed); | ||||||
|  |  | ||||||
|  |   // TODO(tommycli): Remove once we deprecate the plugin ASK policy. | ||||||
|  |   bool legacy_ask_user = plugin_setting == CONTENT_SETTING_ASK; | ||||||
|  |   plugin_setting = content_settings::PluginsFieldTrial::EffectiveContentSetting( | ||||||
|  |       CONTENT_SETTINGS_TYPE_PLUGINS, plugin_setting); | ||||||
|  |  | ||||||
|  |   DCHECK(plugin_setting != CONTENT_SETTING_DEFAULT); | ||||||
|  |   DCHECK(plugin_setting != CONTENT_SETTING_ASK); | ||||||
|  |  | ||||||
|  |   PluginMetadata::SecurityStatus plugin_status = | ||||||
|  |       plugin_metadata->GetSecurityStatus(plugin); | ||||||
|  | #if defined(ENABLE_PLUGIN_INSTALLATION) | ||||||
|  |   // Check if the plugin is outdated. | ||||||
|  |   if (plugin_status == PluginMetadata::SECURITY_STATUS_OUT_OF_DATE && | ||||||
|  |       !allow_outdated_plugins_.GetValue()) { | ||||||
|  |     if (allow_outdated_plugins_.IsManaged()) { | ||||||
|  |       *status = CefViewHostMsg_GetPluginInfo_Status::kOutdatedDisallowed; | ||||||
|  |     } else { | ||||||
|  |       *status = CefViewHostMsg_GetPluginInfo_Status::kOutdatedBlocked; | ||||||
|  |     } | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  | #endif | ||||||
|  |   // Check if the plugin requires authorization. | ||||||
|  |   if (plugin_status == | ||||||
|  |           PluginMetadata::SECURITY_STATUS_REQUIRES_AUTHORIZATION && | ||||||
|  |       plugin.type != WebPluginInfo::PLUGIN_TYPE_PEPPER_IN_PROCESS && | ||||||
|  |       plugin.type != WebPluginInfo::PLUGIN_TYPE_PEPPER_OUT_OF_PROCESS && | ||||||
|  |       plugin.type != WebPluginInfo::PLUGIN_TYPE_BROWSER_PLUGIN && | ||||||
|  |       !always_authorize_plugins_.GetValue() && | ||||||
|  |       plugin_setting != CONTENT_SETTING_BLOCK && | ||||||
|  |       uses_default_content_setting) { | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kUnauthorized; | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // Check if the plugin is crashing too much. | ||||||
|  |   if (PluginService::GetInstance()->IsPluginUnstable(plugin.path) && | ||||||
|  |       !always_authorize_plugins_.GetValue() && | ||||||
|  |       plugin_setting != CONTENT_SETTING_BLOCK && | ||||||
|  |       uses_default_content_setting) { | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kUnauthorized; | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  |   // If an app has explicitly made internal resources available by listing them | ||||||
|  |   // in |accessible_resources| in the manifest, then allow them to be loaded by | ||||||
|  |   // plugins inside a guest-view. | ||||||
|  |   if (params.url.SchemeIs(extensions::kExtensionScheme) && !is_managed && | ||||||
|  |       plugin_setting == CONTENT_SETTING_BLOCK && | ||||||
|  |       IsPluginLoadingAccessibleResourceInWebView( | ||||||
|  |           extension_registry_, render_process_id_, params.url)) { | ||||||
|  |     plugin_setting = CONTENT_SETTING_ALLOW; | ||||||
|  |   } | ||||||
|  | #endif  // defined(ENABLE_EXTENSIONS) | ||||||
|  |  | ||||||
|  |   if (plugin_setting == CONTENT_SETTING_DETECT_IMPORTANT_CONTENT) { | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent; | ||||||
|  |   } else if (plugin_setting == CONTENT_SETTING_BLOCK) { | ||||||
|  |     // For managed users with the ASK policy, we allow manually running plugins | ||||||
|  |     // via context menu. This is the closest to admin intent. | ||||||
|  |     *status = is_managed && !legacy_ask_user | ||||||
|  |                   ? CefViewHostMsg_GetPluginInfo_Status::kBlockedByPolicy | ||||||
|  |                   : CefViewHostMsg_GetPluginInfo_Status::kBlocked; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (*status == CefViewHostMsg_GetPluginInfo_Status::kAllowed) { | ||||||
|  |     // Allow an embedder of <webview> to block a plugin from being loaded inside | ||||||
|  |     // the guest. In order to do this, set the status to 'Unauthorized' here, | ||||||
|  |     // and update the status as appropriate depending on the response from the | ||||||
|  |     // embedder. | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  |     if (extensions::WebViewRendererState::GetInstance()->IsGuest( | ||||||
|  |             render_process_id_)) { | ||||||
|  |       *status = CefViewHostMsg_GetPluginInfo_Status::kUnauthorized; | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefPluginInfoMessageFilter::Context::FindEnabledPlugin( | ||||||
|  |     int render_frame_id, | ||||||
|  |     const GURL& url, | ||||||
|  |     const GURL& top_origin_url, | ||||||
|  |     const std::string& mime_type, | ||||||
|  |     CefViewHostMsg_GetPluginInfo_Status* status, | ||||||
|  |     WebPluginInfo* plugin, | ||||||
|  |     std::string* actual_mime_type, | ||||||
|  |     scoped_ptr<PluginMetadata>* plugin_metadata) const { | ||||||
|  |   *status = CefViewHostMsg_GetPluginInfo_Status::kAllowed; | ||||||
|  |  | ||||||
|  |   bool allow_wildcard = true; | ||||||
|  |   std::vector<WebPluginInfo> matching_plugins; | ||||||
|  |   std::vector<std::string> mime_types; | ||||||
|  |   PluginService::GetInstance()->GetPluginInfoArray( | ||||||
|  |       url, mime_type, allow_wildcard, &matching_plugins, &mime_types); | ||||||
|  |   if (matching_plugins.empty()) { | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kNotFound; | ||||||
|  | #if defined(OS_WIN) || defined(OS_MACOSX) | ||||||
|  |     if (!PluginService::GetInstance()->NPAPIPluginsSupported()) { | ||||||
|  |       // At this point it is not known for sure this is an NPAPI plugin as it | ||||||
|  |       // could be a not-yet-installed Pepper plugin. To avoid notifying on | ||||||
|  |       // these types, bail early based on a blacklist of pepper mime types. | ||||||
|  |       for (auto pepper_mime_type : kPepperPluginMimeTypes) | ||||||
|  |         if (pepper_mime_type == mime_type) | ||||||
|  |           return false; | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   content::PluginServiceFilter* filter = | ||||||
|  |       PluginService::GetInstance()->GetFilter(); | ||||||
|  |   size_t i = 0; | ||||||
|  |   for (; i < matching_plugins.size(); ++i) { | ||||||
|  |     if (!filter || filter->IsPluginAvailable(render_process_id_, | ||||||
|  |                                              render_frame_id, | ||||||
|  |                                              resource_context_, | ||||||
|  |                                              url, | ||||||
|  |                                              top_origin_url, | ||||||
|  |                                              &matching_plugins[i])) { | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // If we broke out of the loop, we have found an enabled plugin. | ||||||
|  |   bool enabled = i < matching_plugins.size(); | ||||||
|  |   if (!enabled) { | ||||||
|  |     // Otherwise, we only found disabled plugins, so we take the first one. | ||||||
|  |     i = 0; | ||||||
|  |     *status = CefViewHostMsg_GetPluginInfo_Status::kDisabled; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   *plugin = matching_plugins[i]; | ||||||
|  |   *actual_mime_type = mime_types[i]; | ||||||
|  |   if (plugin_metadata) | ||||||
|  |     *plugin_metadata = PluginFinder::GetInstance()->GetPluginMetadata(*plugin); | ||||||
|  |  | ||||||
|  |   return enabled; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginInfoMessageFilter::Context::GetPluginContentSetting( | ||||||
|  |     const WebPluginInfo& plugin, | ||||||
|  |     const GURL& policy_url, | ||||||
|  |     const GURL& plugin_url, | ||||||
|  |     const std::string& resource, | ||||||
|  |     ContentSetting* setting, | ||||||
|  |     bool* uses_default_content_setting, | ||||||
|  |     bool* is_managed) const { | ||||||
|  |   scoped_ptr<base::Value> value; | ||||||
|  |   content_settings::SettingInfo info; | ||||||
|  |   bool uses_plugin_specific_setting = false; | ||||||
|  |   if (ShouldUseJavaScriptSettingForPlugin(plugin)) { | ||||||
|  |     value = host_content_settings_map_->GetWebsiteSetting( | ||||||
|  |         policy_url, | ||||||
|  |         policy_url, | ||||||
|  |         CONTENT_SETTINGS_TYPE_JAVASCRIPT, | ||||||
|  |         std::string(), | ||||||
|  |         &info); | ||||||
|  |   } else { | ||||||
|  |     content_settings::SettingInfo specific_info; | ||||||
|  |     scoped_ptr<base::Value> specific_setting = | ||||||
|  |         host_content_settings_map_->GetWebsiteSetting( | ||||||
|  |             policy_url, | ||||||
|  |             plugin_url, | ||||||
|  |             CONTENT_SETTINGS_TYPE_PLUGINS, | ||||||
|  |             resource, | ||||||
|  |             &specific_info); | ||||||
|  |     content_settings::SettingInfo general_info; | ||||||
|  |     scoped_ptr<base::Value> general_setting = | ||||||
|  |         host_content_settings_map_->GetWebsiteSetting( | ||||||
|  |             policy_url, | ||||||
|  |             plugin_url, | ||||||
|  |             CONTENT_SETTINGS_TYPE_PLUGINS, | ||||||
|  |             std::string(), | ||||||
|  |             &general_info); | ||||||
|  |  | ||||||
|  |     // If there is a plugin-specific setting, we use it, unless the general | ||||||
|  |     // setting was set by policy, in which case it takes precedence. | ||||||
|  |     // TODO(tommycli): Remove once we deprecate the plugin ASK policy. | ||||||
|  |     bool legacy_ask_user = content_settings::ValueToContentSetting( | ||||||
|  |                                general_setting.get()) == CONTENT_SETTING_ASK; | ||||||
|  |     bool use_policy = | ||||||
|  |         general_info.source == content_settings::SETTING_SOURCE_POLICY && | ||||||
|  |         !legacy_ask_user; | ||||||
|  |     uses_plugin_specific_setting = specific_setting && !use_policy; | ||||||
|  |     if (uses_plugin_specific_setting) { | ||||||
|  |       value = specific_setting.Pass(); | ||||||
|  |       info = specific_info; | ||||||
|  |     } else { | ||||||
|  |       value = general_setting.Pass(); | ||||||
|  |       info = general_info; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   *setting = content_settings::ValueToContentSetting(value.get()); | ||||||
|  |   *uses_default_content_setting = | ||||||
|  |       !uses_plugin_specific_setting && | ||||||
|  |       info.primary_pattern == ContentSettingsPattern::Wildcard() && | ||||||
|  |       info.secondary_pattern == ContentSettingsPattern::Wildcard(); | ||||||
|  |   *is_managed = info.source == content_settings::SETTING_SOURCE_POLICY; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefPluginInfoMessageFilter::Context::IsPluginEnabled( | ||||||
|  |     const content::WebPluginInfo& plugin) const { | ||||||
|  |   return true; | ||||||
|  | } | ||||||
| @@ -3,8 +3,8 @@ | |||||||
| // Use of this source code is governed by a BSD-style license that can be
 | // Use of this source code is governed by a BSD-style license that can be
 | ||||||
| // found in the LICENSE file.
 | // found in the LICENSE file.
 | ||||||
| 
 | 
 | ||||||
| #ifndef CEF_LIBCEF_BROWSER_EXTENSIONS_PLUGIN_INFO_MESSAGE_FILTER_H_ | #ifndef CEF_LIBCEF_BROWSER_PLUGINS_PLUGIN_INFO_MESSAGE_FILTER_H_ | ||||||
| #define CEF_LIBCEF_BROWSER_EXTENSIONS_PLUGIN_INFO_MESSAGE_FILTER_H_ | #define CEF_LIBCEF_BROWSER_PLUGINS_PLUGIN_INFO_MESSAGE_FILTER_H_ | ||||||
| 
 | 
 | ||||||
| #include <string> | #include <string> | ||||||
| #include <vector> | #include <vector> | ||||||
| @@ -14,19 +14,24 @@ | |||||||
| #include "base/memory/weak_ptr.h" | #include "base/memory/weak_ptr.h" | ||||||
| #include "base/prefs/pref_member.h" | #include "base/prefs/pref_member.h" | ||||||
| #include "base/sequenced_task_runner_helpers.h" | #include "base/sequenced_task_runner_helpers.h" | ||||||
|  | #include "chrome/browser/plugins/plugin_metadata.h" | ||||||
|  | #include "components/content_settings/core/browser/host_content_settings_map.h" | ||||||
|  | #include "components/content_settings/core/common/content_settings.h" | ||||||
| #include "content/public/browser/browser_message_filter.h" | #include "content/public/browser/browser_message_filter.h" | ||||||
| 
 | 
 | ||||||
|  | class CefBrowserContext; | ||||||
| struct CefViewHostMsg_GetPluginInfo_Output; | struct CefViewHostMsg_GetPluginInfo_Output; | ||||||
| enum class CefViewHostMsg_GetPluginInfo_Status; | enum class CefViewHostMsg_GetPluginInfo_Status; | ||||||
| class GURL; | class GURL; | ||||||
| 
 | 
 | ||||||
| namespace content { | namespace content { | ||||||
| class BrowserContext; |  | ||||||
| class ResourceContext; | class ResourceContext; | ||||||
| struct WebPluginInfo; | struct WebPluginInfo; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| namespace extensions { | namespace extensions { | ||||||
|  | class ExtensionRegistry; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| // This class filters out incoming IPC messages requesting plugin information.
 | // This class filters out incoming IPC messages requesting plugin information.
 | ||||||
| class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | ||||||
| @@ -36,13 +41,14 @@ class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | |||||||
|   // Contains all the information needed by the CefPluginInfoMessageFilter.
 |   // Contains all the information needed by the CefPluginInfoMessageFilter.
 | ||||||
|   class Context { |   class Context { | ||||||
|    public: |    public: | ||||||
|     Context(int render_process_id, content::BrowserContext* browser_context); |     Context(int render_process_id, CefBrowserContext* profile); | ||||||
| 
 | 
 | ||||||
|     ~Context(); |     ~Context(); | ||||||
| 
 | 
 | ||||||
|     void DecidePluginStatus( |     void DecidePluginStatus( | ||||||
|         const GetPluginInfo_Params& params, |         const GetPluginInfo_Params& params, | ||||||
|         const content::WebPluginInfo& plugin, |         const content::WebPluginInfo& plugin, | ||||||
|  |         const PluginMetadata* plugin_metadata, | ||||||
|         CefViewHostMsg_GetPluginInfo_Status* status) const; |         CefViewHostMsg_GetPluginInfo_Status* status) const; | ||||||
|     bool FindEnabledPlugin(int render_frame_id, |     bool FindEnabledPlugin(int render_frame_id, | ||||||
|                            const GURL& url, |                            const GURL& url, | ||||||
| @@ -50,15 +56,33 @@ class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | |||||||
|                            const std::string& mime_type, |                            const std::string& mime_type, | ||||||
|                            CefViewHostMsg_GetPluginInfo_Status* status, |                            CefViewHostMsg_GetPluginInfo_Status* status, | ||||||
|                            content::WebPluginInfo* plugin, |                            content::WebPluginInfo* plugin, | ||||||
|                            std::string* actual_mime_type) const; |                            std::string* actual_mime_type, | ||||||
|  |                            scoped_ptr<PluginMetadata>* plugin_metadata) const; | ||||||
|  |     void GetPluginContentSetting(const content::WebPluginInfo& plugin, | ||||||
|  |                                  const GURL& policy_url, | ||||||
|  |                                  const GURL& plugin_url, | ||||||
|  |                                  const std::string& resource, | ||||||
|  |                                  ContentSetting* setting, | ||||||
|  |                                  bool* is_default, | ||||||
|  |                                  bool* is_managed) const; | ||||||
|  |     void MaybeGrantAccess(CefViewHostMsg_GetPluginInfo_Status status, | ||||||
|  |                           const base::FilePath& path) const; | ||||||
|  |     bool IsPluginEnabled(const content::WebPluginInfo& plugin) const; | ||||||
| 
 | 
 | ||||||
|    private: |    private: | ||||||
|     int render_process_id_; |     int render_process_id_; | ||||||
|     content::ResourceContext* resource_context_; |     content::ResourceContext* resource_context_; | ||||||
|  | #if defined(ENABLE_EXTENSIONS) | ||||||
|  |     extensions::ExtensionRegistry* extension_registry_; | ||||||
|  | #endif | ||||||
|  |     const HostContentSettingsMap* host_content_settings_map_; | ||||||
|  | 
 | ||||||
|  |     BooleanPrefMember allow_outdated_plugins_; | ||||||
|  |     BooleanPrefMember always_authorize_plugins_; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   CefPluginInfoMessageFilter(int render_process_id, |   CefPluginInfoMessageFilter(int render_process_id, | ||||||
|                              content::BrowserContext* browser_context); |                              CefBrowserContext* profile); | ||||||
| 
 | 
 | ||||||
|   // content::BrowserMessageFilter methods:
 |   // content::BrowserMessageFilter methods:
 | ||||||
|   bool OnMessageReceived(const IPC::Message& message) override; |   bool OnMessageReceived(const IPC::Message& message) override; | ||||||
| @@ -76,11 +100,6 @@ class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | |||||||
|                        const GURL& top_origin_url, |                        const GURL& top_origin_url, | ||||||
|                        const std::string& mime_type, |                        const std::string& mime_type, | ||||||
|                        IPC::Message* reply_msg); |                        IPC::Message* reply_msg); | ||||||
|   void OnIsInternalPluginAvailableForMimeType( |  | ||||||
|       const std::string& mime_type, |  | ||||||
|       bool* is_available, |  | ||||||
|       std::vector<base::string16>* additional_param_names, |  | ||||||
|       std::vector<base::string16>* additional_param_values); |  | ||||||
| 
 | 
 | ||||||
|   // |params| wraps the parameters passed to |OnGetPluginInfo|, because
 |   // |params| wraps the parameters passed to |OnGetPluginInfo|, because
 | ||||||
|   // |base::Bind| doesn't support the required arity <http://crbug.com/98542>.
 |   // |base::Bind| doesn't support the required arity <http://crbug.com/98542>.
 | ||||||
| @@ -88,7 +107,23 @@ class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | |||||||
|                      IPC::Message* reply_msg, |                      IPC::Message* reply_msg, | ||||||
|                      const std::vector<content::WebPluginInfo>& plugins); |                      const std::vector<content::WebPluginInfo>& plugins); | ||||||
| 
 | 
 | ||||||
|  | #if defined(ENABLE_PEPPER_CDMS) | ||||||
|  |   // Returns whether any internal plugin supporting |mime_type| is registered
 | ||||||
|  |   // and enabled. Does not determine whether the plugin can actually be
 | ||||||
|  |   // instantiated (e.g. whether it has all its dependencies).
 | ||||||
|  |   // When the returned *|is_available| is true, |additional_param_names| and
 | ||||||
|  |   // |additional_param_values| contain the name-value pairs, if any, specified
 | ||||||
|  |   // for the *first* non-disabled plugin found that is registered for
 | ||||||
|  |   // |mime_type|.
 | ||||||
|  |   void OnIsInternalPluginAvailableForMimeType( | ||||||
|  |       const std::string& mime_type, | ||||||
|  |       bool* is_available, | ||||||
|  |       std::vector<base::string16>* additional_param_names, | ||||||
|  |       std::vector<base::string16>* additional_param_values); | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|   Context context_; |   Context context_; | ||||||
|  |   CefBrowserContext* browser_context_; | ||||||
| 
 | 
 | ||||||
|   scoped_refptr<base::SingleThreadTaskRunner> main_thread_task_runner_; |   scoped_refptr<base::SingleThreadTaskRunner> main_thread_task_runner_; | ||||||
|   base::WeakPtrFactory<CefPluginInfoMessageFilter> weak_ptr_factory_; |   base::WeakPtrFactory<CefPluginInfoMessageFilter> weak_ptr_factory_; | ||||||
| @@ -96,6 +131,4 @@ class CefPluginInfoMessageFilter : public content::BrowserMessageFilter { | |||||||
|   DISALLOW_COPY_AND_ASSIGN(CefPluginInfoMessageFilter); |   DISALLOW_COPY_AND_ASSIGN(CefPluginInfoMessageFilter); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| }  // namespace extensions
 | #endif  // CEF_LIBCEF_BROWSER_PLUGINS_PLUGIN_INFO_MESSAGE_FILTER_H_
 | ||||||
| 
 |  | ||||||
| #endif  // CEF_LIBCEF_BROWSER_EXTENSIONS_PLUGIN_INFO_MESSAGE_FILTER_H_
 |  | ||||||
| @@ -163,6 +163,11 @@ IPC_MESSAGE_ROUTED1(CefMsg_Response, | |||||||
| IPC_MESSAGE_ROUTED1(CefMsg_ResponseAck, | IPC_MESSAGE_ROUTED1(CefMsg_ResponseAck, | ||||||
|                     int /* request_id */) |                     int /* request_id */) | ||||||
|  |  | ||||||
|  | // Tells the render frame to load all blocked plugins with the given identifier. | ||||||
|  | // Based on ChromeViewMsg_LoadBlockedPlugins. | ||||||
|  | IPC_MESSAGE_ROUTED1(CefViewMsg_LoadBlockedPlugins, | ||||||
|  |                     std::string /* identifier */) | ||||||
|  |  | ||||||
| // Sent on process startup to indicate whether this process is running in | // Sent on process startup to indicate whether this process is running in | ||||||
| // incognito mode. Based on ChromeViewMsg_SetIsIncognitoProcess. | // incognito mode. Based on ChromeViewMsg_SetIsIncognitoProcess. | ||||||
| IPC_MESSAGE_CONTROL1(CefProcessMsg_SetIsIncognitoProcess, | IPC_MESSAGE_CONTROL1(CefProcessMsg_SetIsIncognitoProcess, | ||||||
|   | |||||||
| @@ -112,4 +112,14 @@ const char kWidevineCdmPath[]             = "widevine-cdm-path"; | |||||||
| // Widevine CDM version. | // Widevine CDM version. | ||||||
| const char kWidevineCdmVersion[]          = "widevine-cdm-version"; | const char kWidevineCdmVersion[]          = "widevine-cdm-version"; | ||||||
|  |  | ||||||
|  | // Default plugin policy action. | ||||||
|  | const char kPluginPolicy[]                = "plugin-policy"; | ||||||
|  | // Allow the content. This is the default value. | ||||||
|  | const char kPluginPolicy_Allow[]          = "allow"; | ||||||
|  | // Allow important content and block unimportant content based on heuristics. | ||||||
|  | // The user can manually load blocked content. | ||||||
|  | const char kPluginPolicy_Detect[]         = "detect"; | ||||||
|  | // Block the content. The user can manually load blocked content. | ||||||
|  | const char kPluginPolicy_Block[]          = "block"; | ||||||
|  |  | ||||||
| }  // namespace switches | }  // namespace switches | ||||||
|   | |||||||
| @@ -47,6 +47,10 @@ extern const char kDisablePdfExtension[]; | |||||||
| extern const char kEnableWidevineCdm[]; | extern const char kEnableWidevineCdm[]; | ||||||
| extern const char kWidevineCdmPath[]; | extern const char kWidevineCdmPath[]; | ||||||
| extern const char kWidevineCdmVersion[]; | extern const char kWidevineCdmVersion[]; | ||||||
|  | extern const char kPluginPolicy[]; | ||||||
|  | extern const char kPluginPolicy_Allow[]; | ||||||
|  | extern const char kPluginPolicy_Detect[]; | ||||||
|  | extern const char kPluginPolicy_Block[]; | ||||||
|  |  | ||||||
| }  // namespace switches | }  // namespace switches | ||||||
|  |  | ||||||
|   | |||||||
| @@ -429,8 +429,15 @@ bool CefContentClient::GetRawDataResource(int resource_id, | |||||||
|     if (handler.get()) { |     if (handler.get()) { | ||||||
|       void* data = NULL; |       void* data = NULL; | ||||||
|       size_t data_size = 0; |       size_t data_size = 0; | ||||||
|       if (handler->GetDataResource(resource_id, data, data_size)) |       if (scale_factor != ui::SCALE_FACTOR_NONE) { | ||||||
|  |         if (handler->GetDataResourceForScale( | ||||||
|  |               resource_id, static_cast<cef_scale_factor_t>(scale_factor), data, | ||||||
|  |               data_size)) { | ||||||
|  |           *value = base::StringPiece(static_cast<char*>(data), data_size); | ||||||
|  |         } | ||||||
|  |       } else if (handler->GetDataResource(resource_id, data, data_size)) { | ||||||
|         *value = base::StringPiece(static_cast<char*>(data), data_size); |         *value = base::StringPiece(static_cast<char*>(data), data_size); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,10 +27,12 @@ | |||||||
| #include "chrome/common/chrome_paths.h" | #include "chrome/common/chrome_paths.h" | ||||||
| #include "chrome/common/chrome_switches.h" | #include "chrome/common/chrome_switches.h" | ||||||
| #include "chrome/common/widevine_cdm_constants.h" | #include "chrome/common/widevine_cdm_constants.h" | ||||||
|  | #include "components/content_settings/core/common/content_settings_pattern.h" | ||||||
| #include "content/public/browser/browser_main_runner.h" | #include "content/public/browser/browser_main_runner.h" | ||||||
| #include "content/public/browser/render_process_host.h" | #include "content/public/browser/render_process_host.h" | ||||||
| #include "content/public/common/content_switches.h" | #include "content/public/common/content_switches.h" | ||||||
| #include "content/public/common/main_function_params.h" | #include "content/public/common/main_function_params.h" | ||||||
|  | #include "extensions/common/constants.h" | ||||||
| #include "pdf/pdf.h" | #include "pdf/pdf.h" | ||||||
| #include "ui/base/layout.h" | #include "ui/base/layout.h" | ||||||
| #include "ui/base/resource/resource_bundle.h" | #include "ui/base/resource/resource_bundle.h" | ||||||
| @@ -483,6 +485,9 @@ bool CefMainDelegate::BasicStartupComplete(int* exit_code) { | |||||||
|  |  | ||||||
|   logging::InitLogging(log_settings); |   logging::InitLogging(log_settings); | ||||||
|  |  | ||||||
|  |   ContentSettingsPattern::SetNonWildcardDomainNonPortScheme( | ||||||
|  |       extensions::kExtensionScheme); | ||||||
|  |  | ||||||
|   content::SetContentClient(&content_client_); |   content::SetContentClient(&content_client_); | ||||||
|  |  | ||||||
|   return false; |   return false; | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ | |||||||
| #include "libcef/renderer/webkit_glue.h" | #include "libcef/renderer/webkit_glue.h" | ||||||
|  |  | ||||||
| #include "base/base64.h" | #include "base/base64.h" | ||||||
|  | #include "base/threading/thread_restrictions.h" | ||||||
| #include "net/base/escape.h" | #include "net/base/escape.h" | ||||||
| #include "net/base/mime_util.h" | #include "net/base/mime_util.h" | ||||||
| #include "third_party/WebKit/public/platform/WebString.h" | #include "third_party/WebKit/public/platform/WebString.h" | ||||||
| @@ -76,6 +77,10 @@ bool CefCreateURL(const CefURLParts& parts, | |||||||
| } | } | ||||||
|  |  | ||||||
| CefString CefGetMimeType(const CefString& extension) { | CefString CefGetMimeType(const CefString& extension) { | ||||||
|  |   // Requests should not block on the disk!  On POSIX this goes to disk. | ||||||
|  |   // http://code.google.com/p/chromium/issues/detail?id=59849 | ||||||
|  |   base::ThreadRestrictions::ScopedAllowIO allow_io; | ||||||
|  |  | ||||||
|   std::string mime_type; |   std::string mime_type; | ||||||
|   net::GetMimeTypeFromExtension(extension, &mime_type); |   net::GetMimeTypeFromExtension(extension, &mime_type); | ||||||
|   return mime_type; |   return mime_type; | ||||||
|   | |||||||
							
								
								
									
										47
									
								
								libcef/common/resource_bundle_impl.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								libcef/common/resource_bundle_impl.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework 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 "libcef/common/resource_bundle_impl.h" | ||||||
|  |  | ||||||
|  | #include "ui/base/resource/resource_bundle.h" | ||||||
|  |  | ||||||
|  | CefResourceBundleImpl::CefResourceBundleImpl() { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefString CefResourceBundleImpl::GetLocalizedString(int string_id) { | ||||||
|  |   if (!ui::ResourceBundle::HasSharedInstance()) | ||||||
|  |     return CefString(); | ||||||
|  |  | ||||||
|  |   return ui::ResourceBundle::GetSharedInstance().GetLocalizedString(string_id); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefResourceBundleImpl::GetDataResource(int resource_id, | ||||||
|  |                                             void*& data, | ||||||
|  |                                             size_t& data_size) { | ||||||
|  |   return GetDataResourceForScale(resource_id, SCALE_FACTOR_NONE, data, | ||||||
|  |                                  data_size); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefResourceBundleImpl::GetDataResourceForScale(int resource_id, | ||||||
|  |                                                     ScaleFactor scale_factor, | ||||||
|  |                                                     void*& data, | ||||||
|  |                                                     size_t& data_size) { | ||||||
|  |   if (!ui::ResourceBundle::HasSharedInstance()) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   const base::StringPiece& result = | ||||||
|  |       ui::ResourceBundle::GetSharedInstance().GetRawDataResourceForScale( | ||||||
|  |           resource_id, static_cast<ui::ScaleFactor>(scale_factor)); | ||||||
|  |   if (result.empty()) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   data = const_cast<char*>(result.data()); | ||||||
|  |   data_size = result.size(); | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // static | ||||||
|  | CefRefPtr<CefResourceBundle> CefResourceBundle::GetGlobal() { | ||||||
|  |   return new CefResourceBundleImpl(); | ||||||
|  | } | ||||||
							
								
								
									
										31
									
								
								libcef/common/resource_bundle_impl.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								libcef/common/resource_bundle_impl.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework 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 CEF_LIBCEF_COMMON_RESOURCE_BUNDLE_IMPL_H_ | ||||||
|  | #define CEF_LIBCEF_COMMON_RESOURCE_BUNDLE_IMPL_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #include "include/cef_resource_bundle.h" | ||||||
|  |  | ||||||
|  | class CefResourceBundleImpl : public CefResourceBundle { | ||||||
|  |  public: | ||||||
|  |   CefResourceBundleImpl(); | ||||||
|  |  | ||||||
|  |   // CefResourceBundle methods. | ||||||
|  |   CefString GetLocalizedString(int string_id) override; | ||||||
|  |   bool GetDataResource(int resource_id, | ||||||
|  |                        void*& data, | ||||||
|  |                        size_t& data_size) override; | ||||||
|  |   bool GetDataResourceForScale(int resource_id, | ||||||
|  |                                ScaleFactor scale_factor, | ||||||
|  |                                void*& data, | ||||||
|  |                                size_t& data_size) override; | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   IMPLEMENT_REFCOUNTING(CefResourceBundleImpl); | ||||||
|  |   DISALLOW_COPY_AND_ASSIGN(CefResourceBundleImpl); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // CEF_LIBCEF_COMMON_RESOURCE_BUNDLE_IMPL_H_ | ||||||
| @@ -18,6 +18,8 @@ | |||||||
| #include "libcef/renderer/extensions/print_web_view_helper_delegate.h" | #include "libcef/renderer/extensions/print_web_view_helper_delegate.h" | ||||||
| #include "libcef/renderer/media/cef_key_systems.h" | #include "libcef/renderer/media/cef_key_systems.h" | ||||||
| #include "libcef/renderer/pepper/pepper_helper.h" | #include "libcef/renderer/pepper/pepper_helper.h" | ||||||
|  | #include "libcef/renderer/plugins/cef_plugin_placeholder.h" | ||||||
|  | #include "libcef/renderer/plugins/plugin_preroller.h" | ||||||
| #include "libcef/renderer/render_frame_observer.h" | #include "libcef/renderer/render_frame_observer.h" | ||||||
| #include "libcef/renderer/render_message_filter.h" | #include "libcef/renderer/render_message_filter.h" | ||||||
| #include "libcef/renderer/render_process_observer.h" | #include "libcef/renderer/render_process_observer.h" | ||||||
| @@ -26,15 +28,20 @@ | |||||||
| #include "libcef/renderer/webkit_glue.h" | #include "libcef/renderer/webkit_glue.h" | ||||||
|  |  | ||||||
| #include "base/command_line.h" | #include "base/command_line.h" | ||||||
|  | #include "base/metrics/user_metrics_action.h" | ||||||
| #include "base/path_service.h" | #include "base/path_service.h" | ||||||
| #include "base/strings/string_number_conversions.h" | #include "base/strings/string_number_conversions.h" | ||||||
| #include "base/strings/utf_string_conversions.h" | #include "base/strings/utf_string_conversions.h" | ||||||
|  | #include "chrome/common/chrome_switches.h" | ||||||
| #include "chrome/common/pepper_permission_util.h" | #include "chrome/common/pepper_permission_util.h" | ||||||
|  | #include "chrome/grit/generated_resources.h" | ||||||
|  | #include "chrome/renderer/content_settings_observer.h" | ||||||
| #include "chrome/renderer/loadtimes_extension_bindings.h" | #include "chrome/renderer/loadtimes_extension_bindings.h" | ||||||
| #include "chrome/renderer/pepper/chrome_pdf_print_client.h" | #include "chrome/renderer/pepper/chrome_pdf_print_client.h" | ||||||
| #include "chrome/renderer/spellchecker/spellcheck.h" | #include "chrome/renderer/spellchecker/spellcheck.h" | ||||||
| #include "chrome/renderer/spellchecker/spellcheck_provider.h" | #include "chrome/renderer/spellchecker/spellcheck_provider.h" | ||||||
| #include "components/content_settings/core/common/content_settings_types.h" | #include "components/content_settings/core/common/content_settings_types.h" | ||||||
|  | #include "components/nacl/common/nacl_constants.h" | ||||||
| #include "components/printing/renderer/print_web_view_helper.h" | #include "components/printing/renderer/print_web_view_helper.h" | ||||||
| #include "components/web_cache/renderer/web_cache_render_process_observer.h" | #include "components/web_cache/renderer/web_cache_render_process_observer.h" | ||||||
| #include "content/child/worker_task_runner.h" | #include "content/child/worker_task_runner.h" | ||||||
| @@ -61,6 +68,7 @@ | |||||||
| #include "third_party/WebKit/public/platform/WebPrerenderingSupport.h" | #include "third_party/WebKit/public/platform/WebPrerenderingSupport.h" | ||||||
| #include "third_party/WebKit/public/platform/WebString.h" | #include "third_party/WebKit/public/platform/WebString.h" | ||||||
| #include "third_party/WebKit/public/platform/WebURL.h" | #include "third_party/WebKit/public/platform/WebURL.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebConsoleMessage.h" | ||||||
| #include "third_party/WebKit/public/web/WebDocument.h" | #include "third_party/WebKit/public/web/WebDocument.h" | ||||||
| #include "third_party/WebKit/public/web/WebElement.h" | #include "third_party/WebKit/public/web/WebElement.h" | ||||||
| #include "third_party/WebKit/public/web/WebFrame.h" | #include "third_party/WebKit/public/web/WebFrame.h" | ||||||
| @@ -70,6 +78,7 @@ | |||||||
| #include "third_party/WebKit/public/web/WebRuntimeFeatures.h" | #include "third_party/WebKit/public/web/WebRuntimeFeatures.h" | ||||||
| #include "third_party/WebKit/public/web/WebSecurityPolicy.h" | #include "third_party/WebKit/public/web/WebSecurityPolicy.h" | ||||||
| #include "third_party/WebKit/public/web/WebView.h" | #include "third_party/WebKit/public/web/WebView.h" | ||||||
|  | #include "ui/base/l10n/l10n_util.h" | ||||||
|  |  | ||||||
| #if defined(OS_MACOSX) | #if defined(OS_MACOSX) | ||||||
| #include "base/mac/mac_util.h" | #include "base/mac/mac_util.h" | ||||||
| @@ -185,6 +194,19 @@ void AppendParams(const std::vector<base::string16>& additional_names, | |||||||
|   existing_values->swap(values); |   existing_values->swap(values); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | std::string GetPluginInstancePosterAttribute( | ||||||
|  |     const blink::WebPluginParams& params) { | ||||||
|  |   DCHECK_EQ(params.attributeNames.size(), params.attributeValues.size()); | ||||||
|  |  | ||||||
|  |   for (size_t i = 0; i < params.attributeNames.size(); ++i) { | ||||||
|  |     if (params.attributeNames[i].utf8() == "poster" && | ||||||
|  |         !params.attributeValues[i].isEmpty()) { | ||||||
|  |       return params.attributeValues[i].utf8(); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return std::string(); | ||||||
|  | } | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|  |  | ||||||
| CefContentRendererClient::CefContentRendererClient() | CefContentRendererClient::CefContentRendererClient() | ||||||
| @@ -566,9 +588,10 @@ bool CefContentRendererClient::OverrideCreatePlugin( | |||||||
|  |  | ||||||
|   GURL url(params.url); |   GURL url(params.url); | ||||||
|   CefViewHostMsg_GetPluginInfo_Output output; |   CefViewHostMsg_GetPluginInfo_Output output; | ||||||
|  |   blink::WebString top_origin = frame->top()->securityOrigin().toString(); | ||||||
|   render_frame->Send(new CefViewHostMsg_GetPluginInfo( |   render_frame->Send(new CefViewHostMsg_GetPluginInfo( | ||||||
|       render_frame->GetRoutingID(), url, frame->top()->document().url(), |       render_frame->GetRoutingID(), url, GURL(top_origin), orig_mime_type, | ||||||
|       orig_mime_type, &output)); |       &output)); | ||||||
|  |  | ||||||
|   *plugin = CreatePlugin(render_frame, frame, params, output); |   *plugin = CreatePlugin(render_frame, frame, params, output); | ||||||
|   return true; |   return true; | ||||||
| @@ -656,6 +679,7 @@ void CefContentRendererClient::WillDestroyCurrentMessageLoop() { | |||||||
|   single_process_cleanup_complete_ = true; |   single_process_cleanup_complete_ = true; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // static | ||||||
| bool CefContentRendererClient::IsExtensionOrSharedModuleWhitelisted( | bool CefContentRendererClient::IsExtensionOrSharedModuleWhitelisted( | ||||||
|     const GURL& url, const std::set<std::string>& whitelist) { |     const GURL& url, const std::set<std::string>& whitelist) { | ||||||
|   DCHECK(extensions::ExtensionsEnabled()); |   DCHECK(extensions::ExtensionsEnabled()); | ||||||
| @@ -665,6 +689,167 @@ bool CefContentRendererClient::IsExtensionOrSharedModuleWhitelisted( | |||||||
|       whitelist); |       whitelist); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // static | ||||||
|  | blink::WebPlugin* CefContentRendererClient::CreatePlugin( | ||||||
|  |     content::RenderFrame* render_frame, | ||||||
|  |     blink::WebLocalFrame* frame, | ||||||
|  |     const blink::WebPluginParams& original_params, | ||||||
|  |     const CefViewHostMsg_GetPluginInfo_Output& output) { | ||||||
|  |   const content::WebPluginInfo& info = output.plugin; | ||||||
|  |   const std::string& actual_mime_type = output.actual_mime_type; | ||||||
|  |   const base::string16& group_name = output.group_name; | ||||||
|  |   const std::string& identifier = output.group_identifier; | ||||||
|  |   CefViewHostMsg_GetPluginInfo_Status status = output.status; | ||||||
|  |   GURL url(original_params.url); | ||||||
|  |   std::string orig_mime_type = original_params.mimeType.utf8(); | ||||||
|  |   CefPluginPlaceholder* placeholder = NULL; | ||||||
|  |  | ||||||
|  |   // If the browser plugin is to be enabled, this should be handled by the | ||||||
|  |   // renderer, so the code won't reach here due to the early exit in | ||||||
|  |   // OverrideCreatePlugin. | ||||||
|  |   if (status == CefViewHostMsg_GetPluginInfo_Status::kNotFound || | ||||||
|  |       orig_mime_type == content::kBrowserPluginMimeType) { | ||||||
|  |     placeholder = CefPluginPlaceholder::CreateLoadableMissingPlugin( | ||||||
|  |         render_frame, frame, original_params); | ||||||
|  |   } else { | ||||||
|  |     // TODO(bauerb): This should be in content/. | ||||||
|  |     blink::WebPluginParams params(original_params); | ||||||
|  |     for (size_t i = 0; i < info.mime_types.size(); ++i) { | ||||||
|  |       if (info.mime_types[i].mime_type == actual_mime_type) { | ||||||
|  |         AppendParams(info.mime_types[i].additional_param_names, | ||||||
|  |                      info.mime_types[i].additional_param_values, | ||||||
|  |                      ¶ms.attributeNames, ¶ms.attributeValues); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     if (params.mimeType.isNull() && (actual_mime_type.size() > 0)) { | ||||||
|  |       // Webkit might say that mime type is null while we already know the | ||||||
|  |       // actual mime type via CefViewHostMsg_GetPluginInfo. In that case | ||||||
|  |       // we should use what we know since WebpluginDelegateProxy does some | ||||||
|  |       // specific initializations based on this information. | ||||||
|  |       params.mimeType = blink::WebString::fromUTF8(actual_mime_type.c_str()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     auto create_blocked_plugin = | ||||||
|  |         [&render_frame, &frame, ¶ms, &info, &identifier, &group_name]( | ||||||
|  |             int template_id, const base::string16& message) { | ||||||
|  |           return CefPluginPlaceholder::CreateBlockedPlugin( | ||||||
|  |               render_frame, frame, params, info, identifier, group_name, | ||||||
|  |               template_id, message, PlaceholderPosterInfo()); | ||||||
|  |         }; | ||||||
|  |     switch (status) { | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kNotFound: { | ||||||
|  |         NOTREACHED(); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kAllowed: | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent: { | ||||||
|  |         // Delay loading plugins if prerendering. | ||||||
|  |         // TODO(mmenke):  In the case of prerendering, feed into | ||||||
|  |         //                CefContentRendererClient::CreatePlugin instead, to | ||||||
|  |         //                reduce the chance of future regressions. | ||||||
|  |         bool is_prerendering = false; | ||||||
|  |         bool power_saver_enabled = | ||||||
|  |             status == | ||||||
|  |                 CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent; | ||||||
|  |         bool blocked_for_background_tab = | ||||||
|  |             render_frame->IsHidden() && power_saver_enabled; | ||||||
|  |  | ||||||
|  |         PlaceholderPosterInfo poster_info; | ||||||
|  |         if (power_saver_enabled) { | ||||||
|  |           poster_info.poster_attribute = | ||||||
|  |               GetPluginInstancePosterAttribute(params); | ||||||
|  |           poster_info.base_url = frame->document().url(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (blocked_for_background_tab || is_prerendering || | ||||||
|  |             !poster_info.poster_attribute.empty()) { | ||||||
|  |           placeholder = CefPluginPlaceholder::CreateBlockedPlugin( | ||||||
|  |               render_frame, frame, params, info, identifier, group_name, | ||||||
|  |               poster_info.poster_attribute.empty() ? IDR_BLOCKED_PLUGIN_HTML | ||||||
|  |                                                    : IDR_PLUGIN_POSTER_HTML, | ||||||
|  |               l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED, group_name), | ||||||
|  |               poster_info); | ||||||
|  |           placeholder->set_blocked_for_background_tab( | ||||||
|  |               blocked_for_background_tab); | ||||||
|  |           placeholder->set_blocked_for_prerendering(is_prerendering); | ||||||
|  |           placeholder->set_power_saver_enabled(power_saver_enabled); | ||||||
|  |           placeholder->AllowLoading(); | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         scoped_ptr<content::PluginInstanceThrottler> throttler; | ||||||
|  |         if (power_saver_enabled) { | ||||||
|  |           throttler = content::PluginInstanceThrottler::Create(); | ||||||
|  |           // PluginPreroller manages its own lifetime. | ||||||
|  |           new CefPluginPreroller( | ||||||
|  |               render_frame, frame, params, info, identifier, group_name, | ||||||
|  |               l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED, group_name), | ||||||
|  |               throttler.get()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         return render_frame->CreatePlugin(frame, info, params, | ||||||
|  |                                           throttler.Pass()); | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kNPAPINotSupported: { | ||||||
|  |         content::RenderThread::Get()->RecordAction( | ||||||
|  |             base::UserMetricsAction("Plugin_NPAPINotSupported")); | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringUTF16(IDS_PLUGIN_NOT_SUPPORTED_METRO)); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kDisabled: { | ||||||
|  |         // Intentionally using the blocked plugin resources instead of the | ||||||
|  |         // disabled plugin resources. This provides better messaging (no link to | ||||||
|  |         // chrome://plugins) and adds testing support. | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED_BY_POLICY, | ||||||
|  |                                        group_name)); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kOutdatedBlocked: { | ||||||
|  |         NOTREACHED() << "Plugin installation is not supported."; | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kOutdatedDisallowed: { | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringFUTF16(IDS_PLUGIN_OUTDATED, group_name)); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kUnauthorized: { | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringFUTF16(IDS_PLUGIN_NOT_AUTHORIZED, group_name)); | ||||||
|  |         placeholder->AllowLoading(); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kBlocked: { | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED, group_name)); | ||||||
|  |         placeholder->AllowLoading(); | ||||||
|  |         content::RenderThread::Get()->RecordAction( | ||||||
|  |             base::UserMetricsAction("Plugin_Blocked")); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |       case CefViewHostMsg_GetPluginInfo_Status::kBlockedByPolicy: { | ||||||
|  |         placeholder = create_blocked_plugin( | ||||||
|  |             IDR_BLOCKED_PLUGIN_HTML, | ||||||
|  |             l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED_BY_POLICY, | ||||||
|  |                                        group_name)); | ||||||
|  |         content::RenderThread::Get()->RecordAction( | ||||||
|  |             base::UserMetricsAction("Plugin_BlockedByPolicy")); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   placeholder->SetStatus(status); | ||||||
|  |   return placeholder->plugin(); | ||||||
|  | } | ||||||
|  |  | ||||||
| void CefContentRendererClient::BrowserCreated( | void CefContentRendererClient::BrowserCreated( | ||||||
|     content::RenderView* render_view, |     content::RenderView* render_view, | ||||||
|     content::RenderFrame* render_frame) { |     content::RenderFrame* render_frame) { | ||||||
| @@ -739,57 +924,3 @@ void CefContentRendererClient::RunSingleProcessCleanupOnUIThread() { | |||||||
|   if (!CefContext::Get()->settings().multi_threaded_message_loop) |   if (!CefContext::Get()->settings().multi_threaded_message_loop) | ||||||
|     delete host; |     delete host; | ||||||
| } | } | ||||||
|  |  | ||||||
| blink::WebPlugin* CefContentRendererClient::CreatePlugin( |  | ||||||
|     content::RenderFrame* render_frame, |  | ||||||
|     blink::WebLocalFrame* frame, |  | ||||||
|     const blink::WebPluginParams& original_params, |  | ||||||
|     const CefViewHostMsg_GetPluginInfo_Output& output) { |  | ||||||
|   const content::WebPluginInfo& info = output.plugin; |  | ||||||
|   const std::string& actual_mime_type = output.actual_mime_type; |  | ||||||
|   CefViewHostMsg_GetPluginInfo_Status status = output.status; |  | ||||||
|   GURL url(original_params.url); |  | ||||||
|   std::string orig_mime_type = original_params.mimeType.utf8(); |  | ||||||
|  |  | ||||||
|   // If the browser plugin is to be enabled, this should be handled by the |  | ||||||
|   // renderer, so the code won't reach here due to the early exit in |  | ||||||
|   // OverrideCreatePlugin. |  | ||||||
|   if (status == CefViewHostMsg_GetPluginInfo_Status::kNotFound || |  | ||||||
|       orig_mime_type == content::kBrowserPluginMimeType) { |  | ||||||
|     return NULL; |  | ||||||
|   } else { |  | ||||||
|     // TODO(bauerb): This should be in content/. |  | ||||||
|     blink::WebPluginParams params(original_params); |  | ||||||
|     for (size_t i = 0; i < info.mime_types.size(); ++i) { |  | ||||||
|       if (info.mime_types[i].mime_type == actual_mime_type) { |  | ||||||
|         AppendParams(info.mime_types[i].additional_param_names, |  | ||||||
|                      info.mime_types[i].additional_param_values, |  | ||||||
|                      ¶ms.attributeNames, ¶ms.attributeValues); |  | ||||||
|         break; |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     if (params.mimeType.isNull() && (actual_mime_type.size() > 0)) { |  | ||||||
|       // Webkit might say that mime type is null while we already know the |  | ||||||
|       // actual mime type via CefViewHostMsg_GetPluginInfo. In that case |  | ||||||
|       // we should use what we know since WebpluginDelegateProxy does some |  | ||||||
|       // specific initializations based on this information. |  | ||||||
|       params.mimeType = blink::WebString::fromUTF8(actual_mime_type.c_str()); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     switch (status) { |  | ||||||
|       case CefViewHostMsg_GetPluginInfo_Status::kNotFound: { |  | ||||||
|         NOTREACHED(); |  | ||||||
|         break; |  | ||||||
|       } |  | ||||||
|       case CefViewHostMsg_GetPluginInfo_Status::kAllowed: |  | ||||||
|       case CefViewHostMsg_GetPluginInfo_Status::kPlayImportantContent: { |  | ||||||
|         // TODO(cef): Maybe supply a throttler based on power settings. |  | ||||||
|         return render_frame->CreatePlugin(frame, info, params, nullptr); |  | ||||||
|       } |  | ||||||
|       default: |  | ||||||
|         // TODO(cef): Provide a placeholder for the various failure conditions. |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|   return NULL; |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -116,6 +116,12 @@ class CefContentRendererClient : public content::ContentRendererClient, | |||||||
|   static bool IsExtensionOrSharedModuleWhitelisted( |   static bool IsExtensionOrSharedModuleWhitelisted( | ||||||
|       const GURL& url, const std::set<std::string>& whitelist); |       const GURL& url, const std::set<std::string>& whitelist); | ||||||
|  |  | ||||||
|  |   static blink::WebPlugin* CreatePlugin( | ||||||
|  |       content::RenderFrame* render_frame, | ||||||
|  |       blink::WebLocalFrame* frame, | ||||||
|  |       const blink::WebPluginParams& params, | ||||||
|  |       const CefViewHostMsg_GetPluginInfo_Output& output); | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   void BrowserCreated(content::RenderView* render_view, |   void BrowserCreated(content::RenderView* render_view, | ||||||
|                       content::RenderFrame* render_frame); |                       content::RenderFrame* render_frame); | ||||||
| @@ -123,12 +129,6 @@ class CefContentRendererClient : public content::ContentRendererClient, | |||||||
|   // Perform cleanup work for single-process mode. |   // Perform cleanup work for single-process mode. | ||||||
|   void RunSingleProcessCleanupOnUIThread(); |   void RunSingleProcessCleanupOnUIThread(); | ||||||
|  |  | ||||||
|   static blink::WebPlugin* CreatePlugin( |  | ||||||
|       content::RenderFrame* render_frame, |  | ||||||
|       blink::WebLocalFrame* frame, |  | ||||||
|       const blink::WebPluginParams& params, |  | ||||||
|       const CefViewHostMsg_GetPluginInfo_Output& output); |  | ||||||
|  |  | ||||||
|   scoped_refptr<base::SequencedTaskRunner> render_task_runner_; |   scoped_refptr<base::SequencedTaskRunner> render_task_runner_; | ||||||
|   scoped_ptr<CefRenderProcessObserver> observer_; |   scoped_ptr<CefRenderProcessObserver> observer_; | ||||||
|   scoped_ptr<web_cache::WebCacheRenderProcessObserver> web_cache_observer_; |   scoped_ptr<web_cache::WebCacheRenderProcessObserver> web_cache_observer_; | ||||||
|   | |||||||
							
								
								
									
										284
									
								
								libcef/renderer/plugins/cef_plugin_placeholder.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										284
									
								
								libcef/renderer/plugins/cef_plugin_placeholder.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,284 @@ | |||||||
|  | // Copyright 2013 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 "libcef/renderer/plugins/cef_plugin_placeholder.h" | ||||||
|  |  | ||||||
|  | #include "libcef/common/cef_messages.h" | ||||||
|  | #include "libcef/renderer/content_renderer_client.h" | ||||||
|  | #include "libcef/renderer/plugins/plugin_preroller.h" | ||||||
|  |  | ||||||
|  | #include "base/strings/string_number_conversions.h" | ||||||
|  | #include "base/strings/utf_string_conversions.h" | ||||||
|  | #include "base/values.h" | ||||||
|  | #include "chrome/grit/generated_resources.h" | ||||||
|  | #include "chrome/renderer/custom_menu_commands.h" | ||||||
|  | #include "components/content_settings/content/common/content_settings_messages.h" | ||||||
|  | #include "content/public/common/context_menu_params.h" | ||||||
|  | #include "content/public/renderer/render_frame.h" | ||||||
|  | #include "content/public/renderer/render_thread.h" | ||||||
|  | #include "gin/object_template_builder.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebDocument.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebInputEvent.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebLocalFrame.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebScriptSource.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebView.h" | ||||||
|  | #include "ui/base/l10n/l10n_util.h" | ||||||
|  | #include "ui/base/resource/resource_bundle.h" | ||||||
|  | #include "ui/base/webui/jstemplate_builder.h" | ||||||
|  | #include "ui/gfx/geometry/size.h" | ||||||
|  | #include "url/url_util.h" | ||||||
|  |  | ||||||
|  | using base::UserMetricsAction; | ||||||
|  | using content::RenderThread; | ||||||
|  | using content::RenderView; | ||||||
|  |  | ||||||
|  | namespace { | ||||||
|  | const CefPluginPlaceholder* g_last_active_menu = NULL; | ||||||
|  | }  // namespace | ||||||
|  |  | ||||||
|  | gin::WrapperInfo CefPluginPlaceholder::kWrapperInfo = { | ||||||
|  |     gin::kEmbedderNativeGin}; | ||||||
|  |  | ||||||
|  | CefPluginPlaceholder::CefPluginPlaceholder( | ||||||
|  |     content::RenderFrame* render_frame, | ||||||
|  |     blink::WebLocalFrame* frame, | ||||||
|  |     const blink::WebPluginParams& params, | ||||||
|  |     const std::string& html_data, | ||||||
|  |     const base::string16& title) | ||||||
|  |     : plugins::LoadablePluginPlaceholder(render_frame, | ||||||
|  |                                          frame, | ||||||
|  |                                          params, | ||||||
|  |                                          html_data), | ||||||
|  |       status_(CefViewHostMsg_GetPluginInfo_Status::kAllowed), | ||||||
|  |       title_(title), | ||||||
|  |       has_host_(false), | ||||||
|  |       context_menu_request_id_(0) { | ||||||
|  |   RenderThread::Get()->AddObserver(this); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefPluginPlaceholder::~CefPluginPlaceholder() { | ||||||
|  |   RenderThread::Get()->RemoveObserver(this); | ||||||
|  |   if (context_menu_request_id_ && render_frame()) | ||||||
|  |     render_frame()->CancelContextMenu(context_menu_request_id_); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // static | ||||||
|  | CefPluginPlaceholder* CefPluginPlaceholder::CreateLoadableMissingPlugin( | ||||||
|  |     content::RenderFrame* render_frame, | ||||||
|  |     blink::WebLocalFrame* frame, | ||||||
|  |     const blink::WebPluginParams& params) { | ||||||
|  |   const base::StringPiece template_html( | ||||||
|  |       ResourceBundle::GetSharedInstance().GetRawDataResource( | ||||||
|  |           IDR_BLOCKED_PLUGIN_HTML)); | ||||||
|  |  | ||||||
|  |   base::DictionaryValue values; | ||||||
|  |   values.SetString("message", | ||||||
|  |                    l10n_util::GetStringUTF8(IDS_PLUGIN_NOT_SUPPORTED)); | ||||||
|  |  | ||||||
|  |   std::string html_data = webui::GetI18nTemplateHtml(template_html, &values); | ||||||
|  |  | ||||||
|  |   // Will destroy itself when its WebViewPlugin is going away. | ||||||
|  |   return new CefPluginPlaceholder(render_frame, frame, params, html_data, | ||||||
|  |                                   params.mimeType); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // static | ||||||
|  | CefPluginPlaceholder* CefPluginPlaceholder::CreateBlockedPlugin( | ||||||
|  |     content::RenderFrame* render_frame, | ||||||
|  |     blink::WebLocalFrame* frame, | ||||||
|  |     const blink::WebPluginParams& params, | ||||||
|  |     const content::WebPluginInfo& info, | ||||||
|  |     const std::string& identifier, | ||||||
|  |     const base::string16& name, | ||||||
|  |     int template_id, | ||||||
|  |     const base::string16& message, | ||||||
|  |     const PlaceholderPosterInfo& poster_info) { | ||||||
|  |   base::DictionaryValue values; | ||||||
|  |   values.SetString("message", message); | ||||||
|  |   values.SetString("name", name); | ||||||
|  |   values.SetString("hide", l10n_util::GetStringUTF8(IDS_PLUGIN_HIDE)); | ||||||
|  |   values.SetString("pluginType", | ||||||
|  |                    frame->view()->mainFrame()->document().isPluginDocument() | ||||||
|  |                        ? "document" | ||||||
|  |                        : "embedded"); | ||||||
|  |  | ||||||
|  |   if (!poster_info.poster_attribute.empty()) { | ||||||
|  |     values.SetString("poster", poster_info.poster_attribute); | ||||||
|  |     values.SetString("baseurl", poster_info.base_url.spec()); | ||||||
|  |  | ||||||
|  |     if (!poster_info.custom_poster_size.IsEmpty()) { | ||||||
|  |       float zoom_factor = | ||||||
|  |           blink::WebView::zoomLevelToZoomFactor(frame->view()->zoomLevel()); | ||||||
|  |       int width = roundf(poster_info.custom_poster_size.width() / zoom_factor); | ||||||
|  |       int height = | ||||||
|  |           roundf(poster_info.custom_poster_size.height() / zoom_factor); | ||||||
|  |       values.SetString("visibleWidth", base::IntToString(width) + "px"); | ||||||
|  |       values.SetString("visibleHeight", base::IntToString(height) + "px"); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   const base::StringPiece template_html( | ||||||
|  |       ResourceBundle::GetSharedInstance().GetRawDataResource(template_id)); | ||||||
|  |  | ||||||
|  |   DCHECK(!template_html.empty()) << "unable to load template. ID: " | ||||||
|  |                                  << template_id; | ||||||
|  |   std::string html_data = webui::GetI18nTemplateHtml(template_html, &values); | ||||||
|  |  | ||||||
|  |   // |blocked_plugin| will destroy itself when its WebViewPlugin is going away. | ||||||
|  |   CefPluginPlaceholder* blocked_plugin = new CefPluginPlaceholder( | ||||||
|  |       render_frame, frame, params, html_data, name); | ||||||
|  |  | ||||||
|  |   if (!poster_info.poster_attribute.empty()) | ||||||
|  |     blocked_plugin->BlockForPowerSaverPoster(); | ||||||
|  |   blocked_plugin->SetPluginInfo(info); | ||||||
|  |   blocked_plugin->SetIdentifier(identifier); | ||||||
|  |   return blocked_plugin; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::SetStatus( | ||||||
|  |     CefViewHostMsg_GetPluginInfo_Status status) { | ||||||
|  |   status_ = status; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefPluginPlaceholder::OnMessageReceived(const IPC::Message& message) { | ||||||
|  |   // We don't swallow these messages because multiple blocked plugins and other | ||||||
|  |   // objects have an interest in them. | ||||||
|  |   IPC_BEGIN_MESSAGE_MAP(CefPluginPlaceholder, message) | ||||||
|  |     IPC_MESSAGE_HANDLER(CefViewMsg_LoadBlockedPlugins, OnLoadBlockedPlugins) | ||||||
|  |   IPC_END_MESSAGE_MAP() | ||||||
|  |  | ||||||
|  |   return false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::OpenAboutPluginsCallback() { | ||||||
|  |   // CEF does not use IDR_DISABLED_PLUGIN_HTML which would originate this | ||||||
|  |   // callback for the chrome://plugins link. | ||||||
|  |   NOTREACHED(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::PluginListChanged() { | ||||||
|  |   if (!GetFrame() || !plugin()) | ||||||
|  |     return; | ||||||
|  |   blink::WebDocument document = GetFrame()->top()->document(); | ||||||
|  |   if (document.isNull()) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   CefViewHostMsg_GetPluginInfo_Output output; | ||||||
|  |   std::string mime_type(GetPluginParams().mimeType.utf8()); | ||||||
|  |   render_frame()->Send( | ||||||
|  |       new CefViewHostMsg_GetPluginInfo(routing_id(), | ||||||
|  |                                           GURL(GetPluginParams().url), | ||||||
|  |                                           document.url(), | ||||||
|  |                                           mime_type, | ||||||
|  |                                           &output)); | ||||||
|  |   if (output.status == status_) | ||||||
|  |     return; | ||||||
|  |   blink::WebPlugin* new_plugin = CefContentRendererClient::CreatePlugin( | ||||||
|  |       render_frame(), GetFrame(), GetPluginParams(), output); | ||||||
|  |   ReplacePlugin(new_plugin); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::OnMenuAction(int request_id, unsigned action) { | ||||||
|  |   DCHECK_EQ(context_menu_request_id_, request_id); | ||||||
|  |   if (g_last_active_menu != this) | ||||||
|  |     return; | ||||||
|  |   switch (action) { | ||||||
|  |     case chrome::MENU_COMMAND_PLUGIN_RUN: { | ||||||
|  |       RenderThread::Get()->RecordAction(UserMetricsAction("Plugin_Load_Menu")); | ||||||
|  |       MarkPluginEssential( | ||||||
|  |           content::PluginInstanceThrottler::UNTHROTTLE_METHOD_BY_CLICK); | ||||||
|  |       LoadPlugin(); | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |     case chrome::MENU_COMMAND_PLUGIN_HIDE: { | ||||||
|  |       RenderThread::Get()->RecordAction(UserMetricsAction("Plugin_Hide_Menu")); | ||||||
|  |       HidePlugin(); | ||||||
|  |       break; | ||||||
|  |     } | ||||||
|  |     default: | ||||||
|  |       NOTREACHED(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::OnMenuClosed(int request_id) { | ||||||
|  |   DCHECK_EQ(context_menu_request_id_, request_id); | ||||||
|  |   context_menu_request_id_ = 0; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | v8::Local<v8::Value> CefPluginPlaceholder::GetV8Handle( | ||||||
|  |     v8::Isolate* isolate) { | ||||||
|  |   return gin::CreateHandle(isolate, this).ToV8(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPlaceholder::ShowContextMenu( | ||||||
|  |     const blink::WebMouseEvent& event) { | ||||||
|  |   if (context_menu_request_id_) | ||||||
|  |     return;  // Don't allow nested context menu requests. | ||||||
|  |  | ||||||
|  |   content::ContextMenuParams params; | ||||||
|  |  | ||||||
|  |   if (!title_.empty()) { | ||||||
|  |     content::MenuItem name_item; | ||||||
|  |     name_item.label = title_; | ||||||
|  |     params.custom_items.push_back(name_item); | ||||||
|  |  | ||||||
|  |     content::MenuItem separator_item; | ||||||
|  |     separator_item.type = content::MenuItem::SEPARATOR; | ||||||
|  |     params.custom_items.push_back(separator_item); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if (!GetPluginInfo().path.value().empty()) { | ||||||
|  |     content::MenuItem run_item; | ||||||
|  |     run_item.action = chrome::MENU_COMMAND_PLUGIN_RUN; | ||||||
|  |     // Disable this menu item if the plugin is blocked by policy. | ||||||
|  |     run_item.enabled = LoadingAllowed(); | ||||||
|  |     run_item.label = l10n_util::GetStringUTF16(IDS_CONTENT_CONTEXT_PLUGIN_RUN); | ||||||
|  |     params.custom_items.push_back(run_item); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   content::MenuItem hide_item; | ||||||
|  |   hide_item.action = chrome::MENU_COMMAND_PLUGIN_HIDE; | ||||||
|  |   hide_item.enabled = | ||||||
|  |       !GetFrame()->view()->mainFrame()->document().isPluginDocument(); | ||||||
|  |   hide_item.label = l10n_util::GetStringUTF16(IDS_CONTENT_CONTEXT_PLUGIN_HIDE); | ||||||
|  |   params.custom_items.push_back(hide_item); | ||||||
|  |  | ||||||
|  |   params.x = event.windowX; | ||||||
|  |   params.y = event.windowY; | ||||||
|  |  | ||||||
|  |   context_menu_request_id_ = render_frame()->ShowContextMenu(this, params); | ||||||
|  |   g_last_active_menu = this; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | blink::WebPlugin* CefPluginPlaceholder::CreatePlugin() { | ||||||
|  |   scoped_ptr<content::PluginInstanceThrottler> throttler; | ||||||
|  |   // If the plugin has already been marked essential in its placeholder form, | ||||||
|  |   // we shouldn't create a new throttler and start the process all over again. | ||||||
|  |   if (power_saver_enabled()) { | ||||||
|  |     throttler = content::PluginInstanceThrottler::Create(); | ||||||
|  |     // PluginPreroller manages its own lifetime. | ||||||
|  |     new CefPluginPreroller( | ||||||
|  |         render_frame(), GetFrame(), GetPluginParams(), | ||||||
|  |         GetPluginInfo(), GetIdentifier(), title_, | ||||||
|  |         l10n_util::GetStringFUTF16(IDS_PLUGIN_BLOCKED, title_), | ||||||
|  |         throttler.get()); | ||||||
|  |   } | ||||||
|  |   return render_frame()->CreatePlugin(GetFrame(), GetPluginInfo(), | ||||||
|  |                                       GetPluginParams(), throttler.Pass()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | gin::ObjectTemplateBuilder CefPluginPlaceholder::GetObjectTemplateBuilder( | ||||||
|  |     v8::Isolate* isolate) { | ||||||
|  |   return gin::Wrappable<CefPluginPlaceholder>::GetObjectTemplateBuilder( | ||||||
|  |              isolate) | ||||||
|  |       .SetMethod<void (CefPluginPlaceholder::*)()>( | ||||||
|  |            "hide", &CefPluginPlaceholder::HideCallback) | ||||||
|  |       .SetMethod<void (CefPluginPlaceholder::*)()>( | ||||||
|  |            "load", &CefPluginPlaceholder::LoadCallback) | ||||||
|  |       .SetMethod<void (CefPluginPlaceholder::*)()>( | ||||||
|  |            "didFinishLoading", | ||||||
|  |            &CefPluginPlaceholder::DidFinishLoadingCallback) | ||||||
|  |       .SetMethod("openAboutPlugins", | ||||||
|  |                  &CefPluginPlaceholder::OpenAboutPluginsCallback); | ||||||
|  | } | ||||||
							
								
								
									
										102
									
								
								libcef/renderer/plugins/cef_plugin_placeholder.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										102
									
								
								libcef/renderer/plugins/cef_plugin_placeholder.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,102 @@ | |||||||
|  | // Copyright 2013 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 CEF_LIBCEF_RENDERER_PLUGINS_CEF_PLUGIN_PLACEHOLDER_H_ | ||||||
|  | #define CEF_LIBCEF_RENDERER_PLUGINS_CEF_PLUGIN_PLACEHOLDER_H_ | ||||||
|  |  | ||||||
|  | #include "components/plugins/renderer/loadable_plugin_placeholder.h" | ||||||
|  | #include "content/public/renderer/context_menu_client.h" | ||||||
|  | #include "content/public/renderer/render_process_observer.h" | ||||||
|  |  | ||||||
|  | namespace gfx { | ||||||
|  | class Size; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum class CefViewHostMsg_GetPluginInfo_Status; | ||||||
|  |  | ||||||
|  | // This contains information specifying the poster image of plugin placeholders. | ||||||
|  | // The default constructor specifies no poster image. | ||||||
|  | struct PlaceholderPosterInfo { | ||||||
|  |   // The poster image specified in image 'srcset' attribute format. | ||||||
|  |   std::string poster_attribute; | ||||||
|  |  | ||||||
|  |   // Used to resolve relative paths in |poster_attribute|. | ||||||
|  |   GURL base_url; | ||||||
|  |  | ||||||
|  |   // Specify this to provide partially obscured plugins a centered poster image. | ||||||
|  |   gfx::Size custom_poster_size; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | class CefPluginPlaceholder final | ||||||
|  |     : public plugins::LoadablePluginPlaceholder, | ||||||
|  |       public content::RenderProcessObserver, | ||||||
|  |       public content::ContextMenuClient, | ||||||
|  |       public gin::Wrappable<CefPluginPlaceholder> { | ||||||
|  |  public: | ||||||
|  |   static gin::WrapperInfo kWrapperInfo; | ||||||
|  |  | ||||||
|  |   static CefPluginPlaceholder* CreateBlockedPlugin( | ||||||
|  |       content::RenderFrame* render_frame, | ||||||
|  |       blink::WebLocalFrame* frame, | ||||||
|  |       const blink::WebPluginParams& params, | ||||||
|  |       const content::WebPluginInfo& info, | ||||||
|  |       const std::string& identifier, | ||||||
|  |       const base::string16& name, | ||||||
|  |       int resource_id, | ||||||
|  |       const base::string16& message, | ||||||
|  |       const PlaceholderPosterInfo& poster_info); | ||||||
|  |  | ||||||
|  |   // Creates a new WebViewPlugin with a MissingPlugin as a delegate. | ||||||
|  |   static CefPluginPlaceholder* CreateLoadableMissingPlugin( | ||||||
|  |       content::RenderFrame* render_frame, | ||||||
|  |       blink::WebLocalFrame* frame, | ||||||
|  |       const blink::WebPluginParams& params); | ||||||
|  |  | ||||||
|  |   void SetStatus(CefViewHostMsg_GetPluginInfo_Status status); | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   CefPluginPlaceholder(content::RenderFrame* render_frame, | ||||||
|  |                        blink::WebLocalFrame* frame, | ||||||
|  |                        const blink::WebPluginParams& params, | ||||||
|  |                        const std::string& html_data, | ||||||
|  |                        const base::string16& title); | ||||||
|  |   ~CefPluginPlaceholder() override; | ||||||
|  |  | ||||||
|  |   // content::LoadablePluginPlaceholder method | ||||||
|  |   blink::WebPlugin* CreatePlugin() override; | ||||||
|  |  | ||||||
|  |   // gin::Wrappable (via PluginPlaceholder) method | ||||||
|  |   gin::ObjectTemplateBuilder GetObjectTemplateBuilder( | ||||||
|  |       v8::Isolate* isolate) final; | ||||||
|  |  | ||||||
|  |   // content::RenderViewObserver (via PluginPlaceholder) override: | ||||||
|  |   bool OnMessageReceived(const IPC::Message& message) override; | ||||||
|  |  | ||||||
|  |   // WebViewPlugin::Delegate (via PluginPlaceholder) methods: | ||||||
|  |   v8::Local<v8::Value> GetV8Handle(v8::Isolate* isolate) override; | ||||||
|  |   void ShowContextMenu(const blink::WebMouseEvent&) override; | ||||||
|  |  | ||||||
|  |   // content::RenderProcessObserver methods: | ||||||
|  |   void PluginListChanged() override; | ||||||
|  |  | ||||||
|  |   // content::ContextMenuClient methods: | ||||||
|  |   void OnMenuAction(int request_id, unsigned action) override; | ||||||
|  |   void OnMenuClosed(int request_id) override; | ||||||
|  |  | ||||||
|  |   // Javascript callbacks: | ||||||
|  |   // Open chrome://plugins in a new tab. | ||||||
|  |   void OpenAboutPluginsCallback(); | ||||||
|  |  | ||||||
|  |   CefViewHostMsg_GetPluginInfo_Status status_; | ||||||
|  |  | ||||||
|  |   base::string16 title_; | ||||||
|  |  | ||||||
|  |   bool has_host_; | ||||||
|  |   int context_menu_request_id_;  // Nonzero when request pending. | ||||||
|  |   base::string16 plugin_name_; | ||||||
|  |  | ||||||
|  |   DISALLOW_COPY_AND_ASSIGN(CefPluginPlaceholder); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // CEF_LIBCEF_RENDERER_PLUGINS_CEF_PLUGIN_PLACEHOLDER_H_ | ||||||
							
								
								
									
										91
									
								
								libcef/renderer/plugins/plugin_preroller.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								libcef/renderer/plugins/plugin_preroller.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | // Copyright 2015 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 "libcef/renderer/plugins/plugin_preroller.h" | ||||||
|  |  | ||||||
|  | #include "libcef/renderer/plugins/cef_plugin_placeholder.h" | ||||||
|  |  | ||||||
|  | #include "base/base64.h" | ||||||
|  | #include "chrome/grit/generated_resources.h" | ||||||
|  | #include "third_party/WebKit/public/platform/WebRect.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebElement.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebPlugin.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebPluginContainer.h" | ||||||
|  | #include "ui/gfx/codec/png_codec.h" | ||||||
|  |  | ||||||
|  | CefPluginPreroller::CefPluginPreroller( | ||||||
|  |     content::RenderFrame* render_frame, | ||||||
|  |     blink::WebLocalFrame* frame, | ||||||
|  |     const blink::WebPluginParams& params, | ||||||
|  |     const content::WebPluginInfo& info, | ||||||
|  |     const std::string& identifier, | ||||||
|  |     const base::string16& name, | ||||||
|  |     const base::string16& message, | ||||||
|  |     content::PluginInstanceThrottler* throttler) | ||||||
|  |     : RenderFrameObserver(render_frame), | ||||||
|  |       frame_(frame), | ||||||
|  |       params_(params), | ||||||
|  |       info_(info), | ||||||
|  |       identifier_(identifier), | ||||||
|  |       name_(name), | ||||||
|  |       message_(message), | ||||||
|  |       throttler_(throttler) { | ||||||
|  |   DCHECK(throttler); | ||||||
|  |   throttler_->AddObserver(this); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CefPluginPreroller::~CefPluginPreroller() { | ||||||
|  |   if (throttler_) | ||||||
|  |     throttler_->RemoveObserver(this); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPreroller::OnKeyframeExtracted(const SkBitmap* bitmap) { | ||||||
|  |   std::vector<unsigned char> png_data; | ||||||
|  |   if (!gfx::PNGCodec::EncodeBGRASkBitmap(*bitmap, false, &png_data)) { | ||||||
|  |     DLOG(ERROR) << "Provided keyframe could not be encoded as PNG."; | ||||||
|  |     return; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   base::StringPiece png_as_string(reinterpret_cast<char*>(&png_data[0]), | ||||||
|  |                                   png_data.size()); | ||||||
|  |  | ||||||
|  |   std::string data_url_header = "data:image/png;base64,"; | ||||||
|  |   std::string data_url_body; | ||||||
|  |   base::Base64Encode(png_as_string, &data_url_body); | ||||||
|  |   keyframe_data_url_ = GURL(data_url_header + data_url_body); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPreroller::OnThrottleStateChange() { | ||||||
|  |   if (!throttler_->IsThrottled()) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   PlaceholderPosterInfo poster_info; | ||||||
|  |   poster_info.poster_attribute = keyframe_data_url_.spec(); | ||||||
|  |   poster_info.custom_poster_size = throttler_->GetSize(); | ||||||
|  |  | ||||||
|  |   CefPluginPlaceholder* placeholder = | ||||||
|  |       CefPluginPlaceholder::CreateBlockedPlugin( | ||||||
|  |           render_frame(), frame_, params_, info_, identifier_, name_, | ||||||
|  |           IDR_PLUGIN_POSTER_HTML, message_, poster_info); | ||||||
|  |   placeholder->SetPremadePlugin(throttler_); | ||||||
|  |   placeholder->set_power_saver_enabled(true); | ||||||
|  |   placeholder->AllowLoading(); | ||||||
|  |  | ||||||
|  |   blink::WebPluginContainer* container = | ||||||
|  |       throttler_->GetWebPlugin()->container(); | ||||||
|  |   container->setPlugin(placeholder->plugin()); | ||||||
|  |  | ||||||
|  |   bool success = placeholder->plugin()->initialize(container); | ||||||
|  |   DCHECK(success); | ||||||
|  |  | ||||||
|  |   container->invalidate(); | ||||||
|  |   container->reportGeometry(); | ||||||
|  |  | ||||||
|  |   delete this; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefPluginPreroller::OnThrottlerDestroyed() { | ||||||
|  |   throttler_ = nullptr; | ||||||
|  |   delete this; | ||||||
|  | } | ||||||
							
								
								
									
										61
									
								
								libcef/renderer/plugins/plugin_preroller.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								libcef/renderer/plugins/plugin_preroller.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | // Copyright 2015 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 CEF_LIBCEF_RENDERER_PLUGINS_PLUGIN_PREROLLER_H_ | ||||||
|  | #define CEF_LIBCEF_RENDERER_PLUGINS_PLUGIN_PREROLLER_H_ | ||||||
|  |  | ||||||
|  | #include "base/macros.h" | ||||||
|  | #include "content/public/common/webplugininfo.h" | ||||||
|  | #include "content/public/renderer/plugin_instance_throttler.h" | ||||||
|  | #include "content/public/renderer/render_frame_observer.h" | ||||||
|  | #include "third_party/WebKit/public/web/WebPluginParams.h" | ||||||
|  | #include "url/gurl.h" | ||||||
|  |  | ||||||
|  | namespace blink { | ||||||
|  | class WebLocalFrame; | ||||||
|  | class WebPlugin; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | class SkBitmap; | ||||||
|  |  | ||||||
|  | // This class manages a plugin briefly for the purposes of keyframe extraction. | ||||||
|  | // Once a keyframe has been extracted, this class will replace the plugin with | ||||||
|  | // a ChromePluginPlaceholder. The actual plugin will continue to live in a | ||||||
|  | // throttled state. This class manages its own lifetime. | ||||||
|  | class CefPluginPreroller : public content::PluginInstanceThrottler::Observer, | ||||||
|  |                            public content::RenderFrameObserver { | ||||||
|  |  public: | ||||||
|  |   // Does not take ownership of either |plugin| or |throttler|. | ||||||
|  |   CefPluginPreroller(content::RenderFrame* render_frame, | ||||||
|  |                      blink::WebLocalFrame* frame, | ||||||
|  |                      const blink::WebPluginParams& params, | ||||||
|  |                      const content::WebPluginInfo& info, | ||||||
|  |                      const std::string& identifier, | ||||||
|  |                      const base::string16& name, | ||||||
|  |                      const base::string16& message, | ||||||
|  |                      content::PluginInstanceThrottler* throttler); | ||||||
|  |  | ||||||
|  |   ~CefPluginPreroller() override; | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   // content::PluginInstanceThrottler::Observer methods: | ||||||
|  |   void OnKeyframeExtracted(const SkBitmap* bitmap) override; | ||||||
|  |   void OnThrottleStateChange() override; | ||||||
|  |   void OnThrottlerDestroyed() override; | ||||||
|  |  | ||||||
|  |   blink::WebLocalFrame* frame_; | ||||||
|  |   blink::WebPluginParams params_; | ||||||
|  |   content::WebPluginInfo info_; | ||||||
|  |   std::string identifier_; | ||||||
|  |   base::string16 name_; | ||||||
|  |   base::string16 message_; | ||||||
|  |  | ||||||
|  |   content::PluginInstanceThrottler* throttler_; | ||||||
|  |  | ||||||
|  |   GURL keyframe_data_url_; | ||||||
|  |  | ||||||
|  |   DISALLOW_COPY_AND_ASSIGN(CefPluginPreroller); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // CEF_LIBCEF_RENDERER_PLUGINS_PLUGIN_PREROLLER_H_ | ||||||
| @@ -20,6 +20,22 @@ | |||||||
|  |  | ||||||
|       <!-- Manifest files for built-in extensions. --> |       <!-- Manifest files for built-in extensions. --> | ||||||
|       <include name="IDR_PDF_MANIFEST" file="..\..\..\chrome\browser\resources\pdf\manifest.json" type="BINDATA" /> |       <include name="IDR_PDF_MANIFEST" file="..\..\..\chrome\browser\resources\pdf\manifest.json" type="BINDATA" /> | ||||||
|  |  | ||||||
|  |       <!-- Plugin placeholders. --> | ||||||
|  |       <include name="IDR_BLOCKED_PLUGIN_HTML" file="..\..\..\chrome\renderer\resources\plugins\blocked_plugin.html" flattenhtml="true" type="BINDATA" /> | ||||||
|  |       <include name="IDR_PLUGIN_POSTER_HTML" file="..\..\..\chrome\renderer\resources\plugins\plugin_poster.html" flattenhtml="true" type="BINDATA" /> | ||||||
|  |  | ||||||
|  |       <!-- Plugin finder. --> | ||||||
|  |       <if expr="is_win"> | ||||||
|  |         <include name="IDR_PLUGIN_DB_JSON" file="..\..\..\chrome\browser\resources\plugin_metadata\plugins_win.json" type="BINDATA" /> | ||||||
|  |       </if> | ||||||
|  |       <if expr="is_macosx"> | ||||||
|  |         <include name="IDR_PLUGIN_DB_JSON" file="..\..\..\chrome\browser\resources\plugin_metadata\plugins_mac.json" type="BINDATA" /> | ||||||
|  |       </if> | ||||||
|  |       <if expr="desktop_linux or (is_android and enable_plugins)"> | ||||||
|  |         <include name="IDR_PLUGIN_DB_JSON" file="..\..\..\chrome\browser\resources\plugin_metadata\plugins_linux.json" type="BINDATA" /> | ||||||
|  |       </if> | ||||||
|  |        | ||||||
|     </includes> |     </includes> | ||||||
|   </release> |   </release> | ||||||
| </grit> | </grit> | ||||||
|   | |||||||
| @@ -356,6 +356,52 @@ need to be translated for each locale.--> | |||||||
|           DirectWrite Font Cache Builder |           DirectWrite Font Cache Builder | ||||||
|         </message> |         </message> | ||||||
|       </if> |       </if> | ||||||
|  |        | ||||||
|  |       <!-- Plugin placeholders. --> | ||||||
|  |       <message name="IDS_PLUGIN_HIDE" desc="The tooltip for hiding a blocked plugin, displayed in the click to play UI."> | ||||||
|  |         Hide this plugin | ||||||
|  |       </message> | ||||||
|  |       <message name="IDS_PLUGIN_NOT_SUPPORTED" desc="The placeholder text for an unsupported plugin."> | ||||||
|  |         This plugin is not supported. | ||||||
|  |       </message> | ||||||
|  |       <if expr="is_macosx"> | ||||||
|  |         <message name="IDS_PLUGIN_BLOCKED" desc="The placeholder text for a blocked plugin."> | ||||||
|  |           Control-click to play <ph name="PLUGIN_NAME">$1<ex>Flash</ex></ph>. | ||||||
|  |         </message> | ||||||
|  |       </if> | ||||||
|  |       <if expr="not is_macosx"> | ||||||
|  |         <message name="IDS_PLUGIN_BLOCKED" desc="The placeholder text for a blocked plugin."> | ||||||
|  |           Right-click to play <ph name="PLUGIN_NAME">$1<ex>Flash</ex></ph>. | ||||||
|  |         </message> | ||||||
|  |       </if> | ||||||
|  |       <message name="IDS_PLUGIN_NOT_SUPPORTED_METRO" desc="The placeholder text for a plugin that can't run in Windows Metro mode."> | ||||||
|  |         This plugin only works on the desktop. | ||||||
|  |       </message> | ||||||
|  |       <message name="IDS_PLUGIN_OUTDATED" desc="The placeholder text for an outdated plugin."> | ||||||
|  |         <ph name="PLUGIN_NAME">$1<ex>Flash</ex></ph> is out of date. | ||||||
|  |       </message> | ||||||
|  |       <message name="IDS_PLUGIN_NOT_AUTHORIZED" desc="The placeholder text for a plugin that requires user permission to run."> | ||||||
|  |         <ph name="PLUGIN_NAME">$1<ex>Java</ex></ph> needs your permission to run. | ||||||
|  |       </message> | ||||||
|  |       <message name="IDS_PLUGIN_BLOCKED_BY_POLICY" desc="The placeholder text for a plugin blocked by enterprise policy."> | ||||||
|  |         <ph name="PLUGIN_NAME">$1<ex>Flash</ex></ph> is not allowed. | ||||||
|  |       </message> | ||||||
|  |       <if expr="not use_titlecase"> | ||||||
|  |         <message name="IDS_CONTENT_CONTEXT_PLUGIN_RUN" desc="The name of the Run command on the blocked plugin context menu"> | ||||||
|  |           Run this plugin | ||||||
|  |         </message> | ||||||
|  |         <message name="IDS_CONTENT_CONTEXT_PLUGIN_HIDE" desc="The name of the Hide command on the blocked plugin context menu"> | ||||||
|  |           Hide this plugin | ||||||
|  |         </message> | ||||||
|  |       </if> | ||||||
|  |       <if expr="use_titlecase"> | ||||||
|  |         <message name="IDS_CONTENT_CONTEXT_PLUGIN_RUN" desc="In Title Case: The name of the Run command on the blocked plugin context menu"> | ||||||
|  |           Run This Plugin | ||||||
|  |         </message> | ||||||
|  |         <message name="IDS_CONTENT_CONTEXT_PLUGIN_HIDE" desc="In Title Case: The name of the Hide command on the blocked plugin context menu"> | ||||||
|  |           Hide This Plugin | ||||||
|  |         </message> | ||||||
|  |       </if> | ||||||
|     </messages> |     </messages> | ||||||
|   </release> |   </release> | ||||||
| </grit> | </grit> | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ | |||||||
| #include "libcef_dll/ctocpp/context_menu_params_ctocpp.h" | #include "libcef_dll/ctocpp/context_menu_params_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/frame_ctocpp.h" | #include "libcef_dll/ctocpp/frame_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/menu_model_ctocpp.h" | #include "libcef_dll/ctocpp/menu_model_ctocpp.h" | ||||||
|  | #include "libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
| @@ -55,6 +56,49 @@ void CEF_CALLBACK context_menu_handler_on_before_context_menu( | |||||||
|       CefMenuModelCToCpp::Wrap(model)); |       CefMenuModelCToCpp::Wrap(model)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK context_menu_handler_run_context_menu( | ||||||
|  |     struct _cef_context_menu_handler_t* self, cef_browser_t* browser, | ||||||
|  |     struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, | ||||||
|  |     struct _cef_menu_model_t* model, | ||||||
|  |     cef_run_context_menu_callback_t* callback) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: browser; type: refptr_diff | ||||||
|  |   DCHECK(browser); | ||||||
|  |   if (!browser) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: frame; type: refptr_diff | ||||||
|  |   DCHECK(frame); | ||||||
|  |   if (!frame) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: params; type: refptr_diff | ||||||
|  |   DCHECK(params); | ||||||
|  |   if (!params) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: model; type: refptr_diff | ||||||
|  |   DCHECK(model); | ||||||
|  |   if (!model) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: callback; type: refptr_diff | ||||||
|  |   DCHECK(callback); | ||||||
|  |   if (!callback) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefContextMenuHandlerCppToC::Get(self)->RunContextMenu( | ||||||
|  |       CefBrowserCToCpp::Wrap(browser), | ||||||
|  |       CefFrameCToCpp::Wrap(frame), | ||||||
|  |       CefContextMenuParamsCToCpp::Wrap(params), | ||||||
|  |       CefMenuModelCToCpp::Wrap(model), | ||||||
|  |       CefRunContextMenuCallbackCToCpp::Wrap(callback)); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
| int CEF_CALLBACK context_menu_handler_on_context_menu_command( | int CEF_CALLBACK context_menu_handler_on_context_menu_command( | ||||||
|     struct _cef_context_menu_handler_t* self, cef_browser_t* browser, |     struct _cef_context_menu_handler_t* self, cef_browser_t* browser, | ||||||
|     struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, |     struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, | ||||||
| @@ -120,6 +164,7 @@ void CEF_CALLBACK context_menu_handler_on_context_menu_dismissed( | |||||||
| CefContextMenuHandlerCppToC::CefContextMenuHandlerCppToC() { | CefContextMenuHandlerCppToC::CefContextMenuHandlerCppToC() { | ||||||
|   GetStruct()->on_before_context_menu = |   GetStruct()->on_before_context_menu = | ||||||
|       context_menu_handler_on_before_context_menu; |       context_menu_handler_on_before_context_menu; | ||||||
|  |   GetStruct()->run_context_menu = context_menu_handler_run_context_menu; | ||||||
|   GetStruct()->on_context_menu_command = |   GetStruct()->on_context_menu_command = | ||||||
|       context_menu_handler_on_context_menu_command; |       context_menu_handler_on_context_menu_command; | ||||||
|   GetStruct()->on_context_menu_dismissed = |   GetStruct()->on_context_menu_dismissed = | ||||||
|   | |||||||
| @@ -308,6 +308,36 @@ cef_context_menu_edit_state_flags_t CEF_CALLBACK context_menu_params_get_edit_st | |||||||
|   return _retval; |   return _retval; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK context_menu_params_is_custom_menu( | ||||||
|  |     struct _cef_context_menu_params_t* self) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefContextMenuParamsCppToC::Get(self)->IsCustomMenu(); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK context_menu_params_is_pepper_menu( | ||||||
|  |     struct _cef_context_menu_params_t* self) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefContextMenuParamsCppToC::Get(self)->IsPepperMenu(); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -336,6 +366,8 @@ CefContextMenuParamsCppToC::CefContextMenuParamsCppToC() { | |||||||
|   GetStruct()->is_spell_check_enabled = |   GetStruct()->is_spell_check_enabled = | ||||||
|       context_menu_params_is_spell_check_enabled; |       context_menu_params_is_spell_check_enabled; | ||||||
|   GetStruct()->get_edit_state_flags = context_menu_params_get_edit_state_flags; |   GetStruct()->get_edit_state_flags = context_menu_params_get_edit_state_flags; | ||||||
|  |   GetStruct()->is_custom_menu = context_menu_params_is_custom_menu; | ||||||
|  |   GetStruct()->is_pepper_menu = context_menu_params_is_pepper_menu; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> CefRefPtr<CefContextMenuParams> CefCppToC<CefContextMenuParamsCppToC, | template<> CefRefPtr<CefContextMenuParams> CefCppToC<CefContextMenuParamsCppToC, | ||||||
|   | |||||||
| @@ -12,6 +12,7 @@ | |||||||
|  |  | ||||||
| #include "libcef_dll/cpptoc/request_context_handler_cpptoc.h" | #include "libcef_dll/cpptoc/request_context_handler_cpptoc.h" | ||||||
| #include "libcef_dll/ctocpp/cookie_manager_ctocpp.h" | #include "libcef_dll/ctocpp/cookie_manager_ctocpp.h" | ||||||
|  | #include "libcef_dll/ctocpp/web_plugin_info_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
| @@ -34,6 +35,46 @@ cef_cookie_manager_t* CEF_CALLBACK request_context_handler_get_cookie_manager( | |||||||
|   return CefCookieManagerCToCpp::Unwrap(_retval); |   return CefCookieManagerCToCpp::Unwrap(_retval); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK request_context_handler_on_before_plugin_load( | ||||||
|  |     struct _cef_request_context_handler_t* self, const cef_string_t* mime_type, | ||||||
|  |     const cef_string_t* plugin_url, const cef_string_t* top_origin_url, | ||||||
|  |     struct _cef_web_plugin_info_t* plugin_info, | ||||||
|  |     cef_plugin_policy_t* plugin_policy) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: mime_type; type: string_byref_const | ||||||
|  |   DCHECK(mime_type); | ||||||
|  |   if (!mime_type) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: top_origin_url; type: string_byref_const | ||||||
|  |   DCHECK(top_origin_url); | ||||||
|  |   if (!top_origin_url) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: plugin_info; type: refptr_diff | ||||||
|  |   DCHECK(plugin_info); | ||||||
|  |   if (!plugin_info) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: plugin_policy; type: simple_byaddr | ||||||
|  |   DCHECK(plugin_policy); | ||||||
|  |   if (!plugin_policy) | ||||||
|  |     return 0; | ||||||
|  |   // Unverified params: plugin_url | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefRequestContextHandlerCppToC::Get(self)->OnBeforePluginLoad( | ||||||
|  |       CefString(mime_type), | ||||||
|  |       CefString(plugin_url), | ||||||
|  |       CefString(top_origin_url), | ||||||
|  |       CefWebPluginInfoCToCpp::Wrap(plugin_info), | ||||||
|  |       plugin_policy); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -41,6 +82,8 @@ cef_cookie_manager_t* CEF_CALLBACK request_context_handler_get_cookie_manager( | |||||||
|  |  | ||||||
| CefRequestContextHandlerCppToC::CefRequestContextHandlerCppToC() { | CefRequestContextHandlerCppToC::CefRequestContextHandlerCppToC() { | ||||||
|   GetStruct()->get_cookie_manager = request_context_handler_get_cookie_manager; |   GetStruct()->get_cookie_manager = request_context_handler_get_cookie_manager; | ||||||
|  |   GetStruct()->on_before_plugin_load = | ||||||
|  |       request_context_handler_on_before_plugin_load; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> CefRefPtr<CefRequestContextHandler> CefCppToC<CefRequestContextHandlerCppToC, | template<> CefRefPtr<CefRequestContextHandler> CefCppToC<CefRequestContextHandlerCppToC, | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ | |||||||
| #include "libcef_dll/ctocpp/request_callback_ctocpp.h" | #include "libcef_dll/ctocpp/request_callback_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/response_ctocpp.h" | #include "libcef_dll/ctocpp/response_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/sslinfo_ctocpp.h" | #include "libcef_dll/ctocpp/sslinfo_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/web_plugin_info_ctocpp.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace { | namespace { | ||||||
| @@ -389,36 +388,6 @@ int CEF_CALLBACK request_handler_on_certificate_error( | |||||||
|   return _retval; |   return _retval; | ||||||
| } | } | ||||||
|  |  | ||||||
| int CEF_CALLBACK request_handler_on_before_plugin_load( |  | ||||||
|     struct _cef_request_handler_t* self, cef_browser_t* browser, |  | ||||||
|     const cef_string_t* url, const cef_string_t* policy_url, |  | ||||||
|     struct _cef_web_plugin_info_t* info) { |  | ||||||
|   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING |  | ||||||
|  |  | ||||||
|   DCHECK(self); |  | ||||||
|   if (!self) |  | ||||||
|     return 0; |  | ||||||
|   // Verify param: browser; type: refptr_diff |  | ||||||
|   DCHECK(browser); |  | ||||||
|   if (!browser) |  | ||||||
|     return 0; |  | ||||||
|   // Verify param: info; type: refptr_diff |  | ||||||
|   DCHECK(info); |  | ||||||
|   if (!info) |  | ||||||
|     return 0; |  | ||||||
|   // Unverified params: url, policy_url |  | ||||||
|  |  | ||||||
|   // Execute |  | ||||||
|   bool _retval = CefRequestHandlerCppToC::Get(self)->OnBeforePluginLoad( |  | ||||||
|       CefBrowserCToCpp::Wrap(browser), |  | ||||||
|       CefString(url), |  | ||||||
|       CefString(policy_url), |  | ||||||
|       CefWebPluginInfoCToCpp::Wrap(info)); |  | ||||||
|  |  | ||||||
|   // Return type: bool |  | ||||||
|   return _retval; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CEF_CALLBACK request_handler_on_plugin_crashed( | void CEF_CALLBACK request_handler_on_plugin_crashed( | ||||||
|     struct _cef_request_handler_t* self, cef_browser_t* browser, |     struct _cef_request_handler_t* self, cef_browser_t* browser, | ||||||
|     const cef_string_t* plugin_path) { |     const cef_string_t* plugin_path) { | ||||||
| @@ -495,7 +464,6 @@ CefRequestHandlerCppToC::CefRequestHandlerCppToC() { | |||||||
|   GetStruct()->on_quota_request = request_handler_on_quota_request; |   GetStruct()->on_quota_request = request_handler_on_quota_request; | ||||||
|   GetStruct()->on_protocol_execution = request_handler_on_protocol_execution; |   GetStruct()->on_protocol_execution = request_handler_on_protocol_execution; | ||||||
|   GetStruct()->on_certificate_error = request_handler_on_certificate_error; |   GetStruct()->on_certificate_error = request_handler_on_certificate_error; | ||||||
|   GetStruct()->on_before_plugin_load = request_handler_on_before_plugin_load; |  | ||||||
|   GetStruct()->on_plugin_crashed = request_handler_on_plugin_crashed; |   GetStruct()->on_plugin_crashed = request_handler_on_plugin_crashed; | ||||||
|   GetStruct()->on_render_view_ready = request_handler_on_render_view_ready; |   GetStruct()->on_render_view_ready = request_handler_on_render_view_ready; | ||||||
|   GetStruct()->on_render_process_terminated = |   GetStruct()->on_render_process_terminated = | ||||||
|   | |||||||
							
								
								
									
										153
									
								
								libcef_dll/cpptoc/resource_bundle_cpptoc.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								libcef_dll/cpptoc/resource_bundle_cpptoc.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include "libcef_dll/cpptoc/resource_bundle_cpptoc.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // GLOBAL FUNCTIONS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | CEF_EXPORT cef_resource_bundle_t* cef_resource_bundle_get_global() { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   CefRefPtr<CefResourceBundle> _retval = CefResourceBundle::GetGlobal(); | ||||||
|  |  | ||||||
|  |   // Return type: refptr_same | ||||||
|  |   return CefResourceBundleCppToC::Wrap(_retval); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | namespace { | ||||||
|  |  | ||||||
|  | // MEMBER FUNCTIONS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | cef_string_userfree_t CEF_CALLBACK resource_bundle_get_localized_string( | ||||||
|  |     struct _cef_resource_bundle_t* self, int string_id) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return NULL; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   CefString _retval = CefResourceBundleCppToC::Get(self)->GetLocalizedString( | ||||||
|  |       string_id); | ||||||
|  |  | ||||||
|  |   // Return type: string | ||||||
|  |   return _retval.DetachToUserFree(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK resource_bundle_get_data_resource( | ||||||
|  |     struct _cef_resource_bundle_t* self, int resource_id, void** data, | ||||||
|  |     size_t* data_size) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data; type: simple_byref | ||||||
|  |   DCHECK(data); | ||||||
|  |   if (!data) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data_size; type: simple_byref | ||||||
|  |   DCHECK(data_size); | ||||||
|  |   if (!data_size) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Translate param: data; type: simple_byref | ||||||
|  |   void* dataVal = data?*data:NULL; | ||||||
|  |   // Translate param: data_size; type: simple_byref | ||||||
|  |   size_t data_sizeVal = data_size?*data_size:0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefResourceBundleCppToC::Get(self)->GetDataResource( | ||||||
|  |       resource_id, | ||||||
|  |       dataVal, | ||||||
|  |       data_sizeVal); | ||||||
|  |  | ||||||
|  |   // Restore param: data; type: simple_byref | ||||||
|  |   if (data) | ||||||
|  |     *data = dataVal; | ||||||
|  |   // Restore param: data_size; type: simple_byref | ||||||
|  |   if (data_size) | ||||||
|  |     *data_size = data_sizeVal; | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK resource_bundle_get_data_resource_for_scale( | ||||||
|  |     struct _cef_resource_bundle_t* self, int resource_id, | ||||||
|  |     cef_scale_factor_t scale_factor, void** data, size_t* data_size) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data; type: simple_byref | ||||||
|  |   DCHECK(data); | ||||||
|  |   if (!data) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data_size; type: simple_byref | ||||||
|  |   DCHECK(data_size); | ||||||
|  |   if (!data_size) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Translate param: data; type: simple_byref | ||||||
|  |   void* dataVal = data?*data:NULL; | ||||||
|  |   // Translate param: data_size; type: simple_byref | ||||||
|  |   size_t data_sizeVal = data_size?*data_size:0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefResourceBundleCppToC::Get(self)->GetDataResourceForScale( | ||||||
|  |       resource_id, | ||||||
|  |       scale_factor, | ||||||
|  |       dataVal, | ||||||
|  |       data_sizeVal); | ||||||
|  |  | ||||||
|  |   // Restore param: data; type: simple_byref | ||||||
|  |   if (data) | ||||||
|  |     *data = dataVal; | ||||||
|  |   // Restore param: data_size; type: simple_byref | ||||||
|  |   if (data_size) | ||||||
|  |     *data_size = data_sizeVal; | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | }  // namespace | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|  | CefResourceBundleCppToC::CefResourceBundleCppToC() { | ||||||
|  |   GetStruct()->get_localized_string = resource_bundle_get_localized_string; | ||||||
|  |   GetStruct()->get_data_resource = resource_bundle_get_data_resource; | ||||||
|  |   GetStruct()->get_data_resource_for_scale = | ||||||
|  |       resource_bundle_get_data_resource_for_scale; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template<> CefRefPtr<CefResourceBundle> CefCppToC<CefResourceBundleCppToC, | ||||||
|  |     CefResourceBundle, cef_resource_bundle_t>::UnwrapDerived( | ||||||
|  |     CefWrapperType type, cef_resource_bundle_t* s) { | ||||||
|  |   NOTREACHED() << "Unexpected class type: " << type; | ||||||
|  |   return NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #ifndef NDEBUG | ||||||
|  | template<> base::AtomicRefCount CefCppToC<CefResourceBundleCppToC, | ||||||
|  |     CefResourceBundle, cef_resource_bundle_t>::DebugObjCt = 0; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | template<> CefWrapperType CefCppToC<CefResourceBundleCppToC, CefResourceBundle, | ||||||
|  |     cef_resource_bundle_t>::kWrapperType = WT_RESOURCE_BUNDLE; | ||||||
							
								
								
									
										35
									
								
								libcef_dll/cpptoc/resource_bundle_cpptoc.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								libcef_dll/cpptoc/resource_bundle_cpptoc.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_LIBCEF_DLL_CPPTOC_RESOURCE_BUNDLE_CPPTOC_H_ | ||||||
|  | #define CEF_LIBCEF_DLL_CPPTOC_RESOURCE_BUNDLE_CPPTOC_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #ifndef BUILDING_CEF_SHARED | ||||||
|  | #pragma message("Warning: "__FILE__" may be accessed DLL-side only") | ||||||
|  | #else  // BUILDING_CEF_SHARED | ||||||
|  |  | ||||||
|  | #include "include/cef_resource_bundle.h" | ||||||
|  | #include "include/capi/cef_resource_bundle_capi.h" | ||||||
|  | #include "libcef_dll/cpptoc/cpptoc.h" | ||||||
|  |  | ||||||
|  | // Wrap a C++ class with a C structure. | ||||||
|  | // This class may be instantiated and accessed DLL-side only. | ||||||
|  | class CefResourceBundleCppToC | ||||||
|  |     : public CefCppToC<CefResourceBundleCppToC, CefResourceBundle, | ||||||
|  |         cef_resource_bundle_t> { | ||||||
|  |  public: | ||||||
|  |   CefResourceBundleCppToC(); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // BUILDING_CEF_SHARED | ||||||
|  | #endif  // CEF_LIBCEF_DLL_CPPTOC_RESOURCE_BUNDLE_CPPTOC_H_ | ||||||
| @@ -18,7 +18,7 @@ namespace { | |||||||
| // MEMBER FUNCTIONS - Body may be edited by hand. | // MEMBER FUNCTIONS - Body may be edited by hand. | ||||||
|  |  | ||||||
| int CEF_CALLBACK resource_bundle_handler_get_localized_string( | int CEF_CALLBACK resource_bundle_handler_get_localized_string( | ||||||
|     struct _cef_resource_bundle_handler_t* self, int message_id, |     struct _cef_resource_bundle_handler_t* self, int string_id, | ||||||
|     cef_string_t* string) { |     cef_string_t* string) { | ||||||
|   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
| @@ -35,7 +35,7 @@ int CEF_CALLBACK resource_bundle_handler_get_localized_string( | |||||||
|  |  | ||||||
|   // Execute |   // Execute | ||||||
|   bool _retval = CefResourceBundleHandlerCppToC::Get(self)->GetLocalizedString( |   bool _retval = CefResourceBundleHandlerCppToC::Get(self)->GetLocalizedString( | ||||||
|       message_id, |       string_id, | ||||||
|       stringStr); |       stringStr); | ||||||
|  |  | ||||||
|   // Return type: bool |   // Return type: bool | ||||||
| @@ -81,6 +81,47 @@ int CEF_CALLBACK resource_bundle_handler_get_data_resource( | |||||||
|   return _retval; |   return _retval; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | int CEF_CALLBACK resource_bundle_handler_get_data_resource_for_scale( | ||||||
|  |     struct _cef_resource_bundle_handler_t* self, int resource_id, | ||||||
|  |     cef_scale_factor_t scale_factor, void** data, size_t* data_size) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data; type: simple_byref | ||||||
|  |   DCHECK(data); | ||||||
|  |   if (!data) | ||||||
|  |     return 0; | ||||||
|  |   // Verify param: data_size; type: simple_byref | ||||||
|  |   DCHECK(data_size); | ||||||
|  |   if (!data_size) | ||||||
|  |     return 0; | ||||||
|  |  | ||||||
|  |   // Translate param: data; type: simple_byref | ||||||
|  |   void* dataVal = data?*data:NULL; | ||||||
|  |   // Translate param: data_size; type: simple_byref | ||||||
|  |   size_t data_sizeVal = data_size?*data_size:0; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   bool _retval = CefResourceBundleHandlerCppToC::Get( | ||||||
|  |       self)->GetDataResourceForScale( | ||||||
|  |       resource_id, | ||||||
|  |       scale_factor, | ||||||
|  |       dataVal, | ||||||
|  |       data_sizeVal); | ||||||
|  |  | ||||||
|  |   // Restore param: data; type: simple_byref | ||||||
|  |   if (data) | ||||||
|  |     *data = dataVal; | ||||||
|  |   // Restore param: data_size; type: simple_byref | ||||||
|  |   if (data_size) | ||||||
|  |     *data_size = data_sizeVal; | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval; | ||||||
|  | } | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -90,6 +131,8 @@ CefResourceBundleHandlerCppToC::CefResourceBundleHandlerCppToC() { | |||||||
|   GetStruct()->get_localized_string = |   GetStruct()->get_localized_string = | ||||||
|       resource_bundle_handler_get_localized_string; |       resource_bundle_handler_get_localized_string; | ||||||
|   GetStruct()->get_data_resource = resource_bundle_handler_get_data_resource; |   GetStruct()->get_data_resource = resource_bundle_handler_get_data_resource; | ||||||
|  |   GetStruct()->get_data_resource_for_scale = | ||||||
|  |       resource_bundle_handler_get_data_resource_for_scale; | ||||||
| } | } | ||||||
|  |  | ||||||
| template<> CefRefPtr<CefResourceBundleHandler> CefCppToC<CefResourceBundleHandlerCppToC, | template<> CefRefPtr<CefResourceBundleHandler> CefCppToC<CefResourceBundleHandlerCppToC, | ||||||
|   | |||||||
							
								
								
									
										72
									
								
								libcef_dll/cpptoc/run_context_menu_callback_cpptoc.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								libcef_dll/cpptoc/run_context_menu_callback_cpptoc.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,72 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include "libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | namespace { | ||||||
|  |  | ||||||
|  | // MEMBER FUNCTIONS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | void CEF_CALLBACK run_context_menu_callback_cont( | ||||||
|  |     struct _cef_run_context_menu_callback_t* self, int command_id, | ||||||
|  |     cef_event_flags_t event_flags) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   CefRunContextMenuCallbackCppToC::Get(self)->Continue( | ||||||
|  |       command_id, | ||||||
|  |       event_flags); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CEF_CALLBACK run_context_menu_callback_cancel( | ||||||
|  |     struct _cef_run_context_menu_callback_t* self) { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   DCHECK(self); | ||||||
|  |   if (!self) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   CefRunContextMenuCallbackCppToC::Get(self)->Cancel(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | }  // namespace | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|  | CefRunContextMenuCallbackCppToC::CefRunContextMenuCallbackCppToC() { | ||||||
|  |   GetStruct()->cont = run_context_menu_callback_cont; | ||||||
|  |   GetStruct()->cancel = run_context_menu_callback_cancel; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template<> CefRefPtr<CefRunContextMenuCallback> CefCppToC<CefRunContextMenuCallbackCppToC, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::UnwrapDerived( | ||||||
|  |     CefWrapperType type, cef_run_context_menu_callback_t* s) { | ||||||
|  |   NOTREACHED() << "Unexpected class type: " << type; | ||||||
|  |   return NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #ifndef NDEBUG | ||||||
|  | template<> base::AtomicRefCount CefCppToC<CefRunContextMenuCallbackCppToC, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::DebugObjCt = | ||||||
|  |     0; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | template<> CefWrapperType CefCppToC<CefRunContextMenuCallbackCppToC, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::kWrapperType = | ||||||
|  |     WT_RUN_CONTEXT_MENU_CALLBACK; | ||||||
							
								
								
									
										35
									
								
								libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,35 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_LIBCEF_DLL_CPPTOC_RUN_CONTEXT_MENU_CALLBACK_CPPTOC_H_ | ||||||
|  | #define CEF_LIBCEF_DLL_CPPTOC_RUN_CONTEXT_MENU_CALLBACK_CPPTOC_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #ifndef BUILDING_CEF_SHARED | ||||||
|  | #pragma message("Warning: "__FILE__" may be accessed DLL-side only") | ||||||
|  | #else  // BUILDING_CEF_SHARED | ||||||
|  |  | ||||||
|  | #include "include/cef_context_menu_handler.h" | ||||||
|  | #include "include/capi/cef_context_menu_handler_capi.h" | ||||||
|  | #include "libcef_dll/cpptoc/cpptoc.h" | ||||||
|  |  | ||||||
|  | // Wrap a C++ class with a C structure. | ||||||
|  | // This class may be instantiated and accessed DLL-side only. | ||||||
|  | class CefRunContextMenuCallbackCppToC | ||||||
|  |     : public CefCppToC<CefRunContextMenuCallbackCppToC, | ||||||
|  |         CefRunContextMenuCallback, cef_run_context_menu_callback_t> { | ||||||
|  |  public: | ||||||
|  |   CefRunContextMenuCallbackCppToC(); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // BUILDING_CEF_SHARED | ||||||
|  | #endif  // CEF_LIBCEF_DLL_CPPTOC_RUN_CONTEXT_MENU_CALLBACK_CPPTOC_H_ | ||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/cpptoc/cpptoc.h" | #include "libcef_dll/cpptoc/cpptoc.h" | ||||||
|  |  | ||||||
| // Wrap a C++ class with a C structure. | // Wrap a C++ class with a C structure. | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/cpptoc/cpptoc.h" | #include "libcef_dll/cpptoc/cpptoc.h" | ||||||
|  |  | ||||||
| // Wrap a C++ class with a C structure. | // Wrap a C++ class with a C structure. | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/cpptoc/cpptoc.h" | #include "libcef_dll/cpptoc/cpptoc.h" | ||||||
|  |  | ||||||
| // Wrap a C++ class with a C structure. | // Wrap a C++ class with a C structure. | ||||||
|   | |||||||
| @@ -14,6 +14,7 @@ | |||||||
| #include "libcef_dll/cpptoc/context_menu_params_cpptoc.h" | #include "libcef_dll/cpptoc/context_menu_params_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/frame_cpptoc.h" | #include "libcef_dll/cpptoc/frame_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/menu_model_cpptoc.h" | #include "libcef_dll/cpptoc/menu_model_cpptoc.h" | ||||||
|  | #include "libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h" | ||||||
| #include "libcef_dll/ctocpp/context_menu_handler_ctocpp.h" | #include "libcef_dll/ctocpp/context_menu_handler_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -53,6 +54,49 @@ void CefContextMenuHandlerCToCpp::OnBeforeContextMenu( | |||||||
|       CefMenuModelCppToC::Wrap(model)); |       CefMenuModelCppToC::Wrap(model)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefContextMenuHandlerCToCpp::RunContextMenu(CefRefPtr<CefBrowser> browser, | ||||||
|  |     CefRefPtr<CefFrame> frame, CefRefPtr<CefContextMenuParams> params, | ||||||
|  |     CefRefPtr<CefMenuModel> model, | ||||||
|  |     CefRefPtr<CefRunContextMenuCallback> callback) { | ||||||
|  |   cef_context_menu_handler_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, run_context_menu)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Verify param: browser; type: refptr_diff | ||||||
|  |   DCHECK(browser.get()); | ||||||
|  |   if (!browser.get()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: frame; type: refptr_diff | ||||||
|  |   DCHECK(frame.get()); | ||||||
|  |   if (!frame.get()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: params; type: refptr_diff | ||||||
|  |   DCHECK(params.get()); | ||||||
|  |   if (!params.get()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: model; type: refptr_diff | ||||||
|  |   DCHECK(model.get()); | ||||||
|  |   if (!model.get()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: callback; type: refptr_diff | ||||||
|  |   DCHECK(callback.get()); | ||||||
|  |   if (!callback.get()) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->run_context_menu(_struct, | ||||||
|  |       CefBrowserCppToC::Wrap(browser), | ||||||
|  |       CefFrameCppToC::Wrap(frame), | ||||||
|  |       CefContextMenuParamsCppToC::Wrap(params), | ||||||
|  |       CefMenuModelCppToC::Wrap(model), | ||||||
|  |       CefRunContextMenuCallbackCppToC::Wrap(callback)); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
| bool CefContextMenuHandlerCToCpp::OnContextMenuCommand( | bool CefContextMenuHandlerCToCpp::OnContextMenuCommand( | ||||||
|     CefRefPtr<CefBrowser> browser, CefRefPtr<CefFrame> frame, |     CefRefPtr<CefBrowser> browser, CefRefPtr<CefFrame> frame, | ||||||
|     CefRefPtr<CefContextMenuParams> params, int command_id, |     CefRefPtr<CefContextMenuParams> params, int command_id, | ||||||
|   | |||||||
| @@ -34,6 +34,9 @@ class CefContextMenuHandlerCToCpp | |||||||
|   void OnBeforeContextMenu(CefRefPtr<CefBrowser> browser, |   void OnBeforeContextMenu(CefRefPtr<CefBrowser> browser, | ||||||
|       CefRefPtr<CefFrame> frame, CefRefPtr<CefContextMenuParams> params, |       CefRefPtr<CefFrame> frame, CefRefPtr<CefContextMenuParams> params, | ||||||
|       CefRefPtr<CefMenuModel> model) override; |       CefRefPtr<CefMenuModel> model) override; | ||||||
|  |   bool RunContextMenu(CefRefPtr<CefBrowser> browser, CefRefPtr<CefFrame> frame, | ||||||
|  |       CefRefPtr<CefContextMenuParams> params, CefRefPtr<CefMenuModel> model, | ||||||
|  |       CefRefPtr<CefRunContextMenuCallback> callback) override; | ||||||
|   bool OnContextMenuCommand(CefRefPtr<CefBrowser> browser, |   bool OnContextMenuCommand(CefRefPtr<CefBrowser> browser, | ||||||
|       CefRefPtr<CefFrame> frame, CefRefPtr<CefContextMenuParams> params, |       CefRefPtr<CefFrame> frame, CefRefPtr<CefContextMenuParams> params, | ||||||
|       int command_id, EventFlags event_flags) override; |       int command_id, EventFlags event_flags) override; | ||||||
|   | |||||||
| @@ -303,6 +303,34 @@ CefContextMenuParams::EditStateFlags CefContextMenuParamsCToCpp::GetEditStateFla | |||||||
|   return _retval; |   return _retval; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefContextMenuParamsCToCpp::IsCustomMenu() { | ||||||
|  |   cef_context_menu_params_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, is_custom_menu)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->is_custom_menu(_struct); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefContextMenuParamsCToCpp::IsPepperMenu() { | ||||||
|  |   cef_context_menu_params_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, is_pepper_menu)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->is_pepper_menu(_struct); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // CONSTRUCTOR - Do not edit by hand. | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -50,6 +50,8 @@ class CefContextMenuParamsCToCpp | |||||||
|   bool IsEditable() OVERRIDE; |   bool IsEditable() OVERRIDE; | ||||||
|   bool IsSpellCheckEnabled() OVERRIDE; |   bool IsSpellCheckEnabled() OVERRIDE; | ||||||
|   EditStateFlags GetEditStateFlags() OVERRIDE; |   EditStateFlags GetEditStateFlags() OVERRIDE; | ||||||
|  |   bool IsCustomMenu() OVERRIDE; | ||||||
|  |   bool IsPepperMenu() OVERRIDE; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // USING_CEF_SHARED | #endif  // USING_CEF_SHARED | ||||||
|   | |||||||
| @@ -11,6 +11,7 @@ | |||||||
| // | // | ||||||
|  |  | ||||||
| #include "libcef_dll/cpptoc/cookie_manager_cpptoc.h" | #include "libcef_dll/cpptoc/cookie_manager_cpptoc.h" | ||||||
|  | #include "libcef_dll/cpptoc/web_plugin_info_cpptoc.h" | ||||||
| #include "libcef_dll/ctocpp/request_context_handler_ctocpp.h" | #include "libcef_dll/ctocpp/request_context_handler_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -30,6 +31,46 @@ CefRefPtr<CefCookieManager> CefRequestContextHandlerCToCpp::GetCookieManager() { | |||||||
|   return CefCookieManagerCppToC::Unwrap(_retval); |   return CefCookieManagerCppToC::Unwrap(_retval); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefRequestContextHandlerCToCpp::OnBeforePluginLoad( | ||||||
|  |     const CefString& mime_type, const CefString& plugin_url, | ||||||
|  |     const CefString& top_origin_url, CefRefPtr<CefWebPluginInfo> plugin_info, | ||||||
|  |     PluginPolicy* plugin_policy) { | ||||||
|  |   cef_request_context_handler_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, on_before_plugin_load)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Verify param: mime_type; type: string_byref_const | ||||||
|  |   DCHECK(!mime_type.empty()); | ||||||
|  |   if (mime_type.empty()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: top_origin_url; type: string_byref_const | ||||||
|  |   DCHECK(!top_origin_url.empty()); | ||||||
|  |   if (top_origin_url.empty()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: plugin_info; type: refptr_diff | ||||||
|  |   DCHECK(plugin_info.get()); | ||||||
|  |   if (!plugin_info.get()) | ||||||
|  |     return false; | ||||||
|  |   // Verify param: plugin_policy; type: simple_byaddr | ||||||
|  |   DCHECK(plugin_policy); | ||||||
|  |   if (!plugin_policy) | ||||||
|  |     return false; | ||||||
|  |   // Unverified params: plugin_url | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->on_before_plugin_load(_struct, | ||||||
|  |       mime_type.GetStruct(), | ||||||
|  |       plugin_url.GetStruct(), | ||||||
|  |       top_origin_url.GetStruct(), | ||||||
|  |       CefWebPluginInfoCppToC::Wrap(plugin_info), | ||||||
|  |       plugin_policy); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // CONSTRUCTOR - Do not edit by hand. | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,6 +32,10 @@ class CefRequestContextHandlerCToCpp | |||||||
|  |  | ||||||
|   // CefRequestContextHandler methods. |   // CefRequestContextHandler methods. | ||||||
|   CefRefPtr<CefCookieManager> GetCookieManager() override; |   CefRefPtr<CefCookieManager> GetCookieManager() override; | ||||||
|  |   bool OnBeforePluginLoad(const CefString& mime_type, | ||||||
|  |       const CefString& plugin_url, const CefString& top_origin_url, | ||||||
|  |       CefRefPtr<CefWebPluginInfo> plugin_info, | ||||||
|  |       PluginPolicy* plugin_policy) override; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // BUILDING_CEF_SHARED | #endif  // BUILDING_CEF_SHARED | ||||||
|   | |||||||
| @@ -17,7 +17,6 @@ | |||||||
| #include "libcef_dll/cpptoc/request_callback_cpptoc.h" | #include "libcef_dll/cpptoc/request_callback_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/response_cpptoc.h" | #include "libcef_dll/cpptoc/response_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/sslinfo_cpptoc.h" | #include "libcef_dll/cpptoc/sslinfo_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/web_plugin_info_cpptoc.h" |  | ||||||
| #include "libcef_dll/ctocpp/request_handler_ctocpp.h" | #include "libcef_dll/ctocpp/request_handler_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/resource_handler_ctocpp.h" | #include "libcef_dll/ctocpp/resource_handler_ctocpp.h" | ||||||
|  |  | ||||||
| @@ -375,36 +374,6 @@ bool CefRequestHandlerCToCpp::OnCertificateError(CefRefPtr<CefBrowser> browser, | |||||||
|   return _retval?true:false; |   return _retval?true:false; | ||||||
| } | } | ||||||
|  |  | ||||||
| bool CefRequestHandlerCToCpp::OnBeforePluginLoad(CefRefPtr<CefBrowser> browser, |  | ||||||
|     const CefString& url, const CefString& policy_url, |  | ||||||
|     CefRefPtr<CefWebPluginInfo> info) { |  | ||||||
|   cef_request_handler_t* _struct = GetStruct(); |  | ||||||
|   if (CEF_MEMBER_MISSING(_struct, on_before_plugin_load)) |  | ||||||
|     return false; |  | ||||||
|  |  | ||||||
|   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING |  | ||||||
|  |  | ||||||
|   // Verify param: browser; type: refptr_diff |  | ||||||
|   DCHECK(browser.get()); |  | ||||||
|   if (!browser.get()) |  | ||||||
|     return false; |  | ||||||
|   // Verify param: info; type: refptr_diff |  | ||||||
|   DCHECK(info.get()); |  | ||||||
|   if (!info.get()) |  | ||||||
|     return false; |  | ||||||
|   // Unverified params: url, policy_url |  | ||||||
|  |  | ||||||
|   // Execute |  | ||||||
|   int _retval = _struct->on_before_plugin_load(_struct, |  | ||||||
|       CefBrowserCppToC::Wrap(browser), |  | ||||||
|       url.GetStruct(), |  | ||||||
|       policy_url.GetStruct(), |  | ||||||
|       CefWebPluginInfoCppToC::Wrap(info)); |  | ||||||
|  |  | ||||||
|   // Return type: bool |  | ||||||
|   return _retval?true:false; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void CefRequestHandlerCToCpp::OnPluginCrashed(CefRefPtr<CefBrowser> browser, | void CefRequestHandlerCToCpp::OnPluginCrashed(CefRefPtr<CefBrowser> browser, | ||||||
|     const CefString& plugin_path) { |     const CefString& plugin_path) { | ||||||
|   cef_request_handler_t* _struct = GetStruct(); |   cef_request_handler_t* _struct = GetStruct(); | ||||||
|   | |||||||
| @@ -61,8 +61,6 @@ class CefRequestHandlerCToCpp | |||||||
|       cef_errorcode_t cert_error, const CefString& request_url, |       cef_errorcode_t cert_error, const CefString& request_url, | ||||||
|       CefRefPtr<CefSSLInfo> ssl_info, |       CefRefPtr<CefSSLInfo> ssl_info, | ||||||
|       CefRefPtr<CefRequestCallback> callback) override; |       CefRefPtr<CefRequestCallback> callback) override; | ||||||
|   bool OnBeforePluginLoad(CefRefPtr<CefBrowser> browser, const CefString& url, |  | ||||||
|       const CefString& policy_url, CefRefPtr<CefWebPluginInfo> info) override; |  | ||||||
|   void OnPluginCrashed(CefRefPtr<CefBrowser> browser, |   void OnPluginCrashed(CefRefPtr<CefBrowser> browser, | ||||||
|       const CefString& plugin_path) override; |       const CefString& plugin_path) override; | ||||||
|   void OnRenderViewReady(CefRefPtr<CefBrowser> browser) override; |   void OnRenderViewReady(CefRefPtr<CefBrowser> browser) override; | ||||||
|   | |||||||
							
								
								
									
										104
									
								
								libcef_dll/ctocpp/resource_bundle_ctocpp.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								libcef_dll/ctocpp/resource_bundle_ctocpp.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include "libcef_dll/ctocpp/resource_bundle_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // STATIC METHODS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | CefRefPtr<CefResourceBundle> CefResourceBundle::GetGlobal() { | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   cef_resource_bundle_t* _retval = cef_resource_bundle_get_global(); | ||||||
|  |  | ||||||
|  |   // Return type: refptr_same | ||||||
|  |   return CefResourceBundleCToCpp::Wrap(_retval); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // VIRTUAL METHODS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | CefString CefResourceBundleCToCpp::GetLocalizedString(int string_id) { | ||||||
|  |   cef_resource_bundle_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, get_localized_string)) | ||||||
|  |     return CefString(); | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   cef_string_userfree_t _retval = _struct->get_localized_string(_struct, | ||||||
|  |       string_id); | ||||||
|  |  | ||||||
|  |   // Return type: string | ||||||
|  |   CefString _retvalStr; | ||||||
|  |   _retvalStr.AttachToUserFree(_retval); | ||||||
|  |   return _retvalStr; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefResourceBundleCToCpp::GetDataResource(int resource_id, void*& data, | ||||||
|  |     size_t& data_size) { | ||||||
|  |   cef_resource_bundle_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, get_data_resource)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->get_data_resource(_struct, | ||||||
|  |       resource_id, | ||||||
|  |       &data, | ||||||
|  |       &data_size); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool CefResourceBundleCToCpp::GetDataResourceForScale(int resource_id, | ||||||
|  |     ScaleFactor scale_factor, void*& data, size_t& data_size) { | ||||||
|  |   cef_resource_bundle_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, get_data_resource_for_scale)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->get_data_resource_for_scale(_struct, | ||||||
|  |       resource_id, | ||||||
|  |       scale_factor, | ||||||
|  |       &data, | ||||||
|  |       &data_size); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|  | CefResourceBundleCToCpp::CefResourceBundleCToCpp() { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template<> cef_resource_bundle_t* CefCToCpp<CefResourceBundleCToCpp, | ||||||
|  |     CefResourceBundle, cef_resource_bundle_t>::UnwrapDerived( | ||||||
|  |     CefWrapperType type, CefResourceBundle* c) { | ||||||
|  |   NOTREACHED() << "Unexpected class type: " << type; | ||||||
|  |   return NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #ifndef NDEBUG | ||||||
|  | template<> base::AtomicRefCount CefCToCpp<CefResourceBundleCToCpp, | ||||||
|  |     CefResourceBundle, cef_resource_bundle_t>::DebugObjCt = 0; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | template<> CefWrapperType CefCToCpp<CefResourceBundleCToCpp, CefResourceBundle, | ||||||
|  |     cef_resource_bundle_t>::kWrapperType = WT_RESOURCE_BUNDLE; | ||||||
							
								
								
									
										42
									
								
								libcef_dll/ctocpp/resource_bundle_ctocpp.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								libcef_dll/ctocpp/resource_bundle_ctocpp.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_LIBCEF_DLL_CTOCPP_RESOURCE_BUNDLE_CTOCPP_H_ | ||||||
|  | #define CEF_LIBCEF_DLL_CTOCPP_RESOURCE_BUNDLE_CTOCPP_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #ifndef USING_CEF_SHARED | ||||||
|  | #pragma message("Warning: "__FILE__" may be accessed wrapper-side only") | ||||||
|  | #else  // USING_CEF_SHARED | ||||||
|  |  | ||||||
|  | #include "include/cef_resource_bundle.h" | ||||||
|  | #include "include/capi/cef_resource_bundle_capi.h" | ||||||
|  | #include "libcef_dll/ctocpp/ctocpp.h" | ||||||
|  |  | ||||||
|  | // Wrap a C structure with a C++ class. | ||||||
|  | // This class may be instantiated and accessed wrapper-side only. | ||||||
|  | class CefResourceBundleCToCpp | ||||||
|  |     : public CefCToCpp<CefResourceBundleCToCpp, CefResourceBundle, | ||||||
|  |         cef_resource_bundle_t> { | ||||||
|  |  public: | ||||||
|  |   CefResourceBundleCToCpp(); | ||||||
|  |  | ||||||
|  |   // CefResourceBundle methods. | ||||||
|  |   CefString GetLocalizedString(int string_id) OVERRIDE; | ||||||
|  |   bool GetDataResource(int resource_id, void*& data, | ||||||
|  |       size_t& data_size) OVERRIDE; | ||||||
|  |   bool GetDataResourceForScale(int resource_id, ScaleFactor scale_factor, | ||||||
|  |       void*& data, size_t& data_size) OVERRIDE; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // USING_CEF_SHARED | ||||||
|  | #endif  // CEF_LIBCEF_DLL_CTOCPP_RESOURCE_BUNDLE_CTOCPP_H_ | ||||||
| @@ -15,7 +15,7 @@ | |||||||
|  |  | ||||||
| // VIRTUAL METHODS - Body may be edited by hand. | // VIRTUAL METHODS - Body may be edited by hand. | ||||||
|  |  | ||||||
| bool CefResourceBundleHandlerCToCpp::GetLocalizedString(int message_id, | bool CefResourceBundleHandlerCToCpp::GetLocalizedString(int string_id, | ||||||
|     CefString& string) { |     CefString& string) { | ||||||
|   cef_resource_bundle_handler_t* _struct = GetStruct(); |   cef_resource_bundle_handler_t* _struct = GetStruct(); | ||||||
|   if (CEF_MEMBER_MISSING(_struct, get_localized_string)) |   if (CEF_MEMBER_MISSING(_struct, get_localized_string)) | ||||||
| @@ -25,7 +25,7 @@ bool CefResourceBundleHandlerCToCpp::GetLocalizedString(int message_id, | |||||||
|  |  | ||||||
|   // Execute |   // Execute | ||||||
|   int _retval = _struct->get_localized_string(_struct, |   int _retval = _struct->get_localized_string(_struct, | ||||||
|       message_id, |       string_id, | ||||||
|       string.GetWritableStruct()); |       string.GetWritableStruct()); | ||||||
|  |  | ||||||
|   // Return type: bool |   // Return type: bool | ||||||
| @@ -50,6 +50,25 @@ bool CefResourceBundleHandlerCToCpp::GetDataResource(int resource_id, | |||||||
|   return _retval?true:false; |   return _retval?true:false; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | bool CefResourceBundleHandlerCToCpp::GetDataResourceForScale(int resource_id, | ||||||
|  |     ScaleFactor scale_factor, void*& data, size_t& data_size) { | ||||||
|  |   cef_resource_bundle_handler_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, get_data_resource_for_scale)) | ||||||
|  |     return false; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   int _retval = _struct->get_data_resource_for_scale(_struct, | ||||||
|  |       resource_id, | ||||||
|  |       scale_factor, | ||||||
|  |       &data, | ||||||
|  |       &data_size); | ||||||
|  |  | ||||||
|  |   // Return type: bool | ||||||
|  |   return _retval?true:false; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| // CONSTRUCTOR - Do not edit by hand. | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,9 +31,11 @@ class CefResourceBundleHandlerCToCpp | |||||||
|   CefResourceBundleHandlerCToCpp(); |   CefResourceBundleHandlerCToCpp(); | ||||||
|  |  | ||||||
|   // CefResourceBundleHandler methods. |   // CefResourceBundleHandler methods. | ||||||
|   bool GetLocalizedString(int message_id, CefString& string) override; |   bool GetLocalizedString(int string_id, CefString& string) override; | ||||||
|   bool GetDataResource(int resource_id, void*& data, |   bool GetDataResource(int resource_id, void*& data, | ||||||
|       size_t& data_size) override; |       size_t& data_size) override; | ||||||
|  |   bool GetDataResourceForScale(int resource_id, ScaleFactor scale_factor, | ||||||
|  |       void*& data, size_t& data_size) override; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| #endif  // BUILDING_CEF_SHARED | #endif  // BUILDING_CEF_SHARED | ||||||
|   | |||||||
							
								
								
									
										64
									
								
								libcef_dll/ctocpp/run_context_menu_callback_ctocpp.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								libcef_dll/ctocpp/run_context_menu_callback_ctocpp.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #include "libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // VIRTUAL METHODS - Body may be edited by hand. | ||||||
|  |  | ||||||
|  | void CefRunContextMenuCallbackCToCpp::Continue(int command_id, | ||||||
|  |     EventFlags event_flags) { | ||||||
|  |   cef_run_context_menu_callback_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, cont)) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   _struct->cont(_struct, | ||||||
|  |       command_id, | ||||||
|  |       event_flags); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void CefRunContextMenuCallbackCToCpp::Cancel() { | ||||||
|  |   cef_run_context_menu_callback_t* _struct = GetStruct(); | ||||||
|  |   if (CEF_MEMBER_MISSING(_struct, cancel)) | ||||||
|  |     return; | ||||||
|  |  | ||||||
|  |   // AUTO-GENERATED CONTENT - DELETE THIS COMMENT BEFORE MODIFYING | ||||||
|  |  | ||||||
|  |   // Execute | ||||||
|  |   _struct->cancel(_struct); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // CONSTRUCTOR - Do not edit by hand. | ||||||
|  |  | ||||||
|  | CefRunContextMenuCallbackCToCpp::CefRunContextMenuCallbackCToCpp() { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template<> cef_run_context_menu_callback_t* CefCToCpp<CefRunContextMenuCallbackCToCpp, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::UnwrapDerived( | ||||||
|  |     CefWrapperType type, CefRunContextMenuCallback* c) { | ||||||
|  |   NOTREACHED() << "Unexpected class type: " << type; | ||||||
|  |   return NULL; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #ifndef NDEBUG | ||||||
|  | template<> base::AtomicRefCount CefCToCpp<CefRunContextMenuCallbackCToCpp, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::DebugObjCt = | ||||||
|  |     0; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | template<> CefWrapperType CefCToCpp<CefRunContextMenuCallbackCToCpp, | ||||||
|  |     CefRunContextMenuCallback, cef_run_context_menu_callback_t>::kWrapperType = | ||||||
|  |     WT_RUN_CONTEXT_MENU_CALLBACK; | ||||||
							
								
								
									
										39
									
								
								libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,39 @@ | |||||||
|  | // Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights | ||||||
|  | // reserved. Use of this source code is governed by a BSD-style license that | ||||||
|  | // can be found in the LICENSE file. | ||||||
|  | // | ||||||
|  | // --------------------------------------------------------------------------- | ||||||
|  | // | ||||||
|  | // This file was generated by the CEF translator tool. If making changes by | ||||||
|  | // hand only do so within the body of existing method and function | ||||||
|  | // implementations. See the translator.README.txt file in the tools directory | ||||||
|  | // for more information. | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #ifndef CEF_LIBCEF_DLL_CTOCPP_RUN_CONTEXT_MENU_CALLBACK_CTOCPP_H_ | ||||||
|  | #define CEF_LIBCEF_DLL_CTOCPP_RUN_CONTEXT_MENU_CALLBACK_CTOCPP_H_ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #ifndef USING_CEF_SHARED | ||||||
|  | #pragma message("Warning: "__FILE__" may be accessed wrapper-side only") | ||||||
|  | #else  // USING_CEF_SHARED | ||||||
|  |  | ||||||
|  | #include "include/cef_context_menu_handler.h" | ||||||
|  | #include "include/capi/cef_context_menu_handler_capi.h" | ||||||
|  | #include "libcef_dll/ctocpp/ctocpp.h" | ||||||
|  |  | ||||||
|  | // Wrap a C structure with a C++ class. | ||||||
|  | // This class may be instantiated and accessed wrapper-side only. | ||||||
|  | class CefRunContextMenuCallbackCToCpp | ||||||
|  |     : public CefCToCpp<CefRunContextMenuCallbackCToCpp, | ||||||
|  |         CefRunContextMenuCallback, cef_run_context_menu_callback_t> { | ||||||
|  |  public: | ||||||
|  |   CefRunContextMenuCallbackCToCpp(); | ||||||
|  |  | ||||||
|  |   // CefRunContextMenuCallback methods. | ||||||
|  |   void Continue(int command_id, EventFlags event_flags) OVERRIDE; | ||||||
|  |   void Cancel() OVERRIDE; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | #endif  // USING_CEF_SHARED | ||||||
|  | #endif  // CEF_LIBCEF_DLL_CTOCPP_RUN_CONTEXT_MENU_CALLBACK_CTOCPP_H_ | ||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/ctocpp/ctocpp.h" | #include "libcef_dll/ctocpp/ctocpp.h" | ||||||
|  |  | ||||||
| // Wrap a C structure with a C++ class. | // Wrap a C structure with a C++ class. | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/ctocpp/ctocpp.h" | #include "libcef_dll/ctocpp/ctocpp.h" | ||||||
|  |  | ||||||
| // Wrap a C structure with a C++ class. | // Wrap a C structure with a C++ class. | ||||||
|   | |||||||
| @@ -20,6 +20,8 @@ | |||||||
|  |  | ||||||
| #include "include/cef_web_plugin.h" | #include "include/cef_web_plugin.h" | ||||||
| #include "include/capi/cef_web_plugin_capi.h" | #include "include/capi/cef_web_plugin_capi.h" | ||||||
|  | #include "include/cef_browser.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "libcef_dll/ctocpp/ctocpp.h" | #include "libcef_dll/ctocpp/ctocpp.h" | ||||||
|  |  | ||||||
| // Wrap a C structure with a C++ class. | // Wrap a C structure with a C++ class. | ||||||
|   | |||||||
| @@ -58,6 +58,7 @@ | |||||||
| #include "libcef_dll/cpptoc/print_settings_cpptoc.h" | #include "libcef_dll/cpptoc/print_settings_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/process_message_cpptoc.h" | #include "libcef_dll/cpptoc/process_message_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/request_callback_cpptoc.h" | #include "libcef_dll/cpptoc/request_callback_cpptoc.h" | ||||||
|  | #include "libcef_dll/cpptoc/run_context_menu_callback_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/sslcert_principal_cpptoc.h" | #include "libcef_dll/cpptoc/sslcert_principal_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/sslinfo_cpptoc.h" | #include "libcef_dll/cpptoc/sslinfo_cpptoc.h" | ||||||
| #include "libcef_dll/cpptoc/scheme_registrar_cpptoc.h" | #include "libcef_dll/cpptoc/scheme_registrar_cpptoc.h" | ||||||
| @@ -248,6 +249,8 @@ CEF_EXPORT void cef_shutdown() { | |||||||
|   DCHECK(base::AtomicRefCountIsZero( |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|       &CefResourceBundleHandlerCToCpp::DebugObjCt)); |       &CefResourceBundleHandlerCToCpp::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero(&CefResourceHandlerCToCpp::DebugObjCt)); |   DCHECK(base::AtomicRefCountIsZero(&CefResourceHandlerCToCpp::DebugObjCt)); | ||||||
|  |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|  |       &CefRunContextMenuCallbackCppToC::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero( |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|       &CefRunFileDialogCallbackCToCpp::DebugObjCt)); |       &CefRunFileDialogCallbackCToCpp::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero(&CefSSLCertPrincipalCppToC::DebugObjCt)); |   DCHECK(base::AtomicRefCountIsZero(&CefSSLCertPrincipalCppToC::DebugObjCt)); | ||||||
|   | |||||||
| @@ -99,6 +99,7 @@ | |||||||
| #include "libcef_dll/ctocpp/print_settings_ctocpp.h" | #include "libcef_dll/ctocpp/print_settings_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/process_message_ctocpp.h" | #include "libcef_dll/ctocpp/process_message_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/request_callback_ctocpp.h" | #include "libcef_dll/ctocpp/request_callback_ctocpp.h" | ||||||
|  | #include "libcef_dll/ctocpp/run_context_menu_callback_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/sslcert_principal_ctocpp.h" | #include "libcef_dll/ctocpp/sslcert_principal_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/sslinfo_ctocpp.h" | #include "libcef_dll/ctocpp/sslinfo_ctocpp.h" | ||||||
| #include "libcef_dll/ctocpp/scheme_registrar_ctocpp.h" | #include "libcef_dll/ctocpp/scheme_registrar_ctocpp.h" | ||||||
| @@ -240,6 +241,8 @@ CEF_GLOBAL void CefShutdown() { | |||||||
|   DCHECK(base::AtomicRefCountIsZero( |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|       &CefResourceBundleHandlerCppToC::DebugObjCt)); |       &CefResourceBundleHandlerCppToC::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero(&CefResourceHandlerCppToC::DebugObjCt)); |   DCHECK(base::AtomicRefCountIsZero(&CefResourceHandlerCppToC::DebugObjCt)); | ||||||
|  |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|  |       &CefRunContextMenuCallbackCToCpp::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero( |   DCHECK(base::AtomicRefCountIsZero( | ||||||
|       &CefRunFileDialogCallbackCppToC::DebugObjCt)); |       &CefRunFileDialogCallbackCppToC::DebugObjCt)); | ||||||
|   DCHECK(base::AtomicRefCountIsZero(&CefSSLCertPrincipalCToCpp::DebugObjCt)); |   DCHECK(base::AtomicRefCountIsZero(&CefSSLCertPrincipalCToCpp::DebugObjCt)); | ||||||
|   | |||||||
| @@ -76,9 +76,11 @@ enum CefWrapperType { | |||||||
|   WT_REQUEST_CONTEXT, |   WT_REQUEST_CONTEXT, | ||||||
|   WT_REQUEST_CONTEXT_HANDLER, |   WT_REQUEST_CONTEXT_HANDLER, | ||||||
|   WT_REQUEST_HANDLER, |   WT_REQUEST_HANDLER, | ||||||
|  |   WT_RESOURCE_BUNDLE, | ||||||
|   WT_RESOURCE_BUNDLE_HANDLER, |   WT_RESOURCE_BUNDLE_HANDLER, | ||||||
|   WT_RESOURCE_HANDLER, |   WT_RESOURCE_HANDLER, | ||||||
|   WT_RESPONSE, |   WT_RESPONSE, | ||||||
|  |   WT_RUN_CONTEXT_MENU_CALLBACK, | ||||||
|   WT_RUN_FILE_DIALOG_CALLBACK, |   WT_RUN_FILE_DIALOG_CALLBACK, | ||||||
|   WT_SSLCERT_PRINCIPAL, |   WT_SSLCERT_PRINCIPAL, | ||||||
|   WT_SSLINFO, |   WT_SSLINFO, | ||||||
|   | |||||||
| @@ -11,6 +11,7 @@ | |||||||
| namespace client { | namespace client { | ||||||
|  |  | ||||||
| ClientAppBrowser::ClientAppBrowser() { | ClientAppBrowser::ClientAppBrowser() { | ||||||
|  |   CreateDelegates(delegates_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ClientAppBrowser::OnBeforeCommandLineProcessing( | void ClientAppBrowser::OnBeforeCommandLineProcessing( | ||||||
| @@ -46,12 +47,14 @@ void ClientAppBrowser::OnBeforeCommandLineProcessing( | |||||||
|       // See https://bitbucket.org/chromiumembedded/cef/issues/1368 for details. |       // See https://bitbucket.org/chromiumembedded/cef/issues/1368 for details. | ||||||
|       command_line->AppendSwitch("enable-begin-frame-scheduling"); |       command_line->AppendSwitch("enable-begin-frame-scheduling"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     DelegateSet::iterator it = delegates_.begin(); | ||||||
|  |     for (; it != delegates_.end(); ++it) | ||||||
|  |       (*it)->OnBeforeCommandLineProcessing(this, command_line); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| void ClientAppBrowser::OnContextInitialized() { | void ClientAppBrowser::OnContextInitialized() { | ||||||
|   CreateDelegates(delegates_); |  | ||||||
|  |  | ||||||
|   // Register cookieable schemes with the global cookie manager. |   // Register cookieable schemes with the global cookie manager. | ||||||
|   CefRefPtr<CefCookieManager> manager = |   CefRefPtr<CefCookieManager> manager = | ||||||
|       CefCookieManager::GetGlobalManager(NULL); |       CefCookieManager::GetGlobalManager(NULL); | ||||||
|   | |||||||
| @@ -21,7 +21,11 @@ class ClientAppBrowser : public ClientApp, | |||||||
|   // constructor. See CefBrowserProcessHandler for documentation. |   // constructor. See CefBrowserProcessHandler for documentation. | ||||||
|   class Delegate : public virtual CefBase { |   class Delegate : public virtual CefBase { | ||||||
|    public: |    public: | ||||||
|     virtual void OnContextInitialized(CefRefPtr<ClientApp> app) {} |     virtual void OnBeforeCommandLineProcessing( | ||||||
|  |         CefRefPtr<ClientAppBrowser> app, | ||||||
|  |         CefRefPtr<CefCommandLine> command_line) {} | ||||||
|  |  | ||||||
|  |     virtual void OnContextInitialized(CefRefPtr<ClientAppBrowser> app) {} | ||||||
|  |  | ||||||
|     virtual void OnBeforeChildProcessLaunch( |     virtual void OnBeforeChildProcessLaunch( | ||||||
|         CefRefPtr<ClientAppBrowser> app, |         CefRefPtr<ClientAppBrowser> app, | ||||||
|   | |||||||
| @@ -15,6 +15,32 @@ | |||||||
|  |  | ||||||
| namespace client { | namespace client { | ||||||
|  |  | ||||||
|  | namespace { | ||||||
|  |  | ||||||
|  | class ClientRequestContextHandler : public CefRequestContextHandler { | ||||||
|  |  public: | ||||||
|  |   ClientRequestContextHandler() {} | ||||||
|  |  | ||||||
|  |   bool OnBeforePluginLoad(const CefString& mime_type, | ||||||
|  |                           const CefString& plugin_url, | ||||||
|  |                           const CefString& top_origin_url, | ||||||
|  |                           CefRefPtr<CefWebPluginInfo> plugin_info, | ||||||
|  |                           PluginPolicy* plugin_policy) OVERRIDE { | ||||||
|  |     // Always allow the PDF plugin to load. | ||||||
|  |     if (*plugin_policy != PLUGIN_POLICY_ALLOW && | ||||||
|  |         mime_type == "application/pdf") { | ||||||
|  |       *plugin_policy = PLUGIN_POLICY_ALLOW; | ||||||
|  |       return true; | ||||||
|  |     } | ||||||
|  |     return false; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  private: | ||||||
|  |   IMPLEMENT_REFCOUNTING(ClientRequestContextHandler); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace | ||||||
|  |  | ||||||
| RootWindowManager::RootWindowManager(bool terminate_when_all_windows_closed) | RootWindowManager::RootWindowManager(bool terminate_when_all_windows_closed) | ||||||
|     : terminate_when_all_windows_closed_(terminate_when_all_windows_closed) { |     : terminate_when_all_windows_closed_(terminate_when_all_windows_closed) { | ||||||
|   CefRefPtr<CefCommandLine> command_line = |   CefRefPtr<CefCommandLine> command_line = | ||||||
| @@ -128,11 +154,17 @@ CefRefPtr<CefRequestContext> RootWindowManager::GetRequestContext( | |||||||
|       CefString(&settings.cache_path) = ss.str(); |       CefString(&settings.cache_path) = ss.str(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return CefRequestContext::CreateContext(settings, NULL); |     return CefRequestContext::CreateContext(settings, | ||||||
|  |                                             new ClientRequestContextHandler); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // All browsers will share the global request context. |   // All browsers will share the global request context. | ||||||
|   return NULL; |   if (!shared_request_context_.get()) { | ||||||
|  |     shared_request_context_ = | ||||||
|  |         CefRequestContext::CreateContext(CefRequestContext::GetGlobalContext(), | ||||||
|  |                                          new ClientRequestContextHandler); | ||||||
|  |   } | ||||||
|  |   return shared_request_context_; | ||||||
| } | } | ||||||
|  |  | ||||||
| void RootWindowManager::OnTest(RootWindow* root_window, int test_id) { | void RootWindowManager::OnTest(RootWindow* root_window, int test_id) { | ||||||
|   | |||||||
| @@ -80,6 +80,8 @@ class RootWindowManager : public RootWindow::Delegate { | |||||||
|   // Singleton window used as the temporary parent for popup browsers. |   // Singleton window used as the temporary parent for popup browsers. | ||||||
|   TempWindow temp_window_; |   TempWindow temp_window_; | ||||||
|  |  | ||||||
|  |   CefRefPtr<CefRequestContext> shared_request_context_; | ||||||
|  |  | ||||||
|   DISALLOW_COPY_AND_ASSIGN(RootWindowManager); |   DISALLOW_COPY_AND_ASSIGN(RootWindowManager); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,12 +9,11 @@ | |||||||
| namespace client { | namespace client { | ||||||
|  |  | ||||||
| ClientAppRenderer::ClientAppRenderer() { | ClientAppRenderer::ClientAppRenderer() { | ||||||
|  |   CreateDelegates(delegates_); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ClientAppRenderer::OnRenderThreadCreated( | void ClientAppRenderer::OnRenderThreadCreated( | ||||||
|     CefRefPtr<CefListValue> extra_info) { |     CefRefPtr<CefListValue> extra_info) { | ||||||
|   CreateDelegates(delegates_); |  | ||||||
|  |  | ||||||
|   DelegateSet::iterator it = delegates_.begin(); |   DelegateSet::iterator it = delegates_.begin(); | ||||||
|   for (; it != delegates_.end(); ++it) |   for (; it != delegates_.end(); ++it) | ||||||
|     (*it)->OnRenderThreadCreated(this, extra_info); |     (*it)->OnRenderThreadCreated(this, extra_info); | ||||||
|   | |||||||
| @@ -19,6 +19,11 @@ void CreateBrowserDelegates(ClientAppBrowser::DelegateSet& delegates) { | |||||||
|       ClientAppBrowser::DelegateSet& delegates); |       ClientAppBrowser::DelegateSet& delegates); | ||||||
|   CreateNavigationBrowserTests(delegates); |   CreateNavigationBrowserTests(delegates); | ||||||
|  |  | ||||||
|  |   // Bring in the plugin tests. | ||||||
|  |   extern void CreatePluginBrowserTests( | ||||||
|  |       ClientAppBrowser::DelegateSet& delegates); | ||||||
|  |   CreatePluginBrowserTests(delegates); | ||||||
|  |  | ||||||
|   // Bring in the RequestHandler tests. |   // Bring in the RequestHandler tests. | ||||||
|   extern void CreateRequestHandlerBrowserTests( |   extern void CreateRequestHandlerBrowserTests( | ||||||
|       ClientAppBrowser::DelegateSet& delegates); |       ClientAppBrowser::DelegateSet& delegates); | ||||||
|   | |||||||
| @@ -900,6 +900,8 @@ class CookieTestJSHandler : public TestHandler { | |||||||
|   TrackCallback got_load_end2_; |   TrackCallback got_load_end2_; | ||||||
|   TrackCallback got_cookie1_; |   TrackCallback got_cookie1_; | ||||||
|   TrackCallback got_cookie2_; |   TrackCallback got_cookie2_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(CookieTestJSHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
| @@ -1186,6 +1188,8 @@ class CookieTestSchemeHandler : public TestHandler { | |||||||
|   TrackCallback got_cookie1_; |   TrackCallback got_cookie1_; | ||||||
|   TrackCallback got_cookie2_; |   TrackCallback got_cookie2_; | ||||||
|   TrackCallback got_cookie3_; |   TrackCallback got_cookie3_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(CookieTestSchemeHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -145,6 +145,8 @@ class DialogTestHandler : public TestHandler { | |||||||
|  |  | ||||||
|   TrackCallback got_onfiledialog_; |   TrackCallback got_onfiledialog_; | ||||||
|   TrackCallback got_onfiledialogdismissed_; |   TrackCallback got_onfiledialogdismissed_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(DialogTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -104,6 +104,8 @@ class TitleTestHandler : public TestHandler { | |||||||
|   int step_; |   int step_; | ||||||
|  |  | ||||||
|   TrackCallback got_title_[5]; |   TrackCallback got_title_[5]; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(TitleTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -309,6 +309,8 @@ class TestDOMHandler : public TestHandler { | |||||||
|   DOMTestType test_type_; |   DOMTestType test_type_; | ||||||
|   TrackCallback got_message_; |   TrackCallback got_message_; | ||||||
|   TrackCallback got_success_; |   TrackCallback got_success_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(TestDOMHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -256,6 +256,8 @@ class DownloadTestHandler : public TestHandler { | |||||||
|   TrackCallback got_on_before_download_; |   TrackCallback got_on_before_download_; | ||||||
|   TrackCallback got_on_download_updated_; |   TrackCallback got_on_download_updated_; | ||||||
|   TrackCallback got_full_path_; |   TrackCallback got_full_path_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(DownloadTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -158,6 +158,8 @@ class DraggableRegionsTestHandler : public TestHandler { | |||||||
|   } step_; |   } step_; | ||||||
|  |  | ||||||
|   TrackCallback did_call_on_draggable_regions_changed_; |   TrackCallback did_call_on_draggable_regions_changed_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(DraggableRegionsTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -557,6 +557,8 @@ class FrameNavTestHandler : public TestHandler { | |||||||
|   TrackCallback got_destroyed_; |   TrackCallback got_destroyed_; | ||||||
|   scoped_ptr<FrameNavExpectationsFactoryBrowser> factory_; |   scoped_ptr<FrameNavExpectationsFactoryBrowser> factory_; | ||||||
|   scoped_ptr<FrameNavExpectationsBrowser> expectations_; |   scoped_ptr<FrameNavExpectationsBrowser> expectations_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(FrameNavTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Helper for defining frame tests. | // Helper for defining frame tests. | ||||||
|   | |||||||
| @@ -140,6 +140,8 @@ class GeolocationTestHandler : public TestHandler { | |||||||
|   TrackCallback got_allow_; |   TrackCallback got_allow_; | ||||||
|   TrackCallback got_cancel_; |   TrackCallback got_cancel_; | ||||||
|   TrackCallback got_deny_; |   TrackCallback got_deny_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(GeolocationTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -175,6 +175,8 @@ class JSDialogTestHandler : public TestHandler { | |||||||
|   TrackCallback got_onbeforeunloaddialog_; |   TrackCallback got_onbeforeunloaddialog_; | ||||||
|   TrackCallback got_onresetdialogstate_; |   TrackCallback got_onresetdialogstate_; | ||||||
|   TrackCallback got_onloadend_; |   TrackCallback got_onloadend_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(JSDialogTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
| @@ -168,6 +168,8 @@ class LifeSpanTestHandler : public RoutingTestHandler { | |||||||
|  |  | ||||||
|   // Forces the window to close (bypasses test conditions). |   // Forces the window to close (bypasses test conditions). | ||||||
|   bool executing_delay_close_; |   bool executing_delay_close_; | ||||||
|  |  | ||||||
|  |   IMPLEMENT_REFCOUNTING(LifeSpanTestHandler); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace | }  // namespace | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user