blob: cd2db3b8e23111912b6dd6e0efb2184f3bb7baa1 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/browsing_data/content/service_worker_helper.h"
#include <tuple>
#include <utility>
#include <vector>
#include "base/functional/bind.h"
#include "base/functional/callback_helpers.h"
#include "base/location.h"
#include "components/browsing_data/content/browsing_data_helper.h"
#include "content/public/browser/browser_task_traits.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/service_worker_context.h"
#include "content/public/browser/storage_usage_info.h"
#include "third_party/blink/public/common/storage_key/storage_key.h"
using content::BrowserThread;
using content::ServiceWorkerContext;
using content::StorageUsageInfo;
namespace browsing_data {
namespace {
void OnGotAllStorageKeysInfoForServiceWorker(
ServiceWorkerHelper::FetchCallback callback,
const std::vector<StorageUsageInfo>& infos) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
DCHECK(!callback.is_null());
std::list<StorageUsageInfo> result;
for (const StorageUsageInfo& info : infos) {
if (!HasWebScheme(info.storage_key.origin().GetURL()))
continue; // Non-websafe state is not considered browsing data.
result.push_back(info);
}
std::move(callback).Run(result);
}
} // namespace
ServiceWorkerHelper::ServiceWorkerHelper(
ServiceWorkerContext* service_worker_context)
: service_worker_context_(service_worker_context) {
DCHECK(service_worker_context_);
}
ServiceWorkerHelper::~ServiceWorkerHelper() {}
void ServiceWorkerHelper::StartFetching(FetchCallback callback) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
DCHECK(!callback.is_null());
service_worker_context_->GetAllStorageKeysInfo(base::BindOnce(
&OnGotAllStorageKeysInfoForServiceWorker, std::move(callback)));
}
void ServiceWorkerHelper::DeleteServiceWorkers(const url::Origin& origin) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
// TODO(crbug.com/1199077): Update this when the cookie tree model understands
// StorageKey.
service_worker_context_->DeleteForStorageKey(
blink::StorageKey::CreateFirstParty(origin), base::DoNothing());
}
CannedServiceWorkerHelper::CannedServiceWorkerHelper(
content::ServiceWorkerContext* context)
: ServiceWorkerHelper(context) {}
CannedServiceWorkerHelper::~CannedServiceWorkerHelper() {}
void CannedServiceWorkerHelper::Add(const url::Origin& origin) {
if (!HasWebScheme(origin.GetURL()))
return; // Non-websafe state is not considered browsing data.
pending_origins_.insert(origin);
}
void CannedServiceWorkerHelper::Reset() {
pending_origins_.clear();
}
bool CannedServiceWorkerHelper::empty() const {
return pending_origins_.empty();
}
size_t CannedServiceWorkerHelper::GetCount() const {
return pending_origins_.size();
}
const std::set<url::Origin>& CannedServiceWorkerHelper::GetOrigins() const {
return pending_origins_;
}
void CannedServiceWorkerHelper::StartFetching(FetchCallback callback) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
DCHECK(!callback.is_null());
std::list<StorageUsageInfo> result;
for (const auto& origin : pending_origins_)
result.emplace_back(blink::StorageKey::CreateFirstParty(origin), 0,
base::Time());
std::move(callback).Run(result);
}
void CannedServiceWorkerHelper::DeleteServiceWorkers(
const url::Origin& origin) {
pending_origins_.erase(origin);
ServiceWorkerHelper::DeleteServiceWorkers(origin);
}
} // namespace browsing_data