blob: 1e36520762a76763891d7c7b63824e99820e531d [file] [log] [blame]
// Copyright 2015 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 CHROME_BROWSER_EXTENSIONS_CHROME_CONTENT_VERIFIER_DELEGATE_H_
#define CHROME_BROWSER_EXTENSIONS_CHROME_CONTENT_VERIFIER_DELEGATE_H_
#include <map>
#include <memory>
#include <set>
#include <string>
#include "base/macros.h"
#include "base/optional.h"
#include "extensions/browser/content_verifier_delegate.h"
namespace content {
class BrowserContext;
}
namespace net {
class BackoffEntry;
}
namespace extensions {
class PolicyExtensionReinstaller;
class ChromeContentVerifierDelegate : public ContentVerifierDelegate {
public:
// Note that it is important for these to appear in increasing "severity"
// order, because we use this to let command line flags increase, but not
// decrease, the mode you're running in compared to the experiment group.
enum Mode {
// Do not try to fetch content hashes if they are missing, and do not
// enforce them if they are present.
NONE = 0,
// If content hashes are missing, try to fetch them, but do not enforce.
BOOTSTRAP,
// If hashes are present, enforce them. If they are missing, try to fetch
// them.
ENFORCE,
// Treat the absence of hashes the same as a verification failure.
ENFORCE_STRICT
};
static Mode GetDefaultMode();
static void SetDefaultModeForTesting(base::Optional<Mode> mode);
explicit ChromeContentVerifierDelegate(content::BrowserContext* context);
~ChromeContentVerifierDelegate() override;
// ContentVerifierDelegate:
VerifierSourceType GetVerifierSourceType(const Extension& extension) override;
ContentVerifierKey GetPublicKey() override;
GURL GetSignatureFetchUrl(const std::string& extension_id,
const base::Version& version) override;
std::set<base::FilePath> GetBrowserImagePaths(
const extensions::Extension* extension) override;
void VerifyFailed(const std::string& extension_id,
ContentVerifyJob::FailureReason reason) override;
void Shutdown() override;
private:
// Returns what action should be taken if given extension fails verification
// in some way, or NONE if no verification is needed.
Mode GetVerifyMode(const Extension& extension);
content::BrowserContext* context_;
Mode default_mode_;
// This maps an extension id to a backoff entry for slowing down
// redownload/reinstall of corrupt policy extensions if it keeps happening
// in a loop (eg crbug.com/661738).
std::map<std::string, std::unique_ptr<net::BackoffEntry>>
policy_reinstall_backoff_;
// For reporting metrics in BOOTSTRAP mode, when an extension would be
// disabled if content verification was in ENFORCE mode.
std::set<std::string> would_be_disabled_ids_;
std::unique_ptr<PolicyExtensionReinstaller> policy_extension_reinstaller_;
DISALLOW_COPY_AND_ASSIGN(ChromeContentVerifierDelegate);
};
} // namespace extensions
#endif // CHROME_BROWSER_EXTENSIONS_CHROME_CONTENT_VERIFIER_DELEGATE_H_