blob: e0c6f01c239fc6cbe83ae9a2600050e66260fc92 [file] [log] [blame] [edit]
/*
* Copyright (C) 2011, 2013 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 "WebOriginDataManagerProxy.h"
#include "SecurityOriginData.h"
#include "WebContext.h"
#include "WebOriginDataManagerMessages.h"
#include "WebOriginDataManagerProxyMessages.h"
#include "WebSecurityOrigin.h"
#include <WebCore/SecurityOrigin.h>
#include <wtf/NeverDestroyed.h>
using namespace WebCore;
namespace WebKit {
const char* WebOriginDataManagerProxy::supplementName()
{
return "WebOriginDataManagerProxy";
}
PassRefPtr<WebOriginDataManagerProxy> WebOriginDataManagerProxy::create(WebContext* context)
{
return adoptRef(new WebOriginDataManagerProxy(context));
}
WebOriginDataManagerProxy::WebOriginDataManagerProxy(WebContext* context)
: WebContextSupplement(context)
{
context->addMessageReceiver(Messages::WebOriginDataManagerProxy::messageReceiverName(), *this);
}
WebOriginDataManagerProxy::~WebOriginDataManagerProxy()
{
}
void WebOriginDataManagerProxy::contextDestroyed()
{
invalidateCallbackMap(m_arrayCallbacks, CallbackBase::Error::OwnerWasInvalidated);
}
void WebOriginDataManagerProxy::processDidClose(WebProcessProxy*)
{
invalidateCallbackMap(m_arrayCallbacks, CallbackBase::Error::ProcessExited);
}
bool WebOriginDataManagerProxy::shouldTerminate(WebProcessProxy*) const
{
return m_arrayCallbacks.isEmpty();
}
void WebOriginDataManagerProxy::refWebContextSupplement()
{
API::Object::ref();
}
void WebOriginDataManagerProxy::derefWebContextSupplement()
{
API::Object::deref();
}
void WebOriginDataManagerProxy::getOrigins(WKOriginDataTypes types, std::function<void (API::Array*, CallbackBase::Error)> callbackFunction)
{
// FIXME: Right now we only support IndexedDatabase data so we know that we're only sending this request to the DatabaseProcess.
// That's why having one single callback works.
// In the future when we message N-processes we'll have to wait for all N replies before responding to the client.
if (!(types & kWKIndexedDatabaseData)) {
callbackFunction(nullptr, CallbackBase::Error::None);
return;
}
RefPtr<ArrayCallback> callback = ArrayCallback::create(WTF::move(callbackFunction));
if (!context()) {
callback->invalidate();
return;
}
uint64_t callbackID = callback->callbackID();
m_arrayCallbacks.set(callbackID, callback.release());
context()->sendToDatabaseProcessRelaunchingIfNecessary(Messages::WebOriginDataManager::GetOrigins(types, callbackID));
}
void WebOriginDataManagerProxy::didGetOrigins(IPC::Connection* connection, const Vector<SecurityOriginData>& originIdentifiers, uint64_t callbackID)
{
RefPtr<ArrayCallback> callback = m_arrayCallbacks.take(callbackID);
MESSAGE_CHECK_BASE(callback, connection);
Vector<RefPtr<API::Object>> securityOrigins;
securityOrigins.reserveInitialCapacity(originIdentifiers.size());
for (const auto& originIdentifier : originIdentifiers)
securityOrigins.uncheckedAppend(WebSecurityOrigin::create(originIdentifier.securityOrigin()));
callback->performCallbackWithReturnValue(API::Array::create(WTF::move(securityOrigins)).get());
}
void WebOriginDataManagerProxy::deleteEntriesForOrigin(WKOriginDataTypes types, WebSecurityOrigin* origin, std::function<void (CallbackBase::Error)> callbackFunction)
{
// FIXME: Right now we only support IndexedDatabase data so we know that we're only sending this request to the DatabaseProcess.
// That's why having one single callback works.
// In the future when we message N-processes we'll have to wait for all N replies before responding to the client.
if (!(types & kWKIndexedDatabaseData)) {
callbackFunction(CallbackBase::Error::None);
return;
}
RefPtr<VoidCallback> callback = VoidCallback::create(WTF::move(callbackFunction));
if (!context()) {
callback->invalidate();
return;
}
uint64_t callbackID = callback->callbackID();
m_voidCallbacks.set(callbackID, callback.release());
SecurityOriginData securityOriginData;
securityOriginData.protocol = origin->securityOrigin().protocol();
securityOriginData.host = origin->securityOrigin().host();
securityOriginData.port = origin->securityOrigin().port();
context()->sendToDatabaseProcessRelaunchingIfNecessary(Messages::WebOriginDataManager::DeleteEntriesForOrigin(types, securityOriginData, callbackID));
}
void WebOriginDataManagerProxy::deleteEntriesModifiedBetweenDates(WKOriginDataTypes types, double startDate, double endDate, std::function<void (CallbackBase::Error)> callbackFunction)
{
// FIXME: Right now we only support IndexedDatabase data so we know that we're only sending this request to the DatabaseProcess.
// That's why having one single callback works.
// In the future when we message N-processes we'll have to wait for all N replies before responding to the client.
if (!(types & kWKIndexedDatabaseData)) {
callbackFunction(CallbackBase::Error::None);
return;
}
RefPtr<VoidCallback> callback = VoidCallback::create(WTF::move(callbackFunction));
if (!context()) {
callback->invalidate();
return;
}
uint64_t callbackID = callback->callbackID();
m_voidCallbacks.set(callbackID, callback.release());
context()->sendToDatabaseProcessRelaunchingIfNecessary(Messages::WebOriginDataManager::DeleteEntriesModifiedBetweenDates(types, startDate, endDate, callbackID));
}
void WebOriginDataManagerProxy::didDeleteEntries(IPC::Connection* connection, uint64_t callbackID)
{
RefPtr<VoidCallback> callback = m_voidCallbacks.take(callbackID);
MESSAGE_CHECK_BASE(callback, connection);
callback->performCallback();
}
void WebOriginDataManagerProxy::deleteAllEntries(WKOriginDataTypes types, std::function<void (CallbackBase::Error)> callbackFunction)
{
// FIXME: Right now we only support IndexedDatabase data so we know that we're only sending this request to the DatabaseProcess.
// That's why having one single callback works.
// In the future when we message N-processes we'll have to wait for all N replies before responding to the client.
if (!(types & kWKIndexedDatabaseData)) {
callbackFunction(CallbackBase::Error::None);
return;
}
RefPtr<VoidCallback> callback = VoidCallback::create(WTF::move(callbackFunction));
if (!context()) {
callback->invalidate();
return;
}
uint64_t callbackID = callback->callbackID();
m_voidCallbacks.set(callbackID, callback.release());
context()->sendToDatabaseProcessRelaunchingIfNecessary(Messages::WebOriginDataManager::DeleteAllEntries(types, callbackID));
}
void WebOriginDataManagerProxy::didDeleteAllEntries(IPC::Connection* connection, uint64_t callbackID)
{
RefPtr<VoidCallback> callback = m_voidCallbacks.take(callbackID);
MESSAGE_CHECK_BASE(callback, connection);
callback->performCallback();
}
} // namespace WebKit