summaryrefslogtreecommitdiff
path: root/Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp
diff options
context:
space:
mode:
authorKonstantin Tokarev <annulen@yandex.ru>2016-08-25 19:20:41 +0300
committerKonstantin Tokarev <annulen@yandex.ru>2017-02-02 12:30:55 +0000
commit6882a04fb36642862b11efe514251d32070c3d65 (patch)
treeb7959826000b061fd5ccc7512035c7478742f7b0 /Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp
parentab6df191029eeeb0b0f16f127d553265659f739e (diff)
downloadqtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp')
-rw-r--r--Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp217
1 files changed, 217 insertions, 0 deletions
diff --git a/Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp b/Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp
new file mode 100644
index 000000000..67a5422a4
--- /dev/null
+++ b/Source/WebKit2/WebProcess/UserContent/WebUserContentController.cpp
@@ -0,0 +1,217 @@
+/*
+ * Copyright (C) 2014 Apple 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:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. 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.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS 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 APPLE INC. OR ITS 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 "WebUserContentController.h"
+
+#include "DataReference.h"
+#include "WebCompiledContentExtension.h"
+#include "WebFrame.h"
+#include "WebPage.h"
+#include "WebProcess.h"
+#include "WebUserContentControllerMessages.h"
+#include "WebUserContentControllerProxyMessages.h"
+#include <WebCore/DOMWrapperWorld.h>
+#include <WebCore/ScriptController.h>
+#include <WebCore/SecurityOriginData.h>
+#include <WebCore/SerializedScriptValue.h>
+#include <WebCore/UserStyleSheet.h>
+#include <wtf/NeverDestroyed.h>
+
+#if ENABLE(USER_MESSAGE_HANDLERS)
+#include <WebCore/UserMessageHandler.h>
+#include <WebCore/UserMessageHandlerDescriptor.h>
+#endif
+
+using namespace WebCore;
+
+namespace WebKit {
+
+static HashMap<uint64_t, WebUserContentController*>& userContentControllers()
+{
+ static NeverDestroyed<HashMap<uint64_t, WebUserContentController*>> userContentControllers;
+
+ return userContentControllers;
+}
+
+PassRefPtr<WebUserContentController> WebUserContentController::getOrCreate(uint64_t identifier)
+{
+ auto& userContentControllerPtr = userContentControllers().add(identifier, nullptr).iterator->value;
+ if (userContentControllerPtr)
+ return userContentControllerPtr;
+
+ RefPtr<WebUserContentController> userContentController = adoptRef(new WebUserContentController(identifier));
+ userContentControllerPtr = userContentController.get();
+
+ return userContentController.release();
+}
+
+WebUserContentController::WebUserContentController(uint64_t identifier)
+ : m_identifier(identifier)
+ , m_userContentController(UserContentController::create())
+{
+ WebProcess::singleton().addMessageReceiver(Messages::WebUserContentController::messageReceiverName(), m_identifier, *this);
+}
+
+WebUserContentController::~WebUserContentController()
+{
+ ASSERT(userContentControllers().contains(m_identifier));
+
+ WebProcess::singleton().removeMessageReceiver(Messages::WebUserContentController::messageReceiverName(), m_identifier);
+
+ userContentControllers().remove(m_identifier);
+}
+
+void WebUserContentController::addUserScripts(const Vector<WebCore::UserScript>& userScripts)
+{
+ for (const auto& userScript : userScripts)
+ m_userContentController->addUserScript(mainThreadNormalWorld(), std::make_unique<WebCore::UserScript>(userScript));
+}
+
+void WebUserContentController::removeUserScript(const String& urlString)
+{
+ m_userContentController->removeUserScript(mainThreadNormalWorld(), URL(URL(), urlString));
+}
+
+void WebUserContentController::removeAllUserScripts()
+{
+ m_userContentController->removeUserScripts(mainThreadNormalWorld());
+}
+
+void WebUserContentController::addUserStyleSheets(const Vector<WebCore::UserStyleSheet>& userStyleSheets)
+{
+ for (const auto& userStyleSheet : userStyleSheets) {
+ m_userContentController->addUserStyleSheet(mainThreadNormalWorld(),
+ std::make_unique<WebCore::UserStyleSheet>(userStyleSheet), InjectInExistingDocuments);
+ }
+}
+
+void WebUserContentController::removeUserStyleSheet(const String& urlString)
+{
+ m_userContentController->removeUserStyleSheet(mainThreadNormalWorld(), URL(URL(), urlString));
+}
+
+void WebUserContentController::removeAllUserStyleSheets()
+{
+ m_userContentController->removeUserStyleSheets(mainThreadNormalWorld());
+}
+
+#if ENABLE(USER_MESSAGE_HANDLERS)
+class WebUserMessageHandlerDescriptorProxy : public RefCounted<WebUserMessageHandlerDescriptorProxy>, public WebCore::UserMessageHandlerDescriptor::Client {
+public:
+ static PassRefPtr<WebUserMessageHandlerDescriptorProxy> create(WebUserContentController* controller, const String& name, uint64_t identifier)
+ {
+ return adoptRef(new WebUserMessageHandlerDescriptorProxy(controller, name, identifier));
+ }
+
+ virtual ~WebUserMessageHandlerDescriptorProxy()
+ {
+ m_descriptor->invalidateClient();
+ }
+
+ // WebCore::UserMessageHandlerDescriptor::Client
+ virtual void didPostMessage(WebCore::UserMessageHandler& handler, WebCore::SerializedScriptValue* value)
+ {
+ WebCore::Frame* frame = handler.frame();
+ if (!frame)
+ return;
+
+ WebFrame* webFrame = WebFrame::fromCoreFrame(*frame);
+ if (!webFrame)
+ return;
+
+ WebPage* webPage = webFrame->page();
+ if (!webPage)
+ return;
+
+ WebProcess::singleton().parentProcessConnection()->send(Messages::WebUserContentControllerProxy::DidPostMessage(webPage->pageID(), webFrame->frameID(), SecurityOriginData::fromFrame(frame), m_identifier, IPC::DataReference(value->data())), m_controller->identifier());
+ }
+
+ WebCore::UserMessageHandlerDescriptor& descriptor() { return *m_descriptor; }
+ uint64_t identifier() { return m_identifier; }
+
+private:
+ WebUserMessageHandlerDescriptorProxy(WebUserContentController* controller, const String& name, uint64_t identifier)
+ : m_controller(controller)
+ , m_descriptor(UserMessageHandlerDescriptor::create(name, mainThreadNormalWorld(), *this))
+ , m_identifier(identifier)
+ {
+ }
+
+ RefPtr<WebUserContentController> m_controller;
+ RefPtr<WebCore::UserMessageHandlerDescriptor> m_descriptor;
+ uint64_t m_identifier;
+};
+#endif
+
+void WebUserContentController::addUserScriptMessageHandlers(const Vector<WebScriptMessageHandlerHandle>& scriptMessageHandlers)
+{
+#if ENABLE(USER_MESSAGE_HANDLERS)
+ for (auto& handle : scriptMessageHandlers) {
+ RefPtr<WebUserMessageHandlerDescriptorProxy> descriptor = WebUserMessageHandlerDescriptorProxy::create(this, handle.name, handle.identifier);
+
+ m_userMessageHandlerDescriptors.add(descriptor->identifier(), descriptor);
+ m_userContentController->addUserMessageHandlerDescriptor(descriptor->descriptor());
+ }
+#else
+ UNUSED_PARAM(scriptMessageHandlers);
+#endif
+}
+
+void WebUserContentController::removeUserScriptMessageHandler(uint64_t identifier)
+{
+#if ENABLE(USER_MESSAGE_HANDLERS)
+ auto it = m_userMessageHandlerDescriptors.find(identifier);
+ ASSERT(it != m_userMessageHandlerDescriptors.end());
+
+ m_userContentController->removeUserMessageHandlerDescriptor(it->value->descriptor());
+ m_userMessageHandlerDescriptors.remove(it);
+#else
+ UNUSED_PARAM(identifier);
+#endif
+}
+
+#if ENABLE(CONTENT_EXTENSIONS)
+void WebUserContentController::addUserContentExtensions(const Vector<std::pair<String, WebCompiledContentExtensionData>>& userContentExtensions)
+{
+ for (const auto& userContentExtension : userContentExtensions) {
+ WebCompiledContentExtensionData contentExtensionData = userContentExtension.second;
+ RefPtr<WebCompiledContentExtension> compiledContentExtension = WebCompiledContentExtension::create(WTFMove(contentExtensionData));
+ m_userContentController->addUserContentExtension(userContentExtension.first, compiledContentExtension);
+ }
+}
+
+void WebUserContentController::removeUserContentExtension(const String& name)
+{
+ m_userContentController->removeUserContentExtension(name);
+}
+
+void WebUserContentController::removeAllUserContentExtensions()
+{
+ m_userContentController->removeAllUserContentExtensions();
+}
+#endif
+
+} // namespace WebKit