diff options
| author | Steve Block <steveblock@google.com> | 2011-05-06 11:45:16 +0100 |
|---|---|---|
| committer | Steve Block <steveblock@google.com> | 2011-05-12 13:44:10 +0100 |
| commit | cad810f21b803229eb11403f9209855525a25d57 (patch) | |
| tree | 29a6fd0279be608e0fe9ffe9841f722f0f4e4269 /Source/WebCore/bindings/v8/specialization | |
| parent | 121b0cf4517156d0ac5111caf9830c51b69bae8f (diff) | |
| download | external_webkit-cad810f21b803229eb11403f9209855525a25d57.zip external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.gz external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.bz2 | |
Merge WebKit at r75315: Initial merge by git.
Change-Id: I570314b346ce101c935ed22a626b48c2af266b84
Diffstat (limited to 'Source/WebCore/bindings/v8/specialization')
| -rw-r--r-- | Source/WebCore/bindings/v8/specialization/V8BindingState.cpp | 97 | ||||
| -rw-r--r-- | Source/WebCore/bindings/v8/specialization/V8BindingState.h | 72 |
2 files changed, 169 insertions, 0 deletions
diff --git a/Source/WebCore/bindings/v8/specialization/V8BindingState.cpp b/Source/WebCore/bindings/v8/specialization/V8BindingState.cpp new file mode 100644 index 0000000..891272c --- /dev/null +++ b/Source/WebCore/bindings/v8/specialization/V8BindingState.cpp @@ -0,0 +1,97 @@ +/* + * Copyright (C) 2009 Google Inc. 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 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. + */ + +#include "config.h" +#include "V8BindingState.h" + +#include "Frame.h" +#include "ScriptController.h" +#include "V8Proxy.h" +#include <wtf/StdLibExtras.h> + +namespace WebCore { + +State<V8Binding>* State<V8Binding>::Only() +{ + DEFINE_STATIC_LOCAL(State, globalV8BindingState, ()); + return &globalV8BindingState; +} + +DOMWindow* State<V8Binding>::activeWindow() +{ + v8::Local<v8::Context> activeContext = v8::Context::GetCalling(); + if (activeContext.IsEmpty()) { + // There is a single activation record on the stack, so that must + // be the activeContext. + activeContext = v8::Context::GetCurrent(); + } + return V8Proxy::retrieveWindow(activeContext); +} + +DOMWindow* State<V8Binding>::firstWindow() +{ + return V8Proxy::retrieveWindow(v8::Context::GetEntered()); +} + +Frame* State<V8Binding>::activeFrame() +{ + Frame* frame = V8Proxy::retrieveFrameForCallingContext(); + if (!frame) { + // Unfortunately, when processing script from a plug-in, we might not + // have a calling context. In those cases, we fall back to the + // entered context for security checks. + // FIXME: We need a better API for retrieving frames that abstracts + // away this concern. + frame = V8Proxy::retrieveFrameForEnteredContext(); + } + return frame; +} + +Frame* State<V8Binding>::firstFrame() +{ + return V8Proxy::retrieveFrameForEnteredContext(); +} + +void State<V8Binding>::immediatelyReportUnsafeAccessTo(Frame* target) +{ + V8Proxy::reportUnsafeAccessTo(target, V8Proxy::ReportNow); +} + +bool State<V8Binding>::processingUserGesture() +{ + return ScriptController::processingUserGesture(); +} + +bool State<V8Binding>::allowsAccessFromFrame(Frame* frame) +{ + return ScriptController::isSafeScript(frame); +} + +} // namespace WebCore diff --git a/Source/WebCore/bindings/v8/specialization/V8BindingState.h b/Source/WebCore/bindings/v8/specialization/V8BindingState.h new file mode 100644 index 0000000..c472484 --- /dev/null +++ b/Source/WebCore/bindings/v8/specialization/V8BindingState.h @@ -0,0 +1,72 @@ +/* + * Copyright (C) 2009 Google Inc. 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 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. + */ + +#ifndef V8BindingState_h +#define V8BindingState_h + +#include "GenericBinding.h" +#include "V8Binding.h" + +namespace WebCore { + +class Frame; + +// Singleton implementation of State<V8Binding>. Uses V8's global data +// structures to return information about relevant execution state. +template <> +class State<V8Binding> : public State<GenericBinding> { +public: + // Singleton + static State* Only(); + + // Reports an error message (without delay) if the security check fails. + static void immediatelyReportUnsafeAccessTo(Frame*); + + DOMWindow* activeWindow(); + DOMWindow* firstWindow(); + + Frame* activeFrame(); + Frame* firstFrame(); + + bool processingUserGesture(); + + // FIXME: This should be shared in BindingSecurity + bool allowsAccessFromFrame(Frame*); + +private: + explicit State() {} + ~State(); +}; + +typedef State<V8Binding> V8BindingState; + +} + +#endif // V8BindingState_h |
