blob: 189a6e88f7fb5f4ff76085afc2f6c679215ef062 [file] [log] [blame]
// Copyright 2025 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_COOKIES_REF_UNIQUE_COOKIE_KEY_H_
#define NET_COOKIES_REF_UNIQUE_COOKIE_KEY_H_
#include <compare>
#include <optional>
#include <string_view>
#include "base/types/optional_ref.h"
#include "base/types/pass_key.h"
#include "net/base/net_export.h"
#include "net/cookies/cookie_constants.h"
#include "net/cookies/cookie_partition_key.h"
namespace net {
class CookieBase;
// RefUniqueCookieKey is similar to a UniqueCookieKey, but it does not own the
// underlying data. It MUST NOT outlive the CookieBase used to create it,
// because it contains references to data in the CookieBase.
class NET_EXPORT RefUniqueCookieKey {
public:
// Conditionally populates the source scheme and source port depending on the
// state of their associated feature.
static RefUniqueCookieKey Host(
base::PassKey<CookieBase>,
base::optional_ref<const CookiePartitionKey> partition_key,
std::string_view name,
std::string_view domain,
std::string_view path,
std::optional<CookieSourceScheme> source_scheme,
std::optional<int> source_port);
// Same as Host but for use with Domain cookies, which do not
// consider the source_port.
static RefUniqueCookieKey Domain(
base::PassKey<CookieBase>,
base::optional_ref<const CookiePartitionKey> partition_key,
std::string_view name,
std::string_view domain,
std::string_view path,
std::optional<CookieSourceScheme> source_scheme);
RefUniqueCookieKey(RefUniqueCookieKey&&);
RefUniqueCookieKey(const RefUniqueCookieKey&) = delete;
RefUniqueCookieKey& operator=(RefUniqueCookieKey&&) = delete;
RefUniqueCookieKey& operator=(const RefUniqueCookieKey&) = delete;
~RefUniqueCookieKey();
friend bool operator==(const RefUniqueCookieKey&,
const RefUniqueCookieKey&) = default;
friend auto operator<=>(const RefUniqueCookieKey&,
const RefUniqueCookieKey&) = default;
private:
enum class KeyType {
kHost,
kDomain,
};
RefUniqueCookieKey(KeyType key_type,
base::optional_ref<const CookiePartitionKey> partition_key,
std::string_view name,
std::string_view domain,
std::string_view path,
std::optional<CookieSourceScheme> source_scheme,
std::optional<int> port);
// Keys of different "types" (i.e., created by different factory functions)
// are never considered equivalent.
KeyType key_type_;
const base::optional_ref<const CookiePartitionKey> partition_key_;
const std::string_view name_;
const std::string_view domain_;
const std::string_view path_;
// Nullopt in kLegacy keys; may be nullopt in kDomain and kHost keys.
const std::optional<CookieSourceScheme> source_scheme_;
// Nullopt in kLegacy and kDomain keys; may be nullopt in kHost keys.
const std::optional<int> port_;
};
} // namespace net
#endif // NET_COOKIES_REF_UNIQUE_COOKIE_KEY_H_