1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- // Copyright (C) 2011 Internet Systems Consortium, Inc. ("ISC")
- //
- // Permission to use, copy, modify, and/or distribute this software for any
- // purpose with or without fee is hereby granted, provided that the above
- // copyright notice and this permission notice appear in all copies.
- //
- // THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
- // REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
- // AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
- // INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
- // LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
- // OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
- // PERFORMANCE OF THIS SOFTWARE.
- #ifndef __TCP_ENDPOINT_H
- #define __TCP_ENDPOINT_H 1
- #ifndef ASIO_HPP
- #error "asio.hpp must be included before including this, see asiolink.h as to why"
- #endif
- #include <asiolink/ioendpoint.h>
- namespace asiolink {
- /// \brief The \c TCPEndpoint class is a concrete derived class of
- /// \c IOEndpoint that represents an endpoint of a TCP connection.
- ///
- /// In the current implementation, an object of this class is always
- /// instantiated within the wrapper routines. Applications are expected to
- /// get access to the object via the abstract base class, \c IOEndpoint.
- /// This design may be changed when we generalize the wrapper interface.
- ///
- /// Note: this implementation is optimized for the case where this object
- /// is created from an ASIO endpoint object in a receiving code path
- /// by avoiding to make a copy of the base endpoint. For TCP it may not be
- /// a big deal, but when we receive UDP packets at a high rate, the copy
- /// overhead might be significant.
- class TCPEndpoint : public IOEndpoint {
- public:
- ///
- /// \name Constructors and Destructor
- ///
- //@{
- /// \brief Constructor from a pair of address and port.
- ///
- /// \param address The IP address of the endpoint.
- /// \param port The TCP port number of the endpoint.
- TCPEndpoint(const IOAddress& address, const unsigned short port) :
- asio_endpoint_placeholder_(
- new asio::ip::tcp::endpoint(
- asio::ip::address::from_string(address.toText()), port)),
- asio_endpoint_(*asio_endpoint_placeholder_)
- {}
- /// \brief Constructor from an ASIO TCP endpoint.
- ///
- /// This constructor is designed to be an efficient wrapper for the
- /// corresponding ASIO class, \c tcp::endpoint.
- ///
- /// \param asio_endpoint The ASIO representation of the TCP endpoint.
- TCPEndpoint(const asio::ip::tcp::endpoint& asio_endpoint) :
- asio_endpoint_placeholder_(NULL), asio_endpoint_(asio_endpoint)
- {}
- /// \brief The destructor.
- ~TCPEndpoint() { delete asio_endpoint_placeholder_; }
- //@}
- IOAddress getAddress() const {
- return (asio_endpoint_.address());
- }
- uint16_t getPort() const {
- return (asio_endpoint_.port());
- }
- short getProtocol() const {
- return (asio_endpoint_.protocol().protocol());
- }
- short getFamily() const {
- return (asio_endpoint_.protocol().family());
- }
- // This is not part of the exosed IOEndpoint API but allows
- // direct access to the ASIO implementation of the endpoint
- const asio::ip::tcp::endpoint& getASIOEndpoint() const {
- return (asio_endpoint_);
- }
- private:
- const asio::ip::tcp::endpoint* asio_endpoint_placeholder_;
- const asio::ip::tcp::endpoint& asio_endpoint_;
- };
- } // namespace asiolink
- #endif // __TCP_ENDPOINT_H
|