| Index: chrome/browser/safe_browsing/certificate_reporting_service_factory.cc
|
| diff --git a/chrome/browser/safe_browsing/certificate_reporting_service_factory.cc b/chrome/browser/safe_browsing/certificate_reporting_service_factory.cc
|
| index fc1eab154ee65d1b082936cdde0f3e04c19357f8..606e05e7ee7c7c6d07a2f742bec04d901bff95ad 100644
|
| --- a/chrome/browser/safe_browsing/certificate_reporting_service_factory.cc
|
| +++ b/chrome/browser/safe_browsing/certificate_reporting_service_factory.cc
|
| @@ -2,10 +2,28 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| +#include "base/time/default_clock.h"
|
| +#include "chrome/browser/browser_process.h"
|
| +#include "chrome/browser/profiles/profile.h"
|
| #include "chrome/browser/safe_browsing/certificate_reporting_service.h"
|
| #include "chrome/browser/safe_browsing/certificate_reporting_service_factory.h"
|
| +#include "chrome/browser/safe_browsing/safe_browsing_service.h"
|
| #include "components/keyed_service/content/browser_context_dependency_manager.h"
|
|
|
| +namespace {
|
| +
|
| +// Maximum age in seconds until a report is dropped from the retry list.
|
| +// By default, reports older than a day are ignored and never retried again.
|
| +static const uint64_t kMaxReportAgeInSeconds = 86400;
|
| +
|
| +// Maximum number of reports to be kept in the report retry list. If an incoming
|
| +// report has a more recent creation date than the oldest report in the list,
|
| +// the oldest report is removed from the list and the incoming report is added.
|
| +// Otherwise, the incoming report is ignored.
|
| +const size_t kMaxReportCountInQueue = 5;
|
| +
|
| +} // namespace
|
| +
|
| // static
|
| CertificateReportingServiceFactory*
|
| CertificateReportingServiceFactory::GetInstance() {
|
| @@ -20,17 +38,49 @@ CertificateReportingServiceFactory::GetForBrowserContext(
|
| GetInstance()->GetServiceForBrowserContext(context, true));
|
| }
|
|
|
| +void CertificateReportingServiceFactory::SetReportEncryptionParamsForTesting(
|
| + uint8_t* server_public_key,
|
| + uint32_t server_public_key_version) {
|
| + server_public_key_ = server_public_key;
|
| + server_public_key_version_ = server_public_key_version;
|
| +}
|
| +
|
| +void CertificateReportingServiceFactory::SetClockForTesting(
|
| + std::unique_ptr<base::Clock> clock) {
|
| + clock_ = std::move(clock);
|
| +}
|
| +
|
| +void CertificateReportingServiceFactory::SetQueuedReportTTLForTesting(
|
| + base::TimeDelta queued_report_ttl) {
|
| + queued_report_ttl_ = queued_report_ttl;
|
| +}
|
| +
|
| +void CertificateReportingServiceFactory::SetMaxQueuedReportCountForTesting(
|
| + size_t max_queued_report_count) {
|
| + max_queued_report_count_ = max_queued_report_count;
|
| +}
|
| +
|
| CertificateReportingServiceFactory::CertificateReportingServiceFactory()
|
| : BrowserContextKeyedServiceFactory(
|
| "cert_reporting::Factory",
|
| - BrowserContextDependencyManager::GetInstance()) {}
|
| + BrowserContextDependencyManager::GetInstance()),
|
| + server_public_key_(nullptr),
|
| + server_public_key_version_(0),
|
| + clock_(new base::DefaultClock()),
|
| + queued_report_ttl_(base::TimeDelta::FromSeconds(kMaxReportAgeInSeconds)),
|
| + max_queued_report_count_(kMaxReportCountInQueue) {}
|
|
|
| CertificateReportingServiceFactory::~CertificateReportingServiceFactory() {}
|
|
|
| KeyedService* CertificateReportingServiceFactory::BuildServiceInstanceFor(
|
| content::BrowserContext* profile) const {
|
| - // TODO(crbug.com/554323): Create a real CertificateReportingService here.
|
| - return nullptr;
|
| + safe_browsing::SafeBrowsingService* safe_browsing_service =
|
| + g_browser_process->safe_browsing_service();
|
| + return new CertificateReportingService(
|
| + safe_browsing_service, safe_browsing_service->url_request_context(),
|
| + static_cast<Profile*>(profile), server_public_key_,
|
| + server_public_key_version_, max_queued_report_count_, queued_report_ttl_,
|
| + clock_.get());
|
| }
|
|
|
| content::BrowserContext*
|
|
|