| // Copyright 2018 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef COMPONENTS_EXO_WAYLAND_SERVER_UTIL_H_ |
| #define COMPONENTS_EXO_WAYLAND_SERVER_UTIL_H_ |
| |
| #include <wayland-server-core.h> |
| #include <wayland-server-protocol-core.h> |
| #include <memory> |
| |
| #include "base/memory/ptr_util.h" |
| #include "base/time/time.h" |
| #include "components/exo/surface.h" |
| #include "ui/base/class_property.h" |
| |
| struct wl_resource; |
| |
| namespace exo { |
| |
| class SecurityDelegate; |
| class DataOffer; |
| |
| namespace wayland { |
| |
| template <class T> |
| T* GetUserDataAs(wl_resource* resource) { |
| return static_cast<T*>(wl_resource_get_user_data(resource)); |
| } |
| |
| template <class T> |
| std::unique_ptr<T> TakeUserDataAs(wl_resource* resource) { |
| std::unique_ptr<T> user_data = base::WrapUnique(GetUserDataAs<T>(resource)); |
| wl_resource_set_user_data(resource, nullptr); |
| return user_data; |
| } |
| |
| template <class T> |
| void DestroyUserData(wl_resource* resource) { |
| TakeUserDataAs<T>(resource); |
| } |
| |
| template <class T> |
| void SetImplementation(wl_resource* resource, |
| const void* implementation, |
| std::unique_ptr<T> user_data) { |
| wl_resource_set_implementation(resource, implementation, user_data.release(), |
| DestroyUserData<T>); |
| } |
| |
| void SetImplementation(wl_resource* resource, const void* implementation); |
| |
| // Convert a timestamp to a time value that can be used when interfacing |
| // with wayland. Note that we cast a int64_t value to uint32_t which can |
| // potentially overflow. |
| uint32_t TimeTicksToMilliseconds(base::TimeTicks ticks); |
| uint32_t NowInMilliseconds(); |
| |
| wl_resource* GetSurfaceResource(Surface* surface); |
| void SetSurfaceResource(Surface* surface, wl_resource* resource); |
| |
| wl_resource* GetDataOfferResource(const DataOffer* data_offer); |
| void SetDataOfferResource(DataOffer* data_offer, |
| wl_resource* data_offer_resource); |
| |
| // Associates the given |display| with its |security_delegate|. |
| void SetSecurityDelegate(wl_display* display, |
| SecurityDelegate* security_delegate); |
| |
| // Clears the SecurityDelegate association for |display|. |
| void RemoveSecurityDelegate(wl_display* display); |
| |
| // Returns the associated security_delegate for this |display|. |
| SecurityDelegate* GetSecurityDelegate(wl_display* display); |
| |
| // Returns the associated security_delegate for the display this |client| is |
| // connected to. |
| SecurityDelegate* GetSecurityDelegate(wl_client* client); |
| |
| // Returns whether a client has initiated destruction. After destruction begins |
| // resources associated with the client start to be freed and there is a risk of |
| // UAFs in querying for client resources (see crbug.com/1433187). |
| bool IsClientDestroyed(wl_client* client); |
| |
| } // namespace wayland |
| } // namespace exo |
| |
| #endif // COMPONENTS_EXO_WAYLAND_SERVER_UTIL_H_ |