diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp')
-rw-r--r-- | Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp | 102 |
1 files changed, 102 insertions, 0 deletions
diff --git a/Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp b/Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp new file mode 100644 index 000000000..4eefc8691 --- /dev/null +++ b/Source/WebCore/bindings/js/JSDOMBindingSecurity.cpp @@ -0,0 +1,102 @@ +/* + * Copyright (C) 1999-2001 Harri Porten (porten@kde.org) + * Copyright (C) 2004-2011, 2013, 2016 Apple Inc. All rights reserved. + * Copyright (C) 2007 Samuel Weinig <sam@webkit.org> + * Copyright (C) 2013 Michael Pruett <michael@68k.org> + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + */ + +#include "config.h" +#include "JSDOMBindingSecurity.h" + +#include "DOMWindow.h" +#include "Document.h" +#include "Frame.h" +#include "JSDOMExceptionHandling.h" +#include "JSDOMWindowBase.h" +#include "SecurityOrigin.h" +#include <wtf/text/WTFString.h> + +using namespace JSC; + +namespace WebCore { + +void printErrorMessageForFrame(Frame* frame, const String& message) +{ + if (!frame) + return; + frame->document()->domWindow()->printErrorMessage(message); +} + +static inline bool canAccessDocument(JSC::ExecState* state, Document* targetDocument, SecurityReportingOption reportingOption) +{ + VM& vm = state->vm(); + auto scope = DECLARE_THROW_SCOPE(vm); + + if (!targetDocument) + return false; + + DOMWindow& active = activeDOMWindow(state); + + if (active.document()->securityOrigin().canAccess(targetDocument->securityOrigin())) + return true; + + switch (reportingOption) { + case ThrowSecurityError: + throwSecurityError(*state, scope, targetDocument->domWindow()->crossDomainAccessErrorMessage(active)); + break; + case LogSecurityError: + printErrorMessageForFrame(targetDocument->frame(), targetDocument->domWindow()->crossDomainAccessErrorMessage(active)); + break; + case DoNotReportSecurityError: + break; + } + + return false; +} + +bool BindingSecurity::shouldAllowAccessToFrame(ExecState& state, Frame& frame, String& message) +{ + if (BindingSecurity::shouldAllowAccessToFrame(&state, &frame, DoNotReportSecurityError)) + return true; + message = frame.document()->domWindow()->crossDomainAccessErrorMessage(activeDOMWindow(&state)); + return false; +} + +bool BindingSecurity::shouldAllowAccessToDOMWindow(ExecState& state, DOMWindow& globalObject, String& message) +{ + if (BindingSecurity::shouldAllowAccessToDOMWindow(&state, globalObject, DoNotReportSecurityError)) + return true; + message = globalObject.crossDomainAccessErrorMessage(activeDOMWindow(&state)); + return false; +} + +bool BindingSecurity::shouldAllowAccessToDOMWindow(JSC::ExecState* state, DOMWindow& target, SecurityReportingOption reportingOption) +{ + return canAccessDocument(state, target.document(), reportingOption); +} + +bool BindingSecurity::shouldAllowAccessToFrame(JSC::ExecState* state, Frame* target, SecurityReportingOption reportingOption) +{ + return target && canAccessDocument(state, target->document(), reportingOption); +} + +bool BindingSecurity::shouldAllowAccessToNode(JSC::ExecState& state, Node* target) +{ + return !target || canAccessDocument(&state, &target->document(), LogSecurityError); +} + +} // namespace WebCore |