Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "extensions/renderer/script_context.h" | 5 #include "extensions/renderer/script_context.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
| 9 #include "base/strings/string_split.h" | 9 #include "base/strings/string_split.h" |
| 10 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 26 #include "third_party/WebKit/public/web/WebView.h" | 26 #include "third_party/WebKit/public/web/WebView.h" |
| 27 #include "v8/include/v8.h" | 27 #include "v8/include/v8.h" |
| 28 | 28 |
| 29 using content::V8ValueConverter; | 29 using content::V8ValueConverter; |
| 30 | 30 |
| 31 namespace extensions { | 31 namespace extensions { |
| 32 | 32 |
| 33 ScriptContext::ScriptContext(const v8::Handle<v8::Context>& v8_context, | 33 ScriptContext::ScriptContext(const v8::Handle<v8::Context>& v8_context, |
| 34 blink::WebFrame* web_frame, | 34 blink::WebFrame* web_frame, |
| 35 const Extension* extension, | 35 const Extension* extension, |
| 36 Feature::Context context_type) | 36 Feature::Context context_type, |
| 37 const Extension* effective_extension, | |
| 38 Feature::Context effective_context_type) | |
| 37 : v8_context_(v8_context), | 39 : v8_context_(v8_context), |
| 38 web_frame_(web_frame), | 40 web_frame_(web_frame), |
| 39 extension_(extension), | 41 extension_(extension), |
| 40 context_type_(context_type), | 42 context_type_(context_type), |
| 43 effective_extension_(effective_extension), | |
| 44 effective_context_type_(effective_context_type), | |
| 41 safe_builtins_(this), | 45 safe_builtins_(this), |
| 42 isolate_(v8_context->GetIsolate()) { | 46 isolate_(v8_context->GetIsolate()) { |
| 43 VLOG(1) << "Created context:\n" | 47 VLOG(1) << "Created context:\n" |
| 44 << " extension id: " << GetExtensionID() << "\n" | 48 << " extension id: " << GetExtensionID() << "\n" |
| 45 << " frame: " << web_frame_ << "\n" | 49 << " frame: " << web_frame_ << "\n" |
| 46 << " URL: " << GetURL() << "\n" | 50 << " URL: " << GetURL() << "\n" |
| 47 << " context type: " << GetContextTypeDescription(); | 51 << " context type: " << GetContextTypeDescription() << "\n" |
| 52 << " effective extension id: " << GetEffectiveExtensionID() << "\n" | |
| 53 << " effective context type: " | |
| 54 << GetEffectiveContextTypeDescription(); | |
| 48 gin::PerContextData::From(v8_context)->set_runner(this); | 55 gin::PerContextData::From(v8_context)->set_runner(this); |
| 49 } | 56 } |
| 50 | 57 |
| 51 ScriptContext::~ScriptContext() { | 58 ScriptContext::~ScriptContext() { |
| 52 VLOG(1) << "Destroyed context for extension\n" | 59 VLOG(1) << "Destroyed context for extension\n" |
| 53 << " extension id: " << GetExtensionID(); | 60 << " extension id: " << GetExtensionID() << "\n" |
| 61 << " effective extension id: " << GetEffectiveExtensionID(); | |
| 54 Invalidate(); | 62 Invalidate(); |
| 55 } | 63 } |
| 56 | 64 |
| 57 void ScriptContext::Invalidate() { | 65 void ScriptContext::Invalidate() { |
| 58 if (!is_valid()) | 66 if (!is_valid()) |
| 59 return; | 67 return; |
| 60 if (module_system_) | 68 if (module_system_) |
| 61 module_system_->Invalidate(); | 69 module_system_->Invalidate(); |
| 62 web_frame_ = NULL; | 70 web_frame_ = NULL; |
| 63 v8_context_.reset(); | 71 v8_context_.reset(); |
| 64 } | 72 } |
| 65 | 73 |
| 66 const std::string& ScriptContext::GetExtensionID() const { | 74 const std::string& ScriptContext::GetExtensionID() const { |
| 67 return extension_.get() ? extension_->id() : base::EmptyString(); | 75 return extension_.get() ? extension_->id() : base::EmptyString(); |
| 68 } | 76 } |
| 69 | 77 |
| 78 const std::string& ScriptContext::GetEffectiveExtensionID() const { | |
| 79 return effective_extension_.get() ? effective_extension_->id() | |
| 80 : base::EmptyString(); | |
| 81 } | |
| 82 | |
| 70 content::RenderView* ScriptContext::GetRenderView() const { | 83 content::RenderView* ScriptContext::GetRenderView() const { |
| 71 if (web_frame_ && web_frame_->view()) | 84 if (web_frame_ && web_frame_->view()) |
| 72 return content::RenderView::FromWebView(web_frame_->view()); | 85 return content::RenderView::FromWebView(web_frame_->view()); |
| 73 return NULL; | 86 return NULL; |
| 74 } | 87 } |
| 75 | 88 |
| 76 content::RenderFrame* ScriptContext::GetRenderFrame() const { | 89 content::RenderFrame* ScriptContext::GetRenderFrame() const { |
| 77 if (web_frame_) | 90 if (web_frame_) |
| 78 return content::RenderFrame::FromWebFrame(web_frame_); | 91 return content::RenderFrame::FromWebFrame(web_frame_); |
| 79 return NULL; | 92 return NULL; |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 125 module_system_->CallModuleMethod( | 138 module_system_->CallModuleMethod( |
| 126 kEventBindings, "dispatchEvent", arraysize(argv), argv); | 139 kEventBindings, "dispatchEvent", arraysize(argv), argv); |
| 127 } | 140 } |
| 128 | 141 |
| 129 void ScriptContext::DispatchOnUnloadEvent() { | 142 void ScriptContext::DispatchOnUnloadEvent() { |
| 130 v8::HandleScope handle_scope(isolate()); | 143 v8::HandleScope handle_scope(isolate()); |
| 131 v8::Context::Scope context_scope(v8_context()); | 144 v8::Context::Scope context_scope(v8_context()); |
| 132 module_system_->CallModuleMethod("unload_event", "dispatch"); | 145 module_system_->CallModuleMethod("unload_event", "dispatch"); |
| 133 } | 146 } |
| 134 | 147 |
| 135 std::string ScriptContext::GetContextTypeDescription() { | 148 // static |
| 136 switch (context_type_) { | 149 std::string ScriptContext::GetContextTypeDescription( |
|
Devlin
2014/09/03 22:09:16
Unless this is used elsewhere, I'd probably move i
Marijn Kruisselbrink
2014/09/03 23:54:07
Done.
| |
| 150 Feature::Context context_type) { | |
| 151 switch (context_type) { | |
| 137 case Feature::UNSPECIFIED_CONTEXT: | 152 case Feature::UNSPECIFIED_CONTEXT: |
| 138 return "UNSPECIFIED"; | 153 return "UNSPECIFIED"; |
| 139 case Feature::BLESSED_EXTENSION_CONTEXT: | 154 case Feature::BLESSED_EXTENSION_CONTEXT: |
| 140 return "BLESSED_EXTENSION"; | 155 return "BLESSED_EXTENSION"; |
| 141 case Feature::UNBLESSED_EXTENSION_CONTEXT: | 156 case Feature::UNBLESSED_EXTENSION_CONTEXT: |
| 142 return "UNBLESSED_EXTENSION"; | 157 return "UNBLESSED_EXTENSION"; |
| 143 case Feature::CONTENT_SCRIPT_CONTEXT: | 158 case Feature::CONTENT_SCRIPT_CONTEXT: |
| 144 return "CONTENT_SCRIPT"; | 159 return "CONTENT_SCRIPT"; |
| 145 case Feature::WEB_PAGE_CONTEXT: | 160 case Feature::WEB_PAGE_CONTEXT: |
| 146 return "WEB_PAGE"; | 161 return "WEB_PAGE"; |
| 147 case Feature::BLESSED_WEB_PAGE_CONTEXT: | 162 case Feature::BLESSED_WEB_PAGE_CONTEXT: |
| 148 return "BLESSED_WEB_PAGE"; | 163 return "BLESSED_WEB_PAGE"; |
| 149 case Feature::WEBUI_CONTEXT: | 164 case Feature::WEBUI_CONTEXT: |
| 150 return "WEBUI"; | 165 return "WEBUI"; |
| 151 } | 166 } |
| 152 NOTREACHED(); | 167 NOTREACHED(); |
| 153 return std::string(); | 168 return std::string(); |
| 154 } | 169 } |
| 155 | 170 |
| 171 std::string ScriptContext::GetContextTypeDescription() { | |
| 172 return GetContextTypeDescription(context_type_); | |
| 173 } | |
| 174 | |
| 175 std::string ScriptContext::GetEffectiveContextTypeDescription() { | |
| 176 return GetContextTypeDescription(effective_context_type_); | |
| 177 } | |
| 178 | |
| 156 GURL ScriptContext::GetURL() const { | 179 GURL ScriptContext::GetURL() const { |
| 157 return web_frame() ? GetDataSourceURLForFrame(web_frame()) : GURL(); | 180 return web_frame() ? GetDataSourceURLForFrame(web_frame()) : GURL(); |
| 158 } | 181 } |
| 159 | 182 |
| 160 bool ScriptContext::IsAnyFeatureAvailableToContext(const Feature& api) { | 183 bool ScriptContext::IsAnyFeatureAvailableToContext(const Feature& api) { |
| 161 return ExtensionAPI::GetSharedInstance()->IsAnyFeatureAvailableToContext( | 184 return ExtensionAPI::GetSharedInstance()->IsAnyFeatureAvailableToContext( |
| 162 api, extension(), context_type(), GetDataSourceURLForFrame(web_frame())); | 185 api, extension(), context_type(), GetDataSourceURLForFrame(web_frame())); |
| 163 } | 186 } |
| 164 | 187 |
| 165 // static | 188 // static |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 244 v8::Handle<v8::Value> argv[]) { | 267 v8::Handle<v8::Value> argv[]) { |
| 245 return CallFunction(function, argc, argv); | 268 return CallFunction(function, argc, argv); |
| 246 } | 269 } |
| 247 | 270 |
| 248 gin::ContextHolder* ScriptContext::GetContextHolder() { | 271 gin::ContextHolder* ScriptContext::GetContextHolder() { |
| 249 v8::HandleScope handle_scope(isolate()); | 272 v8::HandleScope handle_scope(isolate()); |
| 250 return gin::PerContextData::From(v8_context())->context_holder(); | 273 return gin::PerContextData::From(v8_context())->context_holder(); |
| 251 } | 274 } |
| 252 | 275 |
| 253 } // namespace extensions | 276 } // namespace extensions |
| OLD | NEW |