// Copyright (C) 2013-2024 Internet Systems Consortium, Inc. ("ISC")
//
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
#ifndef PKT_FILTER_INET6_H
#define PKT_FILTER_INET6_H
#include <dhcp/pkt_filter6.h>
#include <boost/scoped_array.hpp><--- Include file: not found. Please note: Cppcheck does not need standard library headers to get proper results.
namespace isc {
namespace dhcp {
/// @brief A DHCPv6 packet handling class using datagram sockets.
///
/// This class opens a datagram IPv6/UDPv6 socket. It also implements functions
/// to send and receive DHCPv6 messages through this socket. It is a default
/// class to be used by @c IfaceMgr to access IPv6 sockets.
class PktFilterInet6 : public PktFilter6 {
public:
/// @brief Check if the socket received time is supported.
///
/// If true, then packets received through this filter will include
/// a SOCKET_RECEIVED event in its event stack.
///
/// @return True if SO_TIMESTAMP is defined.
virtual bool isSocketReceivedTimeSupported() const;
/// @brief Opens a socket.
///
/// This function opens an IPv6 socket on an interface and binds it to a
/// specified UDP port and IP address. The @c addr value may be set to
/// "::" in which case the address is unspecified and the socket is
/// bound to in6addr_any.
///
/// @param iface Interface descriptor.
/// @param addr Address on the interface to be used to send packets.
/// @param port Port number.
/// @param join_multicast A boolean parameter which indicates whether
/// socket should join All_DHCP_Relay_Agents_and_servers multicast
/// group.
///
/// @return A structure describing a primary and fallback socket.
/// @throw isc::dhcp::SocketConfigError if error occurred when opening
/// or configuring a socket.
virtual SocketInfo openSocket(const Iface& iface,<--- Function in derived class
const isc::asiolink::IOAddress& addr,
const uint16_t port,
const bool join_multicast);
/// @brief Receives DHCPv6 message on the interface.
///
/// This function receives a single DHCPv6 message through a socket
/// open on a specified interface. This function will block if there is
/// no message waiting on the specified socket. Therefore the @c IfaceMgr
/// must first check that there is any message on the socket (using
/// select function) prior to calling this function.
///
/// If the message is received through the socket bound to "any"
/// (in6addr_any) address this function will drop this message if it has
/// been sent to an address other than multicast or link-local.
///
/// @param socket_info A structure holding socket information.
///
/// @return A pointer to received message.
/// @throw isc::dhcp::SocketReadError if error occurred during packet
/// reception.
virtual Pkt6Ptr receive(const SocketInfo& socket_info);<--- Function in derived class
/// @brief Sends DHCPv6 message through a specified interface and socket.
///
/// The function sends a DHCPv6 message through a specified interface and
/// socket. In general, there may be multiple sockets open on a single
/// interface as a single interface may have multiple IPv6 addresses.
///
/// @param iface Interface to be used to send packet.
/// @param sockfd A socket descriptor
/// @param pkt A packet to be sent.
///
/// @return A result of sending the message. It is 0 if successful.
/// @throw isc::dhcp::SocketWriteError if error occurred when sending a
/// packet.
virtual int send(const Iface& iface, uint16_t sockfd, const Pkt6Ptr& pkt);<--- Function in derived class
private:
/// Length of the socket control buffer.
static const size_t CONTROL_BUF_LEN;
};
} // namespace isc::dhcp
} // namespace isc
#endif // PKT_FILTER_INET6_H