blob: 32814cf5157ba05e91bc87afa466272d24953c8e [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_FIRST_PARTY_SETS_LOCAL_SET_DECLARATION_H_
#define NET_FIRST_PARTY_SETS_LOCAL_SET_DECLARATION_H_
#include "base/containers/flat_map.h"
#include "net/base/net_export.h"
#include "net/base/schemeful_site.h"
#include "net/first_party_sets/first_party_set_entry.h"
namespace net {
// LocalSetDeclaration represents a Related Website Set that was defined locally
// by a web developer (as opposed to being one of the public Related Website
// Sets, or a set from the RelatedWebsiteSetsOverrides policy).
//
// Locally-defined sets take precedence over the public sets (for testing
// purposes), but can be overridden by the RelatedWebsiteSetsOverrides policy.
//
// See `GlobalFirstPartySets` for how overlaps/shadowing between public sets,
// locally-defined sets, and enterprise policy sets is handled.
class NET_EXPORT LocalSetDeclaration {
public:
// Constructs an empty (no-op) set declaration.
LocalSetDeclaration();
// Constructs a set declaration with the given entries. All entries must be in
// the same set (i.e. they must have the same primary site). The set must not
// be a singleton (i.e. must have more than one entry, or must be empty).
explicit LocalSetDeclaration(
base::flat_map<SchemefulSite, FirstPartySetEntry> set_entries,
base::flat_map<SchemefulSite, SchemefulSite> aliases);
~LocalSetDeclaration();
LocalSetDeclaration(const LocalSetDeclaration&);
LocalSetDeclaration& operator=(const LocalSetDeclaration&);
LocalSetDeclaration(LocalSetDeclaration&&);
LocalSetDeclaration& operator=(LocalSetDeclaration&&);
bool empty() const { return entries_.empty(); }
size_t size() const { return entries_.size(); }
const base::flat_map<SchemefulSite, FirstPartySetEntry>& entries() const {
return entries_;
}
const base::flat_map<SchemefulSite, SchemefulSite>& aliases() const {
return aliases_;
}
private:
// Stores the set of entries, without ccTLD aliases. This may be empty if no
// set was locally defined.
base::flat_map<SchemefulSite, FirstPartySetEntry> entries_;
// Stores the ccTLD aliases. May be empty.
base::flat_map<SchemefulSite, SchemefulSite> aliases_;
};
} // namespace net
#endif // NET_FIRST_PARTY_SETS_LOCAL_SET_DECLARATION_H_