/* * Copyright (C) 2010-2016 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 "InjectedBundle.h" #include "APIArray.h" #include "APIData.h" #include "InjectedBundleScriptWorld.h" #include "NotificationPermissionRequestManager.h" #include "SessionTracker.h" #include "UserData.h" #include "WKAPICast.h" #include "WKBundleAPICast.h" #include "WebConnectionToUIProcess.h" #include "WebCookieManager.h" #include "WebCoreArgumentCoders.h" #include "WebFrame.h" #include "WebFrameNetworkingContext.h" #include "WebPage.h" #include "WebPageGroupProxy.h" #include "WebPreferencesKeys.h" #include "WebPreferencesStore.h" #include "WebProcess.h" #include "WebProcessCreationParameters.h" #include "WebProcessMessages.h" #include "WebProcessPoolMessages.h" #include "WebUserContentController.h" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #if ENABLE(NOTIFICATIONS) || ENABLE(LEGACY_NOTIFICATIONS) #include "WebNotificationManager.h" #endif using namespace WebCore; using namespace JSC; namespace WebKit { PassRefPtr InjectedBundle::create(const WebProcessCreationParameters& parameters, API::Object* initializationUserData) { auto bundle = adoptRef(*new InjectedBundle(parameters)); bundle->m_sandboxExtension = SandboxExtension::create(parameters.injectedBundlePathExtensionHandle); if (!bundle->initialize(parameters, initializationUserData)) return nullptr; return WTFMove(bundle); } InjectedBundle::InjectedBundle(const WebProcessCreationParameters& parameters) : m_path(parameters.injectedBundlePath) , m_platformBundle(0) { } InjectedBundle::~InjectedBundle() { } void InjectedBundle::initializeClient(const WKBundleClientBase* client) { m_client.initialize(client); } void InjectedBundle::postMessage(const String& messageName, API::Object* messageBody) { auto& webProcess = WebProcess::singleton(); webProcess.parentProcessConnection()->send(Messages::WebProcessPool::HandleMessage(messageName, UserData(webProcess.transformObjectsToHandles(messageBody))), 0); } void InjectedBundle::postSynchronousMessage(const String& messageName, API::Object* messageBody, RefPtr& returnData) { UserData returnUserData; auto& webProcess = WebProcess::singleton(); if (!webProcess.parentProcessConnection()->sendSync(Messages::WebProcessPool::HandleSynchronousMessage(messageName, UserData(webProcess.transformObjectsToHandles(messageBody))), Messages::WebProcessPool::HandleSynchronousMessage::Reply(returnUserData), 0)) returnData = nullptr; else returnData = webProcess.transformHandlesToObjects(returnUserData.object()); } WebConnection* InjectedBundle::webConnectionToUIProcess() const { return WebProcess::singleton().webConnectionToUIProcess(); } void InjectedBundle::overrideBoolPreferenceForTestRunner(WebPageGroupProxy* pageGroup, const String& preference, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); if (preference == "WebKitTabToLinksPreferenceKey") { WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::tabsToLinksKey(), enabled); for (auto* page : pages) WebPage::fromCorePage(page)->setTabToLinksEnabled(enabled); } if (preference == "WebKit2AsynchronousPluginInitializationEnabled") { WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::asynchronousPluginInitializationEnabledKey(), enabled); for (auto* page : pages) WebPage::fromCorePage(page)->setAsynchronousPluginInitializationEnabled(enabled); } if (preference == "WebKit2AsynchronousPluginInitializationEnabledForAllPlugins") { WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::asynchronousPluginInitializationEnabledForAllPluginsKey(), enabled); for (auto* page : pages) WebPage::fromCorePage(page)->setAsynchronousPluginInitializationEnabledForAllPlugins(enabled); } if (preference == "WebKit2ArtificialPluginInitializationDelayEnabled") { WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::artificialPluginInitializationDelayEnabledKey(), enabled); for (auto* page : pages) WebPage::fromCorePage(page)->setArtificialPluginInitializationDelayEnabled(enabled); } #if ENABLE(SERVICE_CONTROLS) if (preference == "WebKitImageControlsEnabled") { WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::imageControlsEnabledKey(), enabled); for (auto* page : pages) page->settings().setImageControlsEnabled(enabled); return; } #endif #if ENABLE(CSS_ANIMATIONS_LEVEL_2) if (preference == "WebKitCSSAnimationTriggersEnabled") RuntimeEnabledFeatures::sharedFeatures().setAnimationTriggersEnabled(enabled); #endif #if ENABLE(WEB_ANIMATIONS) if (preference == "WebKitWebAnimationsEnabled") RuntimeEnabledFeatures::sharedFeatures().setWebAnimationsEnabled(enabled); #endif #if ENABLE(FETCH_API) if (preference == "WebKitFetchAPIEnabled") RuntimeEnabledFeatures::sharedFeatures().setFetchAPIEnabled(enabled); #endif #if ENABLE(DOWNLOAD_ATTRIBUTE) if (preference == "WebKitDownloadAttributeEnabled") RuntimeEnabledFeatures::sharedFeatures().setDownloadAttributeEnabled(enabled); #endif if (preference == "WebKitShadowDOMEnabled") RuntimeEnabledFeatures::sharedFeatures().setShadowDOMEnabled(enabled); if (preference == "WebKitCSSGridLayoutEnabled") RuntimeEnabledFeatures::sharedFeatures().setCSSGridLayoutEnabled(enabled); if (preference == "WebKitCustomElementsEnabled") RuntimeEnabledFeatures::sharedFeatures().setCustomElementsEnabled(enabled); if (preference == "WebKitInteractiveFormValidationEnabled") RuntimeEnabledFeatures::sharedFeatures().setInteractiveFormValidationEnabled(enabled); #if ENABLE(WEBGL2) if (preference == "WebKitWebGL2Enabled") RuntimeEnabledFeatures::sharedFeatures().setWebGL2Enabled(enabled); #endif if (preference == "WebKitModernMediaControlsEnabled") RuntimeEnabledFeatures::sharedFeatures().setModernMediaControlsEnabled(enabled); #if ENABLE(ENCRYPTED_MEDIA) if (preference == "WebKitEncryptedMediaAPIEnabled") RuntimeEnabledFeatures::sharedFeatures().setEncryptedMediaAPIEnabled(enabled); #endif #if ENABLE(SUBTLE_CRYPTO) if (preference == "WebKitSubtleCryptoEnabled") RuntimeEnabledFeatures::sharedFeatures().setSubtleCryptoEnabled(enabled); #endif #if ENABLE(MEDIA_STREAM) if (preference == "WebKitMediaStreamEnabled") RuntimeEnabledFeatures::sharedFeatures().setMediaStreamEnabled(enabled); #endif #if ENABLE(WEB_RTC) if (preference == "WebKitPeerConnectionEnabled") RuntimeEnabledFeatures::sharedFeatures().setPeerConnectionEnabled(enabled); #endif // Map the names used in LayoutTests with the names used in WebCore::Settings and WebPreferencesStore. #define FOR_EACH_OVERRIDE_BOOL_PREFERENCE(macro) \ macro(WebKitAcceleratedCompositingEnabled, AcceleratedCompositingEnabled, acceleratedCompositingEnabled) \ macro(WebKitCanvasUsesAcceleratedDrawing, CanvasUsesAcceleratedDrawing, canvasUsesAcceleratedDrawing) \ macro(WebKitFrameFlatteningEnabled, FrameFlatteningEnabled, frameFlatteningEnabled) \ macro(WebKitJavaEnabled, JavaEnabled, javaEnabled) \ macro(WebKitJavaScriptEnabled, ScriptEnabled, javaScriptEnabled) \ macro(WebKitLoadSiteIconsKey, LoadsSiteIconsIgnoringImageLoadingSetting, loadsSiteIconsIgnoringImageLoadingPreference) \ macro(WebKitOfflineWebApplicationCacheEnabled, OfflineWebApplicationCacheEnabled, offlineWebApplicationCacheEnabled) \ macro(WebKitPageCacheSupportsPluginsPreferenceKey, PageCacheSupportsPlugins, pageCacheSupportsPlugins) \ macro(WebKitPluginsEnabled, PluginsEnabled, pluginsEnabled) \ macro(WebKitUsesPageCachePreferenceKey, UsesPageCache, usesPageCache) \ macro(WebKitWebAudioEnabled, WebAudioEnabled, webAudioEnabled) \ macro(WebKitWebGLEnabled, WebGLEnabled, webGLEnabled) \ macro(WebKitXSSAuditorEnabled, XSSAuditorEnabled, xssAuditorEnabled) \ macro(WebKitShouldRespectImageOrientation, ShouldRespectImageOrientation, shouldRespectImageOrientation) \ macro(WebKitEnableCaretBrowsing, CaretBrowsingEnabled, caretBrowsingEnabled) \ macro(WebKitDisplayImagesKey, LoadsImagesAutomatically, loadsImagesAutomatically) \ macro(WebKitHTTPEquivEnabled, HttpEquivEnabled, httpEquivEnabled) \ macro(WebKitVisualViewportEnabled, VisualViewportEnabled, visualViewportEnabled) \ macro(WebKitLargeImageAsyncDecodingEnabled, LargeImageAsyncDecodingEnabled, largeImageAsyncDecodingEnabled) \ macro(WebKitAnimatedImageAsyncDecodingEnabled, AnimatedImageAsyncDecodingEnabled, animatedImageAsyncDecodingEnabled) \ \ #define OVERRIDE_PREFERENCE_AND_SET_IN_EXISTING_PAGES(TestRunnerName, SettingsName, WebPreferencesName) \ if (preference == #TestRunnerName) { \ WebPreferencesStore::overrideBoolValueForKey(WebPreferencesKey::WebPreferencesName##Key(), enabled); \ for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) \ (*iter)->settings().set##SettingsName(enabled); \ return; \ } FOR_EACH_OVERRIDE_BOOL_PREFERENCE(OVERRIDE_PREFERENCE_AND_SET_IN_EXISTING_PAGES) OVERRIDE_PREFERENCE_AND_SET_IN_EXISTING_PAGES(WebKitHiddenPageDOMTimerThrottlingEnabled, HiddenPageDOMTimerThrottlingEnabled, hiddenPageDOMTimerThrottlingEnabled) #undef OVERRIDE_PREFERENCE_AND_SET_IN_EXISTING_PAGES #undef FOR_EACH_OVERRIDE_BOOL_PREFERENCE } void InjectedBundle::setAllowUniversalAccessFromFileURLs(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setAllowUniversalAccessFromFileURLs(enabled); } void InjectedBundle::setAllowFileAccessFromFileURLs(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setAllowFileAccessFromFileURLs(enabled); } void InjectedBundle::setNeedsStorageAccessFromFileURLsQuirk(WebPageGroupProxy* pageGroup, bool needsQuirk) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (auto page : pages) page->settings().setNeedsStorageAccessFromFileURLsQuirk(needsQuirk); } void InjectedBundle::setMinimumLogicalFontSize(WebPageGroupProxy* pageGroup, int size) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setMinimumLogicalFontSize(size); } void InjectedBundle::setFrameFlatteningEnabled(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setFrameFlatteningEnabled(enabled); } void InjectedBundle::setJavaScriptCanAccessClipboard(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setJavaScriptCanAccessClipboard(enabled); } void InjectedBundle::setPrivateBrowsingEnabled(WebPageGroupProxy* pageGroup, bool enabled) { if (enabled) { WebProcess::singleton().ensureLegacyPrivateBrowsingSessionInNetworkProcess(); WebFrameNetworkingContext::ensurePrivateBrowsingSession(SessionID::legacyPrivateSessionID()); } else SessionTracker::destroySession(SessionID::legacyPrivateSessionID()); const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->enableLegacyPrivateBrowsing(enabled); } void InjectedBundle::setUseDashboardCompatibilityMode(WebPageGroupProxy* pageGroup, bool enabled) { #if ENABLE(DASHBOARD_SUPPORT) for (auto& page : PageGroup::pageGroup(pageGroup->identifier())->pages()) page->settings().setUsesDashboardBackwardCompatibilityMode(enabled); #endif } void InjectedBundle::setPopupBlockingEnabled(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); HashSet::const_iterator end = pages.end(); for (HashSet::const_iterator iter = pages.begin(); iter != end; ++iter) (*iter)->settings().setJavaScriptCanOpenWindowsAutomatically(!enabled); } void InjectedBundle::setAuthorAndUserStylesEnabled(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setAuthorAndUserStylesEnabled(enabled); } void InjectedBundle::setSpatialNavigationEnabled(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setSpatialNavigationEnabled(enabled); } void InjectedBundle::addOriginAccessWhitelistEntry(const String& sourceOrigin, const String& destinationProtocol, const String& destinationHost, bool allowDestinationSubdomains) { SecurityPolicy::addOriginAccessWhitelistEntry(SecurityOrigin::createFromString(sourceOrigin).get(), destinationProtocol, destinationHost, allowDestinationSubdomains); } void InjectedBundle::removeOriginAccessWhitelistEntry(const String& sourceOrigin, const String& destinationProtocol, const String& destinationHost, bool allowDestinationSubdomains) { SecurityPolicy::removeOriginAccessWhitelistEntry(SecurityOrigin::createFromString(sourceOrigin).get(), destinationProtocol, destinationHost, allowDestinationSubdomains); } void InjectedBundle::resetOriginAccessWhitelists() { SecurityPolicy::resetOriginAccessWhitelists(); } void InjectedBundle::setAsynchronousSpellCheckingEnabled(WebPageGroupProxy* pageGroup, bool enabled) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setAsynchronousSpellCheckingEnabled(enabled); } int InjectedBundle::numberOfPages(WebFrame* frame, double pageWidthInPixels, double pageHeightInPixels) { Frame* coreFrame = frame ? frame->coreFrame() : 0; if (!coreFrame) return -1; if (!pageWidthInPixels) pageWidthInPixels = coreFrame->view()->width(); if (!pageHeightInPixels) pageHeightInPixels = coreFrame->view()->height(); return PrintContext::numberOfPages(*coreFrame, FloatSize(pageWidthInPixels, pageHeightInPixels)); } int InjectedBundle::pageNumberForElementById(WebFrame* frame, const String& id, double pageWidthInPixels, double pageHeightInPixels) { Frame* coreFrame = frame ? frame->coreFrame() : 0; if (!coreFrame) return -1; Element* element = coreFrame->document()->getElementById(id); if (!element) return -1; if (!pageWidthInPixels) pageWidthInPixels = coreFrame->view()->width(); if (!pageHeightInPixels) pageHeightInPixels = coreFrame->view()->height(); return PrintContext::pageNumberForElement(element, FloatSize(pageWidthInPixels, pageHeightInPixels)); } String InjectedBundle::pageSizeAndMarginsInPixels(WebFrame* frame, int pageIndex, int width, int height, int marginTop, int marginRight, int marginBottom, int marginLeft) { Frame* coreFrame = frame ? frame->coreFrame() : 0; if (!coreFrame) return String(); return PrintContext::pageSizeAndMarginsInPixels(coreFrame, pageIndex, width, height, marginTop, marginRight, marginBottom, marginLeft); } bool InjectedBundle::isPageBoxVisible(WebFrame* frame, int pageIndex) { Frame* coreFrame = frame ? frame->coreFrame() : 0; if (!coreFrame) return false; return PrintContext::isPageBoxVisible(coreFrame, pageIndex); } bool InjectedBundle::isProcessingUserGesture() { return ScriptController::processingUserGesture(); } void InjectedBundle::addUserScript(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld, const String& source, const String& url, API::Array* whitelist, API::Array* blacklist, WebCore::UserScriptInjectionTime injectionTime, WebCore::UserContentInjectedFrames injectedFrames) { // url is not from URL::string(), i.e. it has not already been parsed by URL, so we have to use the relative URL constructor for URL instead of the ParsedURLStringTag version. UserScript userScript{ source, URL(URL(), url), whitelist ? whitelist->toStringVector() : Vector(), blacklist ? blacklist->toStringVector() : Vector(), injectionTime, injectedFrames }; pageGroup->userContentController().addUserScript(*scriptWorld, WTFMove(userScript)); } void InjectedBundle::addUserStyleSheet(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld, const String& source, const String& url, API::Array* whitelist, API::Array* blacklist, WebCore::UserContentInjectedFrames injectedFrames) { // url is not from URL::string(), i.e. it has not already been parsed by URL, so we have to use the relative URL constructor for URL instead of the ParsedURLStringTag version. UserStyleSheet userStyleSheet{ source, URL(URL(), url), whitelist ? whitelist->toStringVector() : Vector(), blacklist ? blacklist->toStringVector() : Vector(), injectedFrames, UserStyleUserLevel }; pageGroup->userContentController().addUserStyleSheet(*scriptWorld, WTFMove(userStyleSheet)); } void InjectedBundle::removeUserScript(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld, const String& url) { // url is not from URL::string(), i.e. it has not already been parsed by URL, so we have to use the relative URL constructor for URL instead of the ParsedURLStringTag version. pageGroup->userContentController().removeUserScriptWithURL(*scriptWorld, URL(URL(), url)); } void InjectedBundle::removeUserStyleSheet(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld, const String& url) { // url is not from URL::string(), i.e. it has not already been parsed by URL, so we have to use the relative URL constructor for URL instead of the ParsedURLStringTag version. pageGroup->userContentController().removeUserStyleSheetWithURL(*scriptWorld, URL(URL(), url)); } void InjectedBundle::removeUserScripts(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld) { pageGroup->userContentController().removeUserScripts(*scriptWorld); } void InjectedBundle::removeUserStyleSheets(WebPageGroupProxy* pageGroup, InjectedBundleScriptWorld* scriptWorld) { pageGroup->userContentController().removeUserStyleSheets(*scriptWorld); } void InjectedBundle::removeAllUserContent(WebPageGroupProxy* pageGroup) { pageGroup->userContentController().removeAllUserContent(); } void InjectedBundle::garbageCollectJavaScriptObjects() { GCController::singleton().garbageCollectNow(); } void InjectedBundle::garbageCollectJavaScriptObjectsOnAlternateThreadForDebugging(bool waitUntilDone) { GCController::singleton().garbageCollectOnAlternateThreadForDebugging(waitUntilDone); } size_t InjectedBundle::javaScriptObjectsCount() { JSLockHolder lock(commonVM()); return commonVM().heap.objectCount(); } void InjectedBundle::reportException(JSContextRef context, JSValueRef exception) { if (!context || !exception) return; JSC::ExecState* execState = toJS(context); JSLockHolder lock(execState); // Make sure the context has a DOMWindow global object, otherwise this context didn't originate from a Page. JSC::JSGlobalObject* globalObject = execState->lexicalGlobalObject(); if (!toJSDOMWindow(globalObject->vm(), globalObject)) return; WebCore::reportException(execState, toJS(execState, exception)); } void InjectedBundle::didCreatePage(WebPage* page) { m_client.didCreatePage(this, page); } void InjectedBundle::willDestroyPage(WebPage* page) { m_client.willDestroyPage(this, page); } void InjectedBundle::didInitializePageGroup(WebPageGroupProxy* pageGroup) { m_client.didInitializePageGroup(this, pageGroup); } void InjectedBundle::didReceiveMessage(const String& messageName, API::Object* messageBody) { m_client.didReceiveMessage(this, messageName, messageBody); } void InjectedBundle::didReceiveMessageToPage(WebPage* page, const String& messageName, API::Object* messageBody) { m_client.didReceiveMessageToPage(this, page, messageName, messageBody); } void InjectedBundle::setUserStyleSheetLocation(WebPageGroupProxy* pageGroup, const String& location) { const HashSet& pages = PageGroup::pageGroup(pageGroup->identifier())->pages(); for (HashSet::iterator iter = pages.begin(); iter != pages.end(); ++iter) (*iter)->settings().setUserStyleSheetLocation(URL(URL(), location)); } void InjectedBundle::setWebNotificationPermission(WebPage* page, const String& originString, bool allowed) { #if ENABLE(NOTIFICATIONS) || ENABLE(LEGACY_NOTIFICATIONS) page->notificationPermissionRequestManager()->setPermissionLevelForTesting(originString, allowed); #else UNUSED_PARAM(page); UNUSED_PARAM(originString); UNUSED_PARAM(allowed); #endif } void InjectedBundle::removeAllWebNotificationPermissions(WebPage* page) { #if ENABLE(NOTIFICATIONS) || ENABLE(LEGACY_NOTIFICATIONS) page->notificationPermissionRequestManager()->removeAllPermissionsForTesting(); #else UNUSED_PARAM(page); #endif } uint64_t InjectedBundle::webNotificationID(JSContextRef jsContext, JSValueRef jsNotification) { #if ENABLE(NOTIFICATIONS) || ENABLE(LEGACY_NOTIFICATIONS) WebCore::Notification* notification = JSNotification::toWrapped(toJS(jsContext)->vm(), toJS(toJS(jsContext), jsNotification)); if (!notification) return 0; return WebProcess::singleton().supplement()->notificationIDForTesting(notification); #else UNUSED_PARAM(jsContext); UNUSED_PARAM(jsNotification); return 0; #endif } // FIXME Get rid of this function and move it into WKBundle.cpp. PassRefPtr InjectedBundle::createWebDataFromUint8Array(JSContextRef context, JSValueRef data) { JSC::ExecState* execState = toJS(context); RefPtr arrayData = WebCore::toUnsharedUint8Array(execState->vm(), toJS(execState, data)); return API::Data::create(static_cast(arrayData->baseAddress()), arrayData->byteLength()); } void InjectedBundle::setTabKeyCyclesThroughElements(WebPage* page, bool enabled) { page->corePage()->setTabKeyCyclesThroughElements(enabled); } void InjectedBundle::setCSSAnimationTriggersEnabled(bool enabled) { #if ENABLE(CSS_ANIMATIONS_LEVEL_2) RuntimeEnabledFeatures::sharedFeatures().setAnimationTriggersEnabled(enabled); #else UNUSED_PARAM(enabled); #endif } void InjectedBundle::setWebAnimationsEnabled(bool enabled) { #if ENABLE(WEB_ANIMATIONS) RuntimeEnabledFeatures::sharedFeatures().setWebAnimationsEnabled(enabled); #else UNUSED_PARAM(enabled); #endif } } // namespace WebKit