Kea
1.9.9-git
|
Structure that holds a lease for IPv4 address. More...
#include <lease.h>
Public Member Functions | |
Lease4 (const isc::asiolink::IOAddress &addr, const HWAddrPtr &hwaddr, const uint8_t *clientid, size_t clientid_len, uint32_t valid_lft, time_t cltt, uint32_t subnet_id, const bool fqdn_fwd=false, const bool fqdn_rev=false, const std::string &hostname="") | |
Constructor. More... | |
Lease4 (const isc::asiolink::IOAddress &address, const HWAddrPtr &hw_address, const ClientIdPtr &client_id, const uint32_t valid_lifetime, const time_t cltt, const SubnetID subnet_id, const bool fqdn_fwd=false, const bool fqdn_rev=false, const std::string &hostname="") | |
Constructor. More... | |
Lease4 () | |
Default constructor. More... | |
Lease4 (const Lease4 &other) | |
Copy constructor. More... | |
bool | belongsToClient (const HWAddrPtr &hw_address, const ClientIdPtr &client_id) const |
Check if the lease belongs to the client with the given identifiers. More... | |
void | decline (uint32_t probation_period) |
Sets IPv4 lease to declined state. More... | |
const std::vector< uint8_t > & | getClientIdVector () const |
Returns a client identifier. More... | |
bool | operator!= (const Lease4 &other) const |
Compare two leases for inequality. More... | |
Lease4 & | operator= (const Lease4 &other) |
Assignment operator. More... | |
bool | operator== (const Lease4 &other) const |
Compare two leases for equality. More... | |
virtual isc::data::ElementPtr | toElement () const |
Return the JSON representation of a lease. More... | |
virtual std::string | toText () const |
Convert lease to printable form. More... | |
Public Member Functions inherited from isc::dhcp::Lease | |
Lease (const isc::asiolink::IOAddress &addr, uint32_t valid_lft, SubnetID subnet_id, time_t cltt, const bool fqdn_fwd, const bool fqdn_rev, const std::string &hostname, const HWAddrPtr &hwaddr) | |
Constructor. More... | |
virtual | ~Lease () |
Destructor. More... | |
bool | expired () const |
returns true if the lease is expired More... | |
bool | stateExpiredReclaimed () const |
Indicates if the lease is in the "expired-reclaimed" state. More... | |
bool | stateDeclined () const |
Indicates if the lease is in the "declined" state. More... | |
bool | hasIdenticalFqdn (const Lease &other) const |
Returns true if the other lease has equal FQDN data. More... | |
const std::vector< uint8_t > & | getHWAddrVector () const |
Returns raw (as vector) hardware address. More... | |
int64_t | getExpirationTime () const |
Returns lease expiration time. More... | |
void | updateCurrentExpirationTime () |
Update lease current expiration time with new value, so that additional operations can be done without performing extra read from the database. More... | |
Public Member Functions inherited from isc::data::UserContext | |
void | contextToElement (data::ElementPtr map) const |
Merge unparse a user_context object. More... | |
data::ConstElementPtr | getContext () const |
Returns const pointer to the user context. More... | |
void | setContext (const data::ConstElementPtr &ctx) |
Sets user context. More... | |
Public Member Functions inherited from isc::data::CfgToElement | |
virtual | ~CfgToElement () |
Destructor. More... | |
Static Public Member Functions | |
static Lease4Ptr | fromElement (const data::ConstElementPtr &element) |
Returns pointer to the IPv4 lease created from JSON representation. More... | |
static std::string | statesToText (const uint32_t state) |
Returns name of the lease states specific to DHCPv4. More... | |
Static Public Member Functions inherited from isc::dhcp::Lease | |
static std::string | lifetimeToText (uint32_t lifetime) |
Print lifetime. More... | |
static Type | textToType (const std::string &text) |
Converts type name to the actual type. More... | |
static std::string | typeToText (Type type) |
returns text representation of a lease type More... | |
static std::string | basicStatesToText (const uint32_t state) |
Returns name(s) of the basic lease state(s). More... | |
static void | syncCurrentExpirationTime (const Lease &from, Lease &to) |
Sync lease current expiration time with new value from another lease, so that additional operations can be done without performing extra read from the database. More... | |
Static Public Member Functions inherited from isc::data::UserContext | |
static data::ElementPtr | toElement (data::ConstElementPtr map) |
Copy an Element map. More... | |
Public Attributes | |
ClientIdPtr | client_id_ |
Client identifier. More... | |
Public Attributes inherited from isc::dhcp::Lease | |
isc::asiolink::IOAddress | addr_ |
IPv4 ot IPv6 address. More... | |
uint32_t | valid_lft_ |
Valid lifetime. More... | |
uint32_t | current_valid_lft_ |
Current valid lifetime. More... | |
uint32_t | reuseable_valid_lft_ |
Remaining valid lifetime. More... | |
time_t | cltt_ |
Client last transmission time. More... | |
time_t | current_cltt_ |
Current client last transmission time. More... | |
SubnetID | subnet_id_ |
Subnet identifier. More... | |
std::string | hostname_ |
Client hostname. More... | |
bool | fqdn_fwd_ |
Forward zone updated? More... | |
bool | fqdn_rev_ |
Reverse zone updated? More... | |
HWAddrPtr | hwaddr_ |
Client's MAC/hardware address. More... | |
uint32_t | state_ |
Holds the lease state(s). More... | |
Additional Inherited Members | |
Public Types inherited from isc::dhcp::Lease | |
enum | Type { TYPE_NA = 0, TYPE_TA = 1, TYPE_PD = 2, TYPE_V4 = 3 } |
Type of lease or pool. More... | |
Static Public Attributes inherited from isc::dhcp::Lease | |
static const uint32_t | INFINITY_LFT = 0xffffffff |
Infinity (means static, i.e. never expire) More... | |
static const uint32_t | STATE_DEFAULT = 0x0 |
A lease in the default state. More... | |
static const uint32_t | STATE_DECLINED = 0x1 |
Declined lease. More... | |
static const uint32_t | STATE_EXPIRED_RECLAIMED = 0x2 |
Expired and reclaimed lease. More... | |
Static Protected Member Functions inherited from isc::dhcp::Lease | |
static void | fromElementCommon (const LeasePtr &lease, const data::ConstElementPtr &element) |
Sets common (for v4 and v6) properties of the lease object. More... | |
Protected Attributes inherited from isc::data::UserContext | |
data::ConstElementPtr | user_context_ |
Pointer to the user context (may be NULL) More... | |
Structure that holds a lease for IPv4 address.
For performance reasons it is a simple structure, not a class. If we chose make it a class, all fields would have to made private and getters/setters would be required. As this is a critical part of the code that will be used extensively, direct access is warranted.
|
inline |
Constructor.
addr | IPv4 address. |
hwaddr | A pointer to HWAddr structure |
clientid | Client identification buffer |
clientid_len | Length of client identification buffer |
valid_lft | Lifetime of the lease |
cltt | Client last transmission time |
subnet_id | Subnet identification |
fqdn_fwd | If true, forward DNS update is performed for a lease. |
fqdn_rev | If true, reverse DNS update is performed for a lease. |
hostname | FQDN of the client which gets the lease. |
isc::dhcp::Lease4::Lease4 | ( | const isc::asiolink::IOAddress & | address, |
const HWAddrPtr & | hw_address, | ||
const ClientIdPtr & | client_id, | ||
const uint32_t | valid_lifetime, | ||
const time_t | cltt, | ||
const SubnetID | subnet_id, | ||
const bool | fqdn_fwd = false , |
||
const bool | fqdn_rev = false , |
||
const std::string & | hostname = "" |
||
) |
Constructor.
address | IPv4 address. |
hw_address | Pointer to client's HW address. |
client_id | pointer to the client id structure. |
valid_lifetime | Valid lifetime value. |
cltt | Timestamp when the lease is acquired, renewed. |
subnet_id | Subnet identifier. |
fqdn_fwd | Forward DNS update performed. |
fqdn_rev | Reverse DNS update performed. |
hostname | Client's name for the DNS update.. |
|
inline |
Default constructor.
Initialize fields that don't have a default constructor.
Definition at line 351 of file lease.h.
Referenced by fromElement().
isc::dhcp::Lease4::Lease4 | ( | const Lease4 & | other | ) |
Copy constructor.
other | the Lease4 object to be copied. |
Definition at line 293 of file lease.cc.
References client_id_, isc::data::UserContext::getContext(), isc::dhcp::Lease::hwaddr_, isc::data::UserContext::setContext(), and isc::dhcp::Lease::state_.
bool isc::dhcp::Lease4::belongsToClient | ( | const HWAddrPtr & | hw_address, |
const ClientIdPtr & | client_id | ||
) | const |
Check if the lease belongs to the client with the given identifiers.
This method checks if the lease belongs to the client using the specified HW address and/or client identifier. Note that any of the pointers passed to this method may be set to null, in which case they are treated as unspecified and are not used for matching the client with the lease.
According to the DHCPv4 specifications, the client identifier takes precedence over the HW address when identifying the lease for the client on the server side. In particular, the RFC4361 introduces the use of DUID for DHCPv4 which should be a stable identifier for the client. The use of stable identifier allows for the correlation of the DHCPv4 and DHCPv6 clients in the dual stack networks. It also allows for allocating the same lease to the client which hardware (and thus MAC address) has changed.
By default, Kea respects the precedence of the client identifier over MAC address and when this method finds the match of the client identifier with the client identifier stored in the lease, it will treat the lease as the lease of this client, even when the HW address doesn't match.
The HW address is used for matching the client with the lease only when the lease is not associated with any client identifier (client identifier for the lease is null) or when the client identifier parameter passed to this method is null. This facilitates the following cases:
Note that the typical case when the server's administrator may want to disable matching the client identifier passed in the client's message is when the client is performing multi-stage boot. In such case, the client identifiers may change on various stages of the boot, but the HW address will remain stable. The server's administrator prefers using the HW address for client identification in this case.
It may also be useful to disable matching client identifiers to mitigate the problem of broken client implementations which generate new client identifiers every time they connect to the network.
hw_address | Pointer to the HW address of the client. |
client_id | Pointer to the client identifier structure. |
Definition at line 361 of file lease.cc.
References client_id_, isc::util::equalValues(), and isc::dhcp::Lease::hwaddr_.
|
virtual |
Sets IPv4 lease to declined state.
See Lease::decline for detailed description.
probation_period | valid lifetime will be set to this value |
Implements isc::dhcp::Lease.
Definition at line 378 of file lease.cc.
References client_id_, isc::dhcp::Lease::cltt_, isc::dhcp::Lease::fqdn_fwd_, isc::dhcp::Lease::fqdn_rev_, isc::dhcp::Lease::hostname_, isc::dhcp::Lease::hwaddr_, isc::dhcp::Lease::state_, isc::dhcp::Lease::STATE_DECLINED, and isc::dhcp::Lease::valid_lft_.
|
static |
Returns pointer to the IPv4 lease created from JSON representation.
element | pointer to the data element object to be parsed. |
Definition at line 450 of file lease.cc.
References isc::dhcp::Lease::fromElementCommon(), isc::dhcp::ClientId::fromText(), isc_throw, and Lease4().
const std::vector< uint8_t > & isc::dhcp::Lease4::getClientIdVector | ( | ) | const |
Returns a client identifier.
Definition at line 342 of file lease.cc.
References client_id_.
|
inline |
Assignment operator.
other | the Lease4 object to be assigned. |
Definition at line 390 of file lease.cc.
References isc::dhcp::Lease::addr_, client_id_, isc::dhcp::Lease::cltt_, isc::dhcp::Lease::current_cltt_, isc::dhcp::Lease::current_valid_lft_, isc::dhcp::Lease::fqdn_fwd_, isc::dhcp::Lease::fqdn_rev_, isc::data::UserContext::getContext(), isc::dhcp::Lease::hostname_, isc::dhcp::Lease::hwaddr_, isc::dhcp::Lease::reuseable_valid_lft_, isc::data::UserContext::setContext(), isc::dhcp::Lease::state_, isc::dhcp::Lease::subnet_id_, and isc::dhcp::Lease::valid_lft_.
bool isc::dhcp::Lease4::operator== | ( | const Lease4 & | other | ) | const |
Compare two leases for equality.
other | lease6 object with which to compare |
Definition at line 598 of file lease.cc.
References isc::dhcp::Lease::addr_, client_id_, isc::dhcp::Lease::cltt_, isc::dhcp::Lease::current_cltt_, isc::dhcp::Lease::current_valid_lft_, isc::dhcp::Lease::fqdn_fwd_, isc::dhcp::Lease::fqdn_rev_, isc::data::UserContext::getContext(), isc::dhcp::Lease::hostname_, isc::dhcp::Lease::hwaddr_, isc::util::nullOrEqualValues(), isc::dhcp::Lease::reuseable_valid_lft_, isc::dhcp::Lease::state_, isc::dhcp::Lease::subnet_id_, and isc::dhcp::Lease::valid_lft_.
|
static |
Returns name of the lease states specific to DHCPv4.
state | Numeric value holding lease states. |
Definition at line 337 of file lease.cc.
References isc::dhcp::Lease::basicStatesToText().
Referenced by toText().
|
virtual |
Return the JSON representation of a lease.
Implements isc::data::CfgToElement.
Definition at line 425 of file lease.cc.
References isc::dhcp::Lease::addr_, client_id_, isc::dhcp::Lease::cltt_, isc::data::UserContext::contextToElement(), isc::dhcp::Lease::fqdn_fwd_, isc::dhcp::Lease::fqdn_rev_, isc::dhcp::Lease::hostname_, isc::dhcp::Lease::hwaddr_, isc::dhcp::Lease::state_, isc::dhcp::Lease::subnet_id_, isc::asiolink::IOAddress::toText(), and isc::dhcp::Lease::valid_lft_.
Referenced by isc::ha::CommandCreator::createLease4Delete(), and isc::ha::CommandCreator::createLease4Update().
|
virtual |
Convert lease to printable form.
Implements isc::dhcp::Lease.
Definition at line 578 of file lease.cc.
References isc::dhcp::Lease::addr_, client_id_, isc::dhcp::Lease::cltt_, isc::data::UserContext::getContext(), isc::dhcp::Lease::hwaddr_, isc::dhcp::Lease::lifetimeToText(), isc::dhcp::Lease::state_, statesToText(), isc::dhcp::Lease::subnet_id_, and isc::dhcp::Lease::valid_lft_.
ClientIdPtr isc::dhcp::Lease4::client_id_ |
Client identifier.
Definition at line 300 of file lease.h.
Referenced by isc::dhcp::CSVLeaseFile4::append(), belongsToClient(), decline(), getClientIdVector(), Lease4(), operator=(), operator==(), toElement(), and toText().