xref: /aosp_15_r20/external/openscreen/cast/common/public/cast_socket.h (revision 3f982cf4871df8771c9d4abe6e9a6f8d829b2736)
1*3f982cf4SFabien Sanglard // Copyright 2019 The Chromium Authors. All rights reserved.
2*3f982cf4SFabien Sanglard // Use of this source code is governed by a BSD-style license that can be
3*3f982cf4SFabien Sanglard // found in the LICENSE file.
4*3f982cf4SFabien Sanglard 
5*3f982cf4SFabien Sanglard #ifndef CAST_COMMON_PUBLIC_CAST_SOCKET_H_
6*3f982cf4SFabien Sanglard #define CAST_COMMON_PUBLIC_CAST_SOCKET_H_
7*3f982cf4SFabien Sanglard 
8*3f982cf4SFabien Sanglard #include <array>
9*3f982cf4SFabien Sanglard #include <memory>
10*3f982cf4SFabien Sanglard #include <vector>
11*3f982cf4SFabien Sanglard 
12*3f982cf4SFabien Sanglard #include "platform/api/tls_connection.h"
13*3f982cf4SFabien Sanglard #include "util/weak_ptr.h"
14*3f982cf4SFabien Sanglard 
15*3f982cf4SFabien Sanglard namespace cast {
16*3f982cf4SFabien Sanglard namespace channel {
17*3f982cf4SFabien Sanglard class CastMessage;
18*3f982cf4SFabien Sanglard }  // namespace channel
19*3f982cf4SFabien Sanglard }  // namespace cast
20*3f982cf4SFabien Sanglard 
21*3f982cf4SFabien Sanglard namespace openscreen {
22*3f982cf4SFabien Sanglard namespace cast {
23*3f982cf4SFabien Sanglard 
24*3f982cf4SFabien Sanglard // Represents a simple message-oriented socket for communicating with the Cast
25*3f982cf4SFabien Sanglard // V2 protocol.  It isn't thread-safe, so it should only be used on the same
26*3f982cf4SFabien Sanglard // TaskRunner thread as its TlsConnection.
27*3f982cf4SFabien Sanglard class CastSocket : public TlsConnection::Client {
28*3f982cf4SFabien Sanglard  public:
29*3f982cf4SFabien Sanglard   class Client {
30*3f982cf4SFabien Sanglard    public:
31*3f982cf4SFabien Sanglard 
32*3f982cf4SFabien Sanglard     // Called when a terminal error on |socket| has occurred.
33*3f982cf4SFabien Sanglard     virtual void OnError(CastSocket* socket, Error error) = 0;
34*3f982cf4SFabien Sanglard 
35*3f982cf4SFabien Sanglard     virtual void OnMessage(CastSocket* socket,
36*3f982cf4SFabien Sanglard                            ::cast::channel::CastMessage message) = 0;
37*3f982cf4SFabien Sanglard 
38*3f982cf4SFabien Sanglard    protected:
39*3f982cf4SFabien Sanglard     virtual ~Client();
40*3f982cf4SFabien Sanglard   };
41*3f982cf4SFabien Sanglard 
42*3f982cf4SFabien Sanglard   CastSocket(std::unique_ptr<TlsConnection> connection, Client* client);
43*3f982cf4SFabien Sanglard   ~CastSocket();
44*3f982cf4SFabien Sanglard 
45*3f982cf4SFabien Sanglard   // Sends |message| immediately unless the underlying TLS connection is
46*3f982cf4SFabien Sanglard   // write-blocked, in which case |message| will be queued.  An error will be
47*3f982cf4SFabien Sanglard   // returned if |message| cannot be serialized for any reason, even while
48*3f982cf4SFabien Sanglard   // write-blocked.
49*3f982cf4SFabien Sanglard   [[nodiscard]] Error Send(const ::cast::channel::CastMessage& message);
50*3f982cf4SFabien Sanglard 
51*3f982cf4SFabien Sanglard   void SetClient(Client* client);
52*3f982cf4SFabien Sanglard 
53*3f982cf4SFabien Sanglard   std::array<uint8_t, 2> GetSanitizedIpAddress();
54*3f982cf4SFabien Sanglard 
socket_id()55*3f982cf4SFabien Sanglard   int socket_id() const { return socket_id_; }
56*3f982cf4SFabien Sanglard 
set_audio_only(bool audio_only)57*3f982cf4SFabien Sanglard   void set_audio_only(bool audio_only) { audio_only_ = audio_only; }
audio_only()58*3f982cf4SFabien Sanglard   bool audio_only() const { return audio_only_; }
59*3f982cf4SFabien Sanglard 
60*3f982cf4SFabien Sanglard   // TlsConnection::Client overrides.
61*3f982cf4SFabien Sanglard   void OnError(TlsConnection* connection, Error error) override;
62*3f982cf4SFabien Sanglard   void OnRead(TlsConnection* connection, std::vector<uint8_t> block) override;
63*3f982cf4SFabien Sanglard 
GetWeakPtr()64*3f982cf4SFabien Sanglard   WeakPtr<CastSocket> GetWeakPtr() const { return weak_factory_.GetWeakPtr(); }
65*3f982cf4SFabien Sanglard 
66*3f982cf4SFabien Sanglard  private:
67*3f982cf4SFabien Sanglard   enum class State : bool {
68*3f982cf4SFabien Sanglard     kOpen = true,
69*3f982cf4SFabien Sanglard     kError = false,
70*3f982cf4SFabien Sanglard   };
71*3f982cf4SFabien Sanglard 
72*3f982cf4SFabien Sanglard   static int g_next_socket_id_;
73*3f982cf4SFabien Sanglard 
74*3f982cf4SFabien Sanglard   const std::unique_ptr<TlsConnection> connection_;
75*3f982cf4SFabien Sanglard   Client* client_;  // May never be null.
76*3f982cf4SFabien Sanglard   const int socket_id_;
77*3f982cf4SFabien Sanglard   bool audio_only_ = false;
78*3f982cf4SFabien Sanglard   std::vector<uint8_t> read_buffer_;
79*3f982cf4SFabien Sanglard   State state_ = State::kOpen;
80*3f982cf4SFabien Sanglard 
81*3f982cf4SFabien Sanglard   WeakPtrFactory<CastSocket> weak_factory_{this};
82*3f982cf4SFabien Sanglard };
83*3f982cf4SFabien Sanglard 
84*3f982cf4SFabien Sanglard // Returns socket->socket_id() if |socket| is not null, otherwise 0.
ToCastSocketId(CastSocket * socket)85*3f982cf4SFabien Sanglard constexpr int ToCastSocketId(CastSocket* socket) {
86*3f982cf4SFabien Sanglard   return socket ? socket->socket_id() : 0;
87*3f982cf4SFabien Sanglard }
88*3f982cf4SFabien Sanglard 
89*3f982cf4SFabien Sanglard }  // namespace cast
90*3f982cf4SFabien Sanglard }  // namespace openscreen
91*3f982cf4SFabien Sanglard 
92*3f982cf4SFabien Sanglard #endif  // CAST_COMMON_PUBLIC_CAST_SOCKET_H_
93