blob: 58e7d8aaea03f76155c956d14aa198658caf8baa [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_BROWSER_APPCACHE_CHROME_APPCACHE_SERVICE_H_
#define CONTENT_BROWSER_APPCACHE_CHROME_APPCACHE_SERVICE_H_
#include <map>
#include <memory>
#include "base/compiler_specific.h"
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "base/sequenced_task_runner_helpers.h"
#include "content/browser/appcache/appcache_backend_impl.h"
#include "content/browser/appcache/appcache_policy.h"
#include "content/browser/appcache/appcache_service_impl.h"
#include "content/common/content_export.h"
#include "mojo/public/cpp/bindings/pending_receiver.h"
#include "mojo/public/cpp/bindings/unique_receiver_set.h"
#include "storage/browser/quota/special_storage_policy.h"
#include "third_party/blink/public/mojom/appcache/appcache.mojom-forward.h"
namespace base {
class FilePath;
}
namespace content {
class BrowserContext;
struct ChromeAppCacheServiceDeleter;
// An AppCacheServiceImpl subclass used by the chrome. There is an instance
// associated with each BrowserContext. This derivation adds refcounting
// semantics since a browser context has multiple URLRequestContexts which refer
// to the same object, and those URLRequestContexts are refcounted independently
// of the owning browser context.
//
// All methods, except the ctor, are expected to be called on
// the IO thread (unless specifically called out in doc comments).
//
// TODO(dpranke): Fix dependencies on AppCacheServiceImpl so that we don't have
// to worry about clients calling AppCacheServiceImpl methods.
class CONTENT_EXPORT ChromeAppCacheService
: public base::RefCountedThreadSafe<ChromeAppCacheService,
ChromeAppCacheServiceDeleter>,
public AppCacheServiceImpl,
public AppCachePolicy {
public:
ChromeAppCacheService(storage::QuotaManagerProxy* proxy,
base::WeakPtr<StoragePartitionImpl> partition);
// If |cache_path| is empty we will use in-memory structs.
void Initialize(
const base::FilePath& cache_path,
BrowserContext* browser_context,
scoped_refptr<storage::SpecialStoragePolicy> special_storage_policy);
void CreateBackend(
int process_id,
int routing_id,
mojo::PendingReceiver<blink::mojom::AppCacheBackend> receiver);
void Shutdown();
// AppCachePolicy overrides
bool CanLoadAppCache(const GURL& manifest_url,
const GURL& first_party) override;
bool CanCreateAppCache(const GURL& manifest_url,
const GURL& first_party) override;
bool IsOriginTrialRequiredForAppCache() override;
protected:
~ChromeAppCacheService() override;
private:
friend class base::DeleteHelper<ChromeAppCacheService>;
friend class base::RefCountedThreadSafe<ChromeAppCacheService,
ChromeAppCacheServiceDeleter>;
friend struct ChromeAppCacheServiceDeleter;
void DeleteOnCorrectThread() const;
BrowserContext* browser_context_ = nullptr;
base::FilePath cache_path_;
mojo::UniqueReceiverSet<blink::mojom::AppCacheBackend> receivers_;
DISALLOW_COPY_AND_ASSIGN(ChromeAppCacheService);
};
struct ChromeAppCacheServiceDeleter {
static void Destruct(const ChromeAppCacheService* service) {
service->DeleteOnCorrectThread();
}
};
} // namespace content
#endif // CONTENT_BROWSER_APPCACHE_CHROME_APPCACHE_SERVICE_H_