/* * Copyright (C) 2010, 2011 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 "WebPlatformStrategies.h" #include "FrameLoader.h" #include "WebFrameNetworkingContext.h" #include #include #include #include #if USE(CFNETWORK) #include #endif using namespace WebCore; void WebPlatformStrategies::initialize() { DEFINE_STATIC_LOCAL(WebPlatformStrategies, platformStrategies, ()); } WebPlatformStrategies::WebPlatformStrategies() { setPlatformStrategies(this); } CookiesStrategy* WebPlatformStrategies::createCookiesStrategy() { return this; } DatabaseStrategy* WebPlatformStrategies::createDatabaseStrategy() { return this; } LoaderStrategy* WebPlatformStrategies::createLoaderStrategy() { return this; } PasteboardStrategy* WebPlatformStrategies::createPasteboardStrategy() { return 0; } PluginStrategy* WebPlatformStrategies::createPluginStrategy() { return this; } SharedWorkerStrategy* WebPlatformStrategies::createSharedWorkerStrategy() { return this; } StorageStrategy* WebPlatformStrategies::createStorageStrategy() { return this; } VisitedLinkStrategy* WebPlatformStrategies::createVisitedLinkStrategy() { return this; } String WebPlatformStrategies::cookiesForDOM(const NetworkStorageSession& session, const KURL& firstParty, const KURL& url) { return WebCore::cookiesForDOM(session, firstParty, url); } void WebPlatformStrategies::setCookiesFromDOM(const NetworkStorageSession& session, const KURL& firstParty, const KURL& url, const String& cookieString) { WebCore::setCookiesFromDOM(session, firstParty, url, cookieString); } bool WebPlatformStrategies::cookiesEnabled(const NetworkStorageSession& session, const KURL& firstParty, const KURL& url) { return WebCore::cookiesEnabled(session, firstParty, url); } String WebPlatformStrategies::cookieRequestHeaderFieldValue(const NetworkStorageSession& session, const KURL& firstParty, const KURL& url) { return WebCore::cookieRequestHeaderFieldValue(session, firstParty, url); } bool WebPlatformStrategies::getRawCookies(const NetworkStorageSession& session, const KURL& firstParty, const KURL& url, Vector& rawCookies) { return WebCore::getRawCookies(session, firstParty, url, rawCookies); } void WebPlatformStrategies::deleteCookie(const NetworkStorageSession& session, const KURL& url, const String& cookieName) { WebCore::deleteCookie(session, url, cookieName); } void WebPlatformStrategies::refreshPlugins() { PluginDatabase::installedPlugins()->refresh(); } void WebPlatformStrategies::getPluginInfo(const WebCore::Page*, Vector& outPlugins) { const Vector& plugins = PluginDatabase::installedPlugins()->plugins(); outPlugins.resize(plugins.size()); for (size_t i = 0; i < plugins.size(); ++i) { PluginPackage* package = plugins[i]; PluginInfo info; info.name = package->name(); info.file = package->fileName(); info.desc = package->description(); const MIMEToDescriptionsMap& mimeToDescriptions = package->mimeToDescriptions(); info.mimes.reserveCapacity(mimeToDescriptions.size()); MIMEToDescriptionsMap::const_iterator end = mimeToDescriptions.end(); for (MIMEToDescriptionsMap::const_iterator it = mimeToDescriptions.begin(); it != end; ++it) { MimeClassInfo mime; mime.type = it->key; mime.desc = it->value; mime.extensions = package->mimeToExtensions().get(mime.type); info.mimes.append(mime); } outPlugins[i] = info; } } bool WebPlatformStrategies::isLinkVisited(Page* page, LinkHash hash, const KURL&, const AtomicString&) { return page->group().isLinkVisited(hash); } void WebPlatformStrategies::addVisitedLink(Page* page, LinkHash hash) { page->group().addVisitedLinkHash(hash); }