blob: 3f48fe9b5f2bc0d7fc079998244aa56c227484ca [file] [log] [blame]
// services/network/public/mojom/cookie_access_observer.mojom.h is auto generated by mojom_bindings_generator.py, do not edit
// Copyright 2013 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 SERVICES_NETWORK_PUBLIC_MOJOM_COOKIE_ACCESS_OBSERVER_MOJOM_H_
#define SERVICES_NETWORK_PUBLIC_MOJOM_COOKIE_ACCESS_OBSERVER_MOJOM_H_
#include <stdint.h>
#include <limits>
#include <type_traits>
#include <utility>
#include "third_party/abseil-cpp/absl/types/optional.h"
#include "mojo/public/cpp/bindings/clone_traits.h"
#include "mojo/public/cpp/bindings/equals_traits.h"
#include "mojo/public/cpp/bindings/lib/serialization.h"
#include "mojo/public/cpp/bindings/struct_ptr.h"
#include "mojo/public/cpp/bindings/struct_traits.h"
#include "mojo/public/cpp/bindings/union_traits.h"
#include "third_party/perfetto/include/perfetto/tracing/traced_value_forward.h"
#include "services/network/public/mojom/cookie_access_observer.mojom-shared.h"
#include "services/network/public/mojom/cookie_access_observer.mojom-forward.h"
#include "url/mojom/url.mojom.h"
#include "services/network/public/mojom/site_for_cookies.mojom.h"
#include "services/network/public/mojom/cookie_manager.mojom.h"
#include <string>
#include <vector>
#include "mojo/public/cpp/bindings/lib/control_message_handler.h"
#include "mojo/public/cpp/bindings/raw_ptr_impl_ref_traits.h"
#ifdef KYTHE_IS_RUNNING
#pragma kythe_inline_metadata "Metadata comment"
#endif
namespace network {
namespace mojom {
class CookieAccessObserverProxy;
template <typename ImplRefTraits>
class CookieAccessObserverStub;
class CookieAccessObserverRequestValidator;
// @generated_from: network.mojom.CookieAccessObserver
class CookieAccessObserver
: public CookieAccessObserverInterfaceBase {
public:
static const char Name_[];
static uint32_t MessageToStableIPCHash_(mojo::Message& message);
static const char* MessageToMethodName_(mojo::Message& message);
static constexpr uint32_t Version_ = 0;
static constexpr bool PassesAssociatedKinds_ = false;
static constexpr bool HasSyncMethods_ = false;
static constexpr bool HasUninterruptableMethods_ = false;
using Base_ = CookieAccessObserverInterfaceBase;
using Proxy_ = CookieAccessObserverProxy;
template <typename ImplRefTraits>
using Stub_ = CookieAccessObserverStub<ImplRefTraits>;
using RequestValidator_ = CookieAccessObserverRequestValidator;
using ResponseValidator_ = mojo::PassThroughFilter;
enum MethodMinVersions : uint32_t {
kOnCookiesAccessedMinVersion = 0,
kCloneMinVersion = 0,
};
virtual ~CookieAccessObserver() = default;
// @generated_from: network.mojom.CookieAccessObserver.OnCookiesAccessed
virtual void OnCookiesAccessed(CookieAccessDetailsPtr details) = 0;
// @generated_from: network.mojom.CookieAccessObserver.Clone
virtual void Clone(::mojo::PendingReceiver<CookieAccessObserver> listener) = 0;
};
// @generated_from: network.mojom.CookieAccessObserver
class CookieAccessObserverProxy
: public CookieAccessObserver {
public:
using InterfaceType = CookieAccessObserver;
explicit CookieAccessObserverProxy(mojo::MessageReceiverWithResponder* receiver);
// @generated_from: network.mojom.CookieAccessObserver.OnCookiesAccessed
void OnCookiesAccessed(CookieAccessDetailsPtr details) final;
// @generated_from: network.mojom.CookieAccessObserver.Clone
void Clone(::mojo::PendingReceiver<CookieAccessObserver> listener) final;
private:
mojo::MessageReceiverWithResponder* receiver_;
};
class CookieAccessObserverStubDispatch {
public:
static bool Accept(CookieAccessObserver* impl, mojo::Message* message);
static bool AcceptWithResponder(
CookieAccessObserver* impl,
mojo::Message* message,
std::unique_ptr<mojo::MessageReceiverWithStatus> responder);
};
template <typename ImplRefTraits =
mojo::RawPtrImplRefTraits<CookieAccessObserver>>
class CookieAccessObserverStub
: public mojo::MessageReceiverWithResponderStatus {
public:
using ImplPointerType = typename ImplRefTraits::PointerType;
CookieAccessObserverStub() = default;
~CookieAccessObserverStub() override = default;
void set_sink(ImplPointerType sink) { sink_ = std::move(sink); }
ImplPointerType& sink() { return sink_; }
bool Accept(mojo::Message* message) override {
if (ImplRefTraits::IsNull(sink_))
return false;
return CookieAccessObserverStubDispatch::Accept(
ImplRefTraits::GetRawPointer(&sink_), message);
}
bool AcceptWithResponder(
mojo::Message* message,
std::unique_ptr<mojo::MessageReceiverWithStatus> responder) override {
if (ImplRefTraits::IsNull(sink_))
return false;
return CookieAccessObserverStubDispatch::AcceptWithResponder(
ImplRefTraits::GetRawPointer(&sink_), message, std::move(responder));
}
private:
ImplPointerType sink_;
};
class CookieAccessObserverRequestValidator : public mojo::MessageReceiver {
public:
bool Accept(mojo::Message* message) override;
};
// @generated_from: network.mojom.CookieAccessDetails
class CookieAccessDetails {
public:
template <typename T>
using EnableIfSame = std::enable_if_t<std::is_same<CookieAccessDetails, T>::value>;
using DataView = CookieAccessDetailsDataView;
using Data_ = internal::CookieAccessDetails_Data;
// @generated_from: network.mojom.CookieAccessDetails.Type
using Type = CookieAccessDetails_Type;
template <typename... Args>
static CookieAccessDetailsPtr New(Args&&... args) {
return CookieAccessDetailsPtr(
absl::in_place, std::forward<Args>(args)...);
}
template <typename U>
static CookieAccessDetailsPtr From(const U& u) {
return mojo::TypeConverter<CookieAccessDetailsPtr, U>::Convert(u);
}
template <typename U>
U To() const {
return mojo::TypeConverter<U, CookieAccessDetails>::Convert(*this);
}
CookieAccessDetails();
CookieAccessDetails(
CookieAccessDetails::Type type,
const ::GURL& url,
const ::net::SiteForCookies& site_for_cookies,
std::vector<::network::mojom::CookieOrLineWithAccessResultPtr> cookie_list,
const absl::optional<std::string>& devtools_request_id);
CookieAccessDetails(const CookieAccessDetails&) = delete;
CookieAccessDetails& operator=(const CookieAccessDetails&) = delete;
~CookieAccessDetails();
// Clone() is a template so it is only instantiated if it is used. Thus, the
// bindings generator does not need to know whether Clone() or copy
// constructor/assignment are available for members.
template <typename StructPtrType = CookieAccessDetailsPtr>
CookieAccessDetailsPtr Clone() const;
// Equals() is a template so it is only instantiated if it is used. Thus, the
// bindings generator does not need to know whether Equals() or == operator
// are available for members.
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool Equals(const T& other) const;
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool operator==(const T& rhs) const { return Equals(rhs); }
template <typename UserType>
static std::vector<uint8_t> Serialize(UserType* input) {
return mojo::internal::SerializeImpl<
CookieAccessDetails::DataView, std::vector<uint8_t>>(input);
}
template <typename UserType>
static mojo::Message SerializeAsMessage(UserType* input) {
return mojo::internal::SerializeAsMessageImpl<
CookieAccessDetails::DataView>(input);
}
// The returned Message is serialized only if the message is moved
// cross-process or cross-language. Otherwise if the message is Deserialized
// as the same UserType |input| will just be moved to |output| in
// DeserializeFromMessage.
template <typename UserType>
static mojo::Message WrapAsMessage(UserType input) {
return mojo::Message(std::make_unique<
internal::CookieAccessDetails_UnserializedMessageContext<
UserType, CookieAccessDetails::DataView>>(0, 0, std::move(input)),
MOJO_CREATE_MESSAGE_FLAG_NONE);
}
template <typename UserType>
static bool Deserialize(const void* data,
size_t data_num_bytes,
UserType* output) {
mojo::Message message;
return mojo::internal::DeserializeImpl<CookieAccessDetails::DataView>(
message, data, data_num_bytes, output, Validate);
}
template <typename UserType>
static bool Deserialize(const std::vector<uint8_t>& input,
UserType* output) {
return CookieAccessDetails::Deserialize(
input.size() == 0 ? nullptr : &input.front(), input.size(), output);
}
template <typename UserType>
static bool DeserializeFromMessage(mojo::Message input,
UserType* output) {
auto context = input.TakeUnserializedContext<
internal::CookieAccessDetails_UnserializedMessageContext<
UserType, CookieAccessDetails::DataView>>();
if (context) {
*output = std::move(context->TakeData());
return true;
}
input.SerializeIfNecessary();
return mojo::internal::DeserializeImpl<CookieAccessDetails::DataView>(
input, input.payload(), input.payload_num_bytes(), output, Validate);
}
// @generated_from: network.mojom.CookieAccessDetails.type
CookieAccessDetails::Type type;
// @generated_from: network.mojom.CookieAccessDetails.url
::GURL url;
// @generated_from: network.mojom.CookieAccessDetails.site_for_cookies
::net::SiteForCookies site_for_cookies;
// @generated_from: network.mojom.CookieAccessDetails.cookie_list
std::vector<::network::mojom::CookieOrLineWithAccessResultPtr> cookie_list;
// @generated_from: network.mojom.CookieAccessDetails.devtools_request_id
absl::optional<std::string> devtools_request_id;
// Serialise this struct into a trace.
void WriteIntoTrace(perfetto::TracedValue traced_context) const;
private:
static bool Validate(const void* data,
mojo::internal::ValidationContext* validation_context);
};
// The comparison operators are templates, so they are only instantiated if they
// are used. Thus, the bindings generator does not need to know whether
// comparison operators are available for members.
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool operator<(const T& lhs, const T& rhs);
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool operator<=(const T& lhs, const T& rhs) {
return !(rhs < lhs);
}
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool operator>(const T& lhs, const T& rhs) {
return rhs < lhs;
}
template <typename T, CookieAccessDetails::EnableIfSame<T>* = nullptr>
bool operator>=(const T& lhs, const T& rhs) {
return !(lhs < rhs);
}
template <typename StructPtrType>
CookieAccessDetailsPtr CookieAccessDetails::Clone() const {
return New(
mojo::Clone(type),
mojo::Clone(url),
mojo::Clone(site_for_cookies),
mojo::Clone(cookie_list),
mojo::Clone(devtools_request_id)
);
}
template <typename T, CookieAccessDetails::EnableIfSame<T>*>
bool CookieAccessDetails::Equals(const T& other_struct) const {
if (!mojo::Equals(this->type, other_struct.type))
return false;
if (!mojo::Equals(this->url, other_struct.url))
return false;
if (!mojo::Equals(this->site_for_cookies, other_struct.site_for_cookies))
return false;
if (!mojo::Equals(this->cookie_list, other_struct.cookie_list))
return false;
if (!mojo::Equals(this->devtools_request_id, other_struct.devtools_request_id))
return false;
return true;
}
template <typename T, CookieAccessDetails::EnableIfSame<T>*>
bool operator<(const T& lhs, const T& rhs) {
if (lhs.type < rhs.type)
return true;
if (rhs.type < lhs.type)
return false;
if (lhs.url < rhs.url)
return true;
if (rhs.url < lhs.url)
return false;
if (lhs.site_for_cookies < rhs.site_for_cookies)
return true;
if (rhs.site_for_cookies < lhs.site_for_cookies)
return false;
if (lhs.cookie_list < rhs.cookie_list)
return true;
if (rhs.cookie_list < lhs.cookie_list)
return false;
if (lhs.devtools_request_id < rhs.devtools_request_id)
return true;
if (rhs.devtools_request_id < lhs.devtools_request_id)
return false;
return false;
}
} // namespace mojom
} // namespace network
namespace mojo {
template <>
struct StructTraits<::network::mojom::CookieAccessDetails::DataView,
::network::mojom::CookieAccessDetailsPtr> {
static bool IsNull(const ::network::mojom::CookieAccessDetailsPtr& input) { return !input; }
static void SetToNull(::network::mojom::CookieAccessDetailsPtr* output) { output->reset(); }
static decltype(::network::mojom::CookieAccessDetails::type) type(
const ::network::mojom::CookieAccessDetailsPtr& input) {
return input->type;
}
static const decltype(::network::mojom::CookieAccessDetails::url)& url(
const ::network::mojom::CookieAccessDetailsPtr& input) {
return input->url;
}
static const decltype(::network::mojom::CookieAccessDetails::site_for_cookies)& site_for_cookies(
const ::network::mojom::CookieAccessDetailsPtr& input) {
return input->site_for_cookies;
}
static const decltype(::network::mojom::CookieAccessDetails::cookie_list)& cookie_list(
const ::network::mojom::CookieAccessDetailsPtr& input) {
return input->cookie_list;
}
static const decltype(::network::mojom::CookieAccessDetails::devtools_request_id)& devtools_request_id(
const ::network::mojom::CookieAccessDetailsPtr& input) {
return input->devtools_request_id;
}
static bool Read(::network::mojom::CookieAccessDetails::DataView input, ::network::mojom::CookieAccessDetailsPtr* output);
};
} // namespace mojo
#endif // SERVICES_NETWORK_PUBLIC_MOJOM_COOKIE_ACCESS_OBSERVER_MOJOM_H_
/* Metadata comment
eyJtZXRhIjogW3siZW5kIjogMTgwNSwgImJlZ2luIjogMTc4NSwgImVkZ2UiOiAiJS9reXRoZS9l
ZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjogImFuY2hvcl9kZWZpbmVzIiwgInZuYW1lIjogeyJjb3Jw
dXMiOiAiY2hyb21pdW0uZ29vZ2xlc291cmNlLmNvbS9jaHJvbWl1bS9zcmMiLCAibGFuZ3VhZ2Ui
OiAibW9qb20iLCAic2lnbmF0dXJlIjogIm5ldHdvcmsubW9qb20uQ29va2llQWNjZXNzT2JzZXJ2
ZXIifX0sIHsiZW5kIjogMjgwNiwgImJlZ2luIjogMjc4OSwgImVkZ2UiOiAiJS9reXRoZS9lZGdl
L2dlbmVyYXRlcyIsICJ0eXBlIjogImFuY2hvcl9kZWZpbmVzIiwgInZuYW1lIjogeyJjb3JwdXMi
OiAiY2hyb21pdW0uZ29vZ2xlc291cmNlLmNvbS9jaHJvbWl1bS9zcmMiLCAibGFuZ3VhZ2UiOiAi
bW9qb20iLCAic2lnbmF0dXJlIjogIm5ldHdvcmsubW9qb20uQ29va2llQWNjZXNzT2JzZXJ2ZXIu
T25Db29raWVzQWNjZXNzZWQifX0sIHsiZW5kIjogMjkyOSwgImJlZ2luIjogMjkyNCwgImVkZ2Ui
OiAiJS9reXRoZS9lZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjogImFuY2hvcl9kZWZpbmVzIiwgInZu
YW1lIjogeyJjb3JwdXMiOiAiY2hyb21pdW0uZ29vZ2xlc291cmNlLmNvbS9jaHJvbWl1bS9zcmMi
LCAibGFuZ3VhZ2UiOiAibW9qb20iLCAic2lnbmF0dXJlIjogIm5ldHdvcmsubW9qb20uQ29va2ll
QWNjZXNzT2JzZXJ2ZXIuQ2xvbmUifX0sIHsiZW5kIjogMzM2MSwgImJlZ2luIjogMzM0NCwgImVk
Z2UiOiAiJS9reXRoZS9lZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjogImFuY2hvcl9kZWZpbmVzIiwg
InZuYW1lIjogeyJjb3JwdXMiOiAiY2hyb21pdW0uZ29vZ2xlc291cmNlLmNvbS9jaHJvbWl1bS9z
cmMiLCAibGFuZ3VhZ2UiOiAibW9qb20iLCAic2lnbmF0dXJlIjogIm5ldHdvcmsubW9qb20uQ29v
a2llQWNjZXNzT2JzZXJ2ZXIuT25Db29raWVzQWNjZXNzZWQifX0sIHsiZW5kIjogMzQ3NywgImJl
Z2luIjogMzQ3MiwgImVkZ2UiOiAiJS9reXRoZS9lZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjogImFu
Y2hvcl9kZWZpbmVzIiwgInZuYW1lIjogeyJjb3JwdXMiOiAiY2hyb21pdW0uZ29vZ2xlc291cmNl
LmNvbS9jaHJvbWl1bS9zcmMiLCAibGFuZ3VhZ2UiOiAibW9qb20iLCAic2lnbmF0dXJlIjogIm5l
dHdvcmsubW9qb20uQ29va2llQWNjZXNzT2JzZXJ2ZXIuQ2xvbmUifX0sIHsiZW5kIjogNTE4Niwg
ImJlZ2luIjogNTE2NywgImVkZ2UiOiAiJS9reXRoZS9lZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjog
ImFuY2hvcl9kZWZpbmVzIiwgInZuYW1lIjogeyJjb3JwdXMiOiAiY2hyb21pdW0uZ29vZ2xlc291
cmNlLmNvbS9jaHJvbWl1bS9zcmMiLCAibGFuZ3VhZ2UiOiAibW9qb20iLCAic2lnbmF0dXJlIjog
Im5ldHdvcmsubW9qb20uQ29va2llQWNjZXNzRGV0YWlscyJ9fSwgeyJlbmQiOiA1NDc5LCAiYmVn
aW4iOiA1NDc1LCAiZWRnZSI6ICIlL2t5dGhlL2VkZ2UvZ2VuZXJhdGVzIiwgInR5cGUiOiAiYW5j
aG9yX2RlZmluZXMiLCAidm5hbWUiOiB7ImNvcnB1cyI6ICJjaHJvbWl1bS5nb29nbGVzb3VyY2Uu
Y29tL2Nocm9taXVtL3NyYyIsICJsYW5ndWFnZSI6ICJtb2pvbSIsICJzaWduYXR1cmUiOiAibmV0
d29yay5tb2pvbS5Db29raWVBY2Nlc3NEZXRhaWxzLlR5cGUifX0sIHsiZW5kIjogOTQyMiwgImJl
Z2luIjogOTQxOCwgImVkZ2UiOiAiJS9reXRoZS9lZGdlL2dlbmVyYXRlcyIsICJ0eXBlIjogImFu
Y2hvcl9kZWZpbmVzIiwgInZuYW1lIjogeyJjb3JwdXMiOiAiY2hyb21pdW0uZ29vZ2xlc291cmNl
LmNvbS9jaHJvbWl1bS9zcmMiLCAibGFuZ3VhZ2UiOiAibW9qb20iLCAic2lnbmF0dXJlIjogIm5l
dHdvcmsubW9qb20uQ29va2llQWNjZXNzRGV0YWlscy50eXBlIn19LCB7ImVuZCI6IDk1MDIsICJi
ZWdpbiI6IDk0OTksICJlZGdlIjogIiUva3l0aGUvZWRnZS9nZW5lcmF0ZXMiLCAidHlwZSI6ICJh
bmNob3JfZGVmaW5lcyIsICJ2bmFtZSI6IHsiY29ycHVzIjogImNocm9taXVtLmdvb2dsZXNvdXJj
ZS5jb20vY2hyb21pdW0vc3JjIiwgImxhbmd1YWdlIjogIm1vam9tIiwgInNpZ25hdHVyZSI6ICJu
ZXR3b3JrLm1vam9tLkNvb2tpZUFjY2Vzc0RldGFpbHMudXJsIn19LCB7ImVuZCI6IDk2MTgsICJi
ZWdpbiI6IDk2MDIsICJlZGdlIjogIiUva3l0aGUvZWRnZS9nZW5lcmF0ZXMiLCAidHlwZSI6ICJh
bmNob3JfZGVmaW5lcyIsICJ2bmFtZSI6IHsiY29ycHVzIjogImNocm9taXVtLmdvb2dsZXNvdXJj
ZS5jb20vY2hyb21pdW0vc3JjIiwgImxhbmd1YWdlIjogIm1vam9tIiwgInNpZ25hdHVyZSI6ICJu
ZXR3b3JrLm1vam9tLkNvb2tpZUFjY2Vzc0RldGFpbHMuc2l0ZV9mb3JfY29va2llcyJ9fSwgeyJl
bmQiOiA5NzY1LCAiYmVnaW4iOiA5NzU0LCAiZWRnZSI6ICIlL2t5dGhlL2VkZ2UvZ2VuZXJhdGVz
IiwgInR5cGUiOiAiYW5jaG9yX2RlZmluZXMiLCAidm5hbWUiOiB7ImNvcnB1cyI6ICJjaHJvbWl1
bS5nb29nbGVzb3VyY2UuY29tL2Nocm9taXVtL3NyYyIsICJsYW5ndWFnZSI6ICJtb2pvbSIsICJz
aWduYXR1cmUiOiAibmV0d29yay5tb2pvbS5Db29raWVBY2Nlc3NEZXRhaWxzLmNvb2tpZV9saXN0
In19LCB7ImVuZCI6IDk4OTMsICJiZWdpbiI6IDk4NzQsICJlZGdlIjogIiUva3l0aGUvZWRnZS9n
ZW5lcmF0ZXMiLCAidHlwZSI6ICJhbmNob3JfZGVmaW5lcyIsICJ2bmFtZSI6IHsiY29ycHVzIjog
ImNocm9taXVtLmdvb2dsZXNvdXJjZS5jb20vY2hyb21pdW0vc3JjIiwgImxhbmd1YWdlIjogIm1v
am9tIiwgInNpZ25hdHVyZSI6ICJuZXR3b3JrLm1vam9tLkNvb2tpZUFjY2Vzc0RldGFpbHMuZGV2
dG9vbHNfcmVxdWVzdF9pZCJ9fV0sICJ0eXBlIjogImt5dGhlMCJ9
*/