F´ Flight Software - C/C++ Documentation
A framework for building embedded system applications to NASA flight quality standards.
TcpClientComponentImpl.hpp
Go to the documentation of this file.
1 // ======================================================================
2 // \title TcpClientComponentImpl.hpp
3 // \author mstarch
4 // \brief hpp file for TcpClientComponentImpl component implementation class
5 //
6 // \copyright
7 // Copyright 2009-2020, by the California Institute of Technology.
8 // ALL RIGHTS RESERVED. United States Government Sponsorship
9 // acknowledged.
10 //
11 // ======================================================================
12 
13 #ifndef TcpClientComponentImpl_HPP
14 #define TcpClientComponentImpl_HPP
15 
16 #include <Drv/Ip/IpSocket.hpp>
20 
21 namespace Drv {
22 
24  friend class TcpClientTester;
25 
26  public:
27  // ----------------------------------------------------------------------
28  // Construction, initialization, and destruction
29  // ----------------------------------------------------------------------
30 
35  TcpClientComponentImpl(const char* const compName);
36 
41 
42  // ----------------------------------------------------------------------
43  // Helper methods to start and stop socket
44  // ----------------------------------------------------------------------
45 
62  SocketIpStatus configure(const char* hostname,
63  const U16 port,
64  const U32 send_timeout_seconds = SOCKET_SEND_TIMEOUT_SECONDS,
65  const U32 send_timeout_microseconds = SOCKET_SEND_TIMEOUT_MICROSECONDS,
66  FwSizeType buffer_size = 1024);
67 
68  protected:
69  // ----------------------------------------------------------------------
70  // Implementations for socket read task virtual methods
71  // ----------------------------------------------------------------------
72 
81  IpSocket& getSocketHandler() override;
82 
91  Fw::Buffer getBuffer() override;
92 
101  void sendBuffer(Fw::Buffer buffer, SocketIpStatus status) override;
102 
106  void connected() override;
107 
108  private:
109  // ----------------------------------------------------------------------
110  // Handler implementations for user-defined typed input ports
111  // ----------------------------------------------------------------------
112 
127  Drv::ByteStreamStatus send_handler(const FwIndexType portNum, Fw::Buffer& fwBuffer) override;
128 
132  void recvReturnIn_handler(FwIndexType portNum,
133  Fw::Buffer& fwBuffer
134  ) override;
135 
136  Drv::TcpClientSocket m_socket;
137 
138  // Member variable to store the buffer size
139  FwSizeType m_allocation_size;
140 };
141 
142 } // end namespace Drv
143 
144 #endif // end TcpClientComponentImpl
Fw::Buffer getBuffer() override
returns a buffer to fill with data
PlatformSizeType FwSizeType
~TcpClientComponentImpl()
Destroy the component.
Auto-generated base for TcpClient component.
SocketIpStatus configure(const char *hostname, const U16 port, const U32 send_timeout_seconds=SOCKET_SEND_TIMEOUT_SECONDS, const U32 send_timeout_microseconds=SOCKET_SEND_TIMEOUT_MICROSECONDS, FwSizeType buffer_size=1024)
Configures the TcpClient settings but does not open the connection.
TcpClientComponentImpl(const char *const compName)
construct the TcpClient component.
IpSocket & getSocketHandler() override
returns a reference to the socket handler
supports a task to read a given socket adaptation
Status returned by the send call.
void connected() override
called when the IPv4 system has been connected
PlatformIndexType FwIndexType
SocketIpStatus
Status enumeration for socket return values.
Definition: IpSocket.hpp:29
Helper base-class for setting up Berkeley sockets.
Definition: IpSocket.hpp:57
void sendBuffer(Fw::Buffer buffer, SocketIpStatus status) override
sends a buffer to be filled with data
Helper for setting up Tcp using Berkeley sockets as a client.