
This CL generalizes Mojo capability control to associated interfaces.
Before this CL, all of the associated interfaces are granted except
mojom::PepperHost.
After this CL, Prerender2 cancels prerendering when a received
binding request is not allowed to bind during prerendering. The
allowlists are defined in
chrome/browser/chrome_content_browser_client_binder_policies.cc (for
//chrome)
and content/browser/mojo_binder_policy_map_impl.cc(for //content).
Design(chromium@):
https://docs.google.com/document/d/1LPLURqzJW1EuhTAuD3igf1HlP4YaaiF3JNpvTdSZ3LE/edit#heading=h.xfm7goxm51fp
Bug: 1259007
Change-Id: I20ab235d7c2d6fa37aba1b686a064b6ffad36088
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3218175
Commit-Queue: Lingqi Chi <lingqi@chromium.org>
Reviewed-by: Hiroki Nakagawa <nhiroki@chromium.org>
Reviewed-by: Alexander Timin <altimin@chromium.org>
Reviewed-by: Daniel Cheng <dcheng@chromium.org>
Reviewed-by: Kouhei Ueno <kouhei@chromium.org>
Reviewed-by: Kentaro Hara <haraken@chromium.org>
Cr-Commit-Position: refs/heads/main@{#939240}
88 lines
3.6 KiB
C++
88 lines
3.6 KiB
C++
// Copyright 2020 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_MOJO_BINDER_POLICY_MAP_IMPL_H_
|
|
#define CONTENT_BROWSER_MOJO_BINDER_POLICY_MAP_IMPL_H_
|
|
|
|
#include <string>
|
|
|
|
#include "base/containers/flat_map.h"
|
|
#include "base/strings/string_piece_forward.h"
|
|
#include "content/common/content_export.h"
|
|
#include "content/public/browser/mojo_binder_policy_map.h"
|
|
|
|
namespace content {
|
|
|
|
// Implements MojoBinderPolicyMap and owns a policy map.
|
|
class CONTENT_EXPORT MojoBinderPolicyMapImpl : public MojoBinderPolicyMap {
|
|
public:
|
|
MojoBinderPolicyMapImpl();
|
|
|
|
// This constructor is for testing.
|
|
explicit MojoBinderPolicyMapImpl(
|
|
const base::flat_map<std::string, MojoBinderNonAssociatedPolicy>&
|
|
init_map);
|
|
~MojoBinderPolicyMapImpl() override;
|
|
|
|
// Disallows copy and move operations.
|
|
MojoBinderPolicyMapImpl(const MojoBinderPolicyMapImpl& other) = delete;
|
|
MojoBinderPolicyMapImpl& operator=(const MojoBinderPolicyMapImpl& other) =
|
|
delete;
|
|
MojoBinderPolicyMapImpl(MojoBinderPolicyMapImpl&&) = delete;
|
|
MojoBinderPolicyMapImpl& operator=(MojoBinderPolicyMapImpl&&) = delete;
|
|
|
|
// Returns the instance used by MojoBinderPolicyApplier for prerendering
|
|
// pages.
|
|
// This is used when the prerendered page and the page that triggered the
|
|
// prerendering are same origin. Currently this is the only use of this class.
|
|
static const MojoBinderPolicyMapImpl* GetInstanceForSameOriginPrerendering();
|
|
|
|
// Gets the corresponding policy of a given Mojo interface name.
|
|
// If the interface name is not in `non_associated_policy_map_`, the given
|
|
// `default_policy` will be returned.
|
|
// Callers should ensure that the corresponding interface is used as a
|
|
// non-associated interface in the context. If the interface is used as a
|
|
// channel-associated interface, they should call
|
|
// `GetAssociatedMojoBinderPolicy`.
|
|
MojoBinderNonAssociatedPolicy GetNonAssociatedMojoBinderPolicy(
|
|
const std::string& interface_name,
|
|
const MojoBinderNonAssociatedPolicy default_policy) const;
|
|
|
|
// Gets the corresponding policy of a given Mojo interface name.
|
|
// If the interface name is not in `associated_policy_map_`, the given
|
|
// `default_policy` will be returned.
|
|
// Callers should ensure that the corresponding interface is used as a
|
|
// channel-associated interface in the context. If the interface is used as a
|
|
// non-associated interface, they should call
|
|
// `GetNonAssociatedMojoBinderPolicy`.
|
|
MojoBinderAssociatedPolicy GetAssociatedMojoBinderPolicy(
|
|
const std::string& interface_name,
|
|
const MojoBinderAssociatedPolicy default_policy) const;
|
|
|
|
// Fails with DCHECK if the interface is not in `non_associated_policy_map_`.
|
|
MojoBinderNonAssociatedPolicy GetNonAssociatedMojoBinderPolicyOrDieForTesting(
|
|
const std::string& interface_name) const;
|
|
|
|
// Fails with DCHECK if the interface is not in `associated_policy_map_`.
|
|
MojoBinderAssociatedPolicy GetAssociatedMojoBinderPolicyOrDieForTesting(
|
|
const std::string& interface_name) const;
|
|
|
|
private:
|
|
// MojoBinderPolicyMap implementation:
|
|
void SetPolicyByName(const base::StringPiece& name,
|
|
MojoBinderAssociatedPolicy policy) override;
|
|
|
|
void SetPolicyByName(const base::StringPiece& name,
|
|
MojoBinderNonAssociatedPolicy policy) override;
|
|
|
|
base::flat_map<std::string, MojoBinderNonAssociatedPolicy>
|
|
non_associated_policy_map_;
|
|
base::flat_map<std::string, MojoBinderAssociatedPolicy>
|
|
associated_policy_map_;
|
|
};
|
|
|
|
} // namespace content
|
|
|
|
#endif // CONTENT_BROWSER_MOJO_BINDER_POLICY_MAP_IMPL_H_
|