blob: 8b99acad243a4d934c4af4ce8222f768cd9d566e [file] [log] [blame]
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef THIRD_PARTY_BLINK_PUBLIC_COMMON_FRAME_FRAME_POLICY_H_
#define THIRD_PARTY_BLINK_PUBLIC_COMMON_FRAME_FRAME_POLICY_H_
#include "services/network/public/cpp/permissions_policy/permissions_policy_declaration.h"
#include "services/network/public/mojom/web_sandbox_flags.mojom-shared.h"
#include "third_party/blink/public/common/permissions_policy/document_policy_features.h"
#include "third_party/blink/public/mojom/fenced_frame/fenced_frame.mojom-shared.h"
#include "third_party/blink/public/mojom/frame/deferred_fetch_policy.mojom-shared.h"
namespace blink {
// This structure contains the attributes of a frame which determine what
// features are available during the lifetime of the framed document. Currently,
// this includes the sandbox flags, the permissions policy container policy, and
// document policy required policy. Used in the frame tree to track sandbox,
// permissions policy and document policy in the browser process, and
// transferred over IPC during frame replication when site isolation is enabled.
//
// Unlike the attributes in FrameOwnerProperties, these attributes are never
// updated after the framed document has been loaded, so two versions of this
// structure are kept in the frame tree for each frame -- the effective policy
// and the pending policy, which will take effect when the frame is next
// navigated.
struct BLINK_COMMON_EXPORT FramePolicy {
FramePolicy();
FramePolicy(network::mojom::WebSandboxFlags sandbox_flags,
const network::ParsedPermissionsPolicy& container_policy,
const DocumentPolicyFeatureState& required_document_policy,
mojom::DeferredFetchPolicy deferred_fetch_policy);
FramePolicy(const FramePolicy& lhs);
~FramePolicy();
friend bool BLINK_COMMON_EXPORT operator==(const FramePolicy& lhs,
const FramePolicy& rhs);
network::mojom::WebSandboxFlags sandbox_flags;
network::ParsedPermissionsPolicy container_policy;
// |required_document_policy| is the combination of the following:
// - iframe 'policy' attribute
// - 'Require-Document-Policy' http header
// - |required_document_policy| of parent frame
DocumentPolicyFeatureState required_document_policy;
// See `mojom::DeferredFetchPolicy` documentation.
mojom::DeferredFetchPolicy deferred_fetch_policy;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_PUBLIC_COMMON_FRAME_FRAME_POLICY_H_