30 uint8_t prefix_len, uint32_t pref, uint32_t valid)
31 :
Option6IAAddr(type, prefix, pref, valid), prefix_len_(prefix_len) {
34 if (prefix_len > 128) {
36 <<
" is not a valid prefix length. "
37 <<
"Allowed range is 0..128");
42 OptionBuffer::const_iterator end)
50 return (cloneInternal<Option6IAPrefix>());
58 buf.writeUint16(
type_);
66 buf.writeUint8(prefix_len_);
68 buf.writeData(&
addr_.
toBytes()[0], isc::asiolink::V6ADDRESS_LEN);
75 OptionBuffer::const_iterator end) {
81 begin +=
sizeof(uint32_t);
84 begin +=
sizeof(uint32_t);
87 begin +=
sizeof(uint8_t);
91 mask(begin, begin + V6ADDRESS_LEN, prefix_len_, address_with_mask);
93 begin += V6ADDRESS_LEN;
100 std::stringstream output;
102 <<
"prefix=" <<
addr_ <<
"/" <<
static_cast<int>(prefix_len_)
104 <<
", valid-lft=" <<
valid_;
107 return (output.str());
116 length += it.second->len();
122Option6IAPrefix::mask(OptionBuffer::const_iterator begin,
123 OptionBuffer::const_iterator end,
126 output_address.resize(16, 0);
128 std::copy(begin, end, output_address.begin());
129 }
else if (
len > 0) {
132 std::copy(begin, begin +
static_cast<uint8_t
>(
len/8), output_address.begin());
141 output_address[
len/8] = (*(begin +
len/8) & (0xFF << (8 - (
len % 8))));
A generic exception that is thrown if a parameter given to a method is considered invalid in that con...
A generic exception that is thrown if a parameter given to a method would refer to or modify out-of-r...
The IOAddress class represents an IP addresses (version agnostic)
bool isV6() const
Convenience function to check for an IPv6 address.
std::vector< uint8_t > toBytes() const
Return address as set of bytes.
static IOAddress fromBytes(short family, const uint8_t *data)
Creates an address from over wire data.
unsigned int valid_
contains valid-lifetime timer (in seconds)
isc::asiolink::IOAddress addr_
contains an IPv6 address
unsigned int preferred_
contains preferred-lifetime timer (in seconds)
static const size_t OPTION6_IAPREFIX_LEN
length of the fixed part of the IAPREFIX option
virtual std::string toText(int indent=0) const
Returns string representation of the option.
virtual void unpack(OptionBufferConstIter begin, OptionBufferConstIter end)
Parses received buffer.
Option6IAPrefix(uint16_t type, const isc::asiolink::IOAddress &addr, uint8_t prefix_length, uint32_t preferred, uint32_t valid)
Constructor, used for options constructed (during transmission).
virtual OptionPtr clone() const
Copies this option and returns a pointer to the copy.
virtual uint16_t len() const
returns data length (data length + DHCPv4/DHCPv6 option header)
void pack(isc::util::OutputBuffer &buf, bool check=true) const
Writes option in wire-format.
uint16_t type_
option type (0-255 for DHCPv4, 0-65535 for DHCPv6)
std::string headerToText(const int indent=0, const std::string &type_name="") const
Returns option header in the textual format.
std::string suboptionsToText(const int indent=0) const
Returns collection of suboptions in the textual format.
void setEncapsulatedSpace(const std::string &encapsulated_space)
Sets the name of the option space encapsulated by this option.
virtual uint16_t getHeaderLen() const
Returns length of header (2 for v4, 4 for v6)
void unpackOptions(const OptionBuffer &buf)
Builds a collection of sub options from the buffer.
void packOptions(isc::util::OutputBuffer &buf, bool check=true) const
Store sub options in a buffer.
static const size_t OPTION6_HDR_LEN
length of any DHCPv6 option header
OptionCollection options_
collection for storing suboptions
The OutputBuffer class is a buffer abstraction for manipulating mutable data.
#define isc_throw(type, stream)
A shortcut macro to insert known values into exception arguments.
std::vector< uint8_t > OptionBuffer
buffer types used in DHCP code.
boost::shared_ptr< Option > OptionPtr
uint32_t readUint32(void const *const buffer, size_t const length)
uint32_t wrapper over readUint.
Defines the logger used by the top-level component of kea-lfc.
#define DHCP6_OPTION_SPACE