Kea
1.9.9-git
|
Configuration Manager. More...
#include <cfgmgr.h>
Public Member Functions | |
bool | ddnsEnabled () |
Convenience method for checking if DHCP-DDNS updates are enabled. More... | |
const D2ClientConfigPtr & | getD2ClientConfig () const |
Fetches the DHCP-DDNS configuration pointer. More... | |
D2ClientMgr & | getD2ClientMgr () |
Fetches the DHCP-DDNS manager. More... | |
util::Optional< std::string > | getDataDir () const |
returns path do the data directory More... | |
uint16_t | getFamily () const |
Returns address family. More... | |
void | setD2ClientConfig (D2ClientConfigPtr &new_config) |
Updates the DHCP-DDNS client configuration to the given value. More... | |
void | setDataDir (const std::string &datadir, bool unspecified=true) |
Sets new data directory. More... | |
void | setFamily (uint16_t family) |
Sets address family (AF_INET or AF_INET6) More... | |
Methods managing the collection of configurations. | |
The following methods manage the process of preparing a configuration without affecting a currently used configuration and then committing the configuration to replace current configuration atomically. They also allow for keeping a history of previous configurations so as the
| |
void | clear () |
Removes current, staging and all previous configurations. More... | |
void | commit () |
Commits the staging configuration. More... | |
void | rollback () |
Removes staging configuration. More... | |
void | revert (const size_t index) |
Reverts to one of the previous configurations. More... | |
SrvConfigPtr | getCurrentCfg () |
Returns a pointer to the current configuration. More... | |
SrvConfigPtr | getStagingCfg () |
Returns a pointer to the staging configuration. More... | |
SrvConfigPtr | createExternalCfg () |
Creates an external configuration and returns pointer to it. More... | |
void | mergeIntoStagingCfg (const uint32_t seq) |
Merges external configuration with the given sequence number into the staging configuration. More... | |
void | mergeIntoCurrentCfg (const uint32_t seq) |
Merges external configuration with the given sequence number into the current configuration. More... | |
Static Public Member Functions | |
static CfgMgr & | instance () |
returns a single instance of Configuration Manager More... | |
Static Public Attributes | |
static const size_t | CONFIG_LIST_SIZE = 10 |
A number of configurations held by CfgMgr . More... | |
Protected Member Functions | |
CfgMgr () | |
Protected constructor. More... | |
virtual | ~CfgMgr () |
virtual destructor More... | |
Configuration Manager.
This singleton class holds the whole configuration for DHCPv4 and DHCPv6 servers.
Below is a sketch of configuration inheritance. Let's investigate the following configuration:
Parameters defined in a global scope are applicable to everything until they are overwritten in a smaller scope, in this case subnet6. In the example above, the first subnet6 has preferred lifetime of 500s and a valid lifetime of 1000s. The second subnet has preferred lifetime of 500s, but valid lifetime of 2000s.
Parameter inheritance is implemented in dedicated classes. See isc::dhcp::SimpleParser4::deriveParameters and isc::dhcp::SimpleParser6::deriveParameters.
|
protected |
|
protectedvirtual |
void isc::dhcp::CfgMgr::clear | ( | ) |
void isc::dhcp::CfgMgr::commit | ( | ) |
Commits the staging configuration.
The staging configuration becomes current configuration when this function is called. It removes the oldest configuration held in the history so as the size of the list of configuration does not exceed the CONFIG_LIST_SIZE
.
This function is exception safe.
SrvConfigPtr isc::dhcp::CfgMgr::createExternalCfg | ( | ) |
Creates an external configuration and returns pointer to it.
External configurations are those that come from other sources than from the configuration file, e.g. a database or a command. They are created aside and merged into the staging or current configuration. External configurations are accessed by their sequence numbers. The sequence numbers are autogenerated when the external configuration instance is created.
bool isc::dhcp::CfgMgr::ddnsEnabled | ( | ) |
SrvConfigPtr isc::dhcp::CfgMgr::getCurrentCfg | ( | ) |
Returns a pointer to the current configuration.
This function returns pointer to the current configuration. If the current configuration is not set it will create a default configuration and return it.
In the previous Kea releases this method used to return a const pointer to the current configuration to ensure that it is not accidentally modified while the server is running. This has been changed in Kea 1.3 release and now this function returns a non-const pointer. The reason is that there are certain use cases when current configuration must be modified without going through a full cycle of server reconfiguration, e.g. add a subnet to the current configuration as a result of receiving a command over control API. In such case the performance of processing such command is critical and rebuilding the whole configuration just for this small configuration change is out of question.
Nevertheless, such configuration updates should always be made with caution and one has to make sure that the configuration data integrity is preserved.
Definition at line 161 of file cfgmgr.cc.
Referenced by isc::dhcp::Dhcpv4Srv::acceptServerId(), isc::dhcp::Dhcpv4Srv::adjustIfaceData(), isc::dhcp::Dhcpv6Srv::buildCfgOptionList(), isc::dhcp::Dhcpv4Srv::buildCfgOptionList(), isc::dhcp::SanityChecker::checkLease(), isc::dhcp::PgSqlLeaseMgr::dbReconnect(), isc::dhcp::MySqlLeaseMgr::dbReconnect(), isc::dhcp::PgSqlHostDataSourceImpl::dbReconnect(), isc::dhcp::MySqlHostDataSourceImpl::dbReconnect(), isc::dhcp::Dhcpv4Srv::deferredUnpack(), isc::dhcp::Dhcpv4Exchange::Dhcpv4Exchange(), isc::dhcp::Dhcpv6Srv::evaluateClasses(), isc::dhcp::AllocEngine::ClientContext6::getDdnsParams(), isc::dhcp::AllocEngine::ClientContext4::getDdnsParams(), isc::dhcp::Dhcpv6Srv::getMAC(), isc::dhcp::AllocEngine::getValidLft(), isc::dhcp::Dhcpv6Srv::initContext(), isc::lease_cmds::LeaseCmdsImpl::lease4UpdateHandler(), isc::lease_cmds::LeaseCmdsImpl::lease4WipeHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6BulkApplyHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6UpdateHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6WipeHandler(), isc::lease_cmds::LeaseCmdsImpl::leaseAddHandler(), isc::dhcp::SanityChecker::leaseCheckingEnabled(), isc::stat_cmds::LeaseStatCmdsImpl::makeResultSet4(), isc::stat_cmds::LeaseStatCmdsImpl::makeResultSet6(), isc::dhcp::Dhcpv6Srv::processRSOO(), isc::dhcp::queueNCR(), isc::dhcp::LeaseMgr::recountLeaseStats4(), isc::dhcp::LeaseMgr::recountLeaseStats6(), isc::dhcp::Dhcpv6Srv::requiredClassify(), isc::dhcp::Dhcpv4Srv::requiredClassify(), isc::dhcp::Dhcpv6Srv::selectSubnet(), isc::dhcp::Dhcpv4Srv::selectSubnet(), isc::dhcp::Dhcpv4Srv::selectSubnet4o6(), and isc::dhcp::Dhcpv4Srv::setFixedFields().
const D2ClientConfigPtr & isc::dhcp::CfgMgr::getD2ClientConfig | ( | ) | const |
D2ClientMgr & isc::dhcp::CfgMgr::getD2ClientMgr | ( | ) |
Fetches the DHCP-DDNS manager.
Definition at line 66 of file cfgmgr.cc.
Referenced by isc::dhcp::Dhcpv6Srv::assignIA_NA(), isc::dhcp::Dhcpv6Srv::createNameChangeRequests(), isc::dhcp::Dhcpv6Srv::d2ClientErrorHandler(), isc::dhcp::Dhcpv4Srv::d2ClientErrorHandler(), isc::dhcp::Dhcpv6Srv::extendIA_NA(), isc::dhcp::Dhcpv4Srv::postAllocateNameUpdate(), isc::dhcp::Dhcpv6Srv::processClientFqdn(), isc::dhcp::Dhcpv4Srv::processClientName(), isc::dhcp::Dhcpv6Srv::startD2(), isc::dhcp::Dhcpv4Srv::startD2(), isc::dhcp::Dhcpv6Srv::stopD2(), and isc::dhcp::Dhcpv4Srv::stopD2().
Optional< std::string > isc::dhcp::CfgMgr::getDataDir | ( | ) | const |
returns path do the data directory
This method returns a path to writable directory that DHCP servers can store data in.
Definition at line 31 of file cfgmgr.cc.
Referenced by isc::dhcp::Memfile_LeaseMgr::getDefaultLeaseFilePath(), and isc::dhcp::SrvConfig::toElement().
|
inline |
Returns address family.
Definition at line 280 of file cfgmgr.h.
Referenced by isc::dhcp::SrvConfig::merge(), isc::dhcp::ClientClassDef::toElement(), and isc::dhcp::SrvConfig::toElement().
SrvConfigPtr isc::dhcp::CfgMgr::getStagingCfg | ( | ) |
Returns a pointer to the staging configuration.
The staging configuration is used by the configuration parsers to create new configuration. The staging configuration doesn't affect the server's operation until it is committed. The staging configuration is a non-const object which can be modified by the caller.
Multiple consecutive calls to this function return the same object which can be modified from various places of the code (e.g. various configuration parsers).
Definition at line 167 of file cfgmgr.cc.
Referenced by isc::dhcp::SanityChecker::checkLease(), isc::dhcp::HostReservationIdsParser4::HostReservationIdsParser4(), isc::dhcp::HostReservationIdsParser6::HostReservationIdsParser6(), isc::dhcp::SanityChecker::leaseCheckingEnabled(), isc::dhcp::Dhcp6to4Ipc::open(), isc::dhcp::Dhcp4to6Ipc::open(), isc::dhcp::Subnet4ConfigParser::parse(), and isc::dhcp::Subnet6ConfigParser::parse().
|
static |
returns a single instance of Configuration Manager
CfgMgr is a singleton and this method is the only way of accessing it.
Definition at line 25 of file cfgmgr.cc.
Referenced by isc::dhcp::Dhcpv4Srv::acceptServerId(), isc::dhcp::Dhcpv4Srv::adjustIfaceData(), isc::dhcp::Dhcpv6Srv::assignIA_NA(), isc::dhcp::Dhcpv6Srv::buildCfgOptionList(), isc::dhcp::Dhcpv4Srv::buildCfgOptionList(), isc::dhcp::SanityChecker::checkLease(), isc::dhcp::Dhcpv6Srv::createNameChangeRequests(), isc::dhcp::Dhcpv6Srv::d2ClientErrorHandler(), isc::dhcp::Dhcpv4Srv::d2ClientErrorHandler(), isc::dhcp::PgSqlLeaseMgr::dbReconnect(), isc::dhcp::MySqlLeaseMgr::dbReconnect(), isc::dhcp::PgSqlHostDataSourceImpl::dbReconnect(), isc::dhcp::MySqlHostDataSourceImpl::dbReconnect(), isc::dhcp::Dhcpv4Srv::declineLease(), isc::dhcp::Dhcpv6Srv::declineLease(), isc::dhcp::Dhcpv4Srv::deferredUnpack(), isc::dhcp::Dhcpv4Exchange::Dhcpv4Exchange(), isc::dhcp::Dhcpv6Srv::evaluateClasses(), isc::dhcp::Dhcpv6Srv::extendIA_NA(), isc::dhcp::AllocEngine::ClientContext6::getDdnsParams(), isc::dhcp::AllocEngine::ClientContext4::getDdnsParams(), isc::dhcp::Memfile_LeaseMgr::getDefaultLeaseFilePath(), isc::dhcp::Dhcpv6Srv::getMAC(), isc::dhcp::AllocEngine::getValidLft(), isc::dhcp::HostReservationIdsParser4::HostReservationIdsParser4(), isc::dhcp::HostReservationIdsParser6::HostReservationIdsParser6(), isc::dhcp::Dhcpv6Srv::initContext(), isc::lease_cmds::LeaseCmdsImpl::lease4ResendDdnsHandler(), isc::lease_cmds::LeaseCmdsImpl::lease4UpdateHandler(), isc::lease_cmds::LeaseCmdsImpl::lease4WipeHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6BulkApplyHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6ResendDdnsHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6UpdateHandler(), isc::lease_cmds::LeaseCmdsImpl::lease6WipeHandler(), isc::lease_cmds::LeaseCmdsImpl::leaseAddHandler(), isc::dhcp::SanityChecker::leaseCheckingEnabled(), isc::stat_cmds::LeaseStatCmdsImpl::makeResultSet4(), isc::stat_cmds::LeaseStatCmdsImpl::makeResultSet6(), isc::dhcp::SrvConfig::merge(), isc::dhcp::Dhcp6to4Ipc::open(), isc::dhcp::Dhcp4to6Ipc::open(), isc::dhcp::SharedNetwork4Parser::parse(), isc::dhcp::SharedNetwork6Parser::parse(), isc::dhcp::Subnet4ConfigParser::parse(), isc::dhcp::Subnet6ConfigParser::parse(), isc::dhcp::Dhcpv4Srv::postAllocateNameUpdate(), isc::dhcp::Dhcpv6Srv::processClientFqdn(), isc::dhcp::Dhcpv4Srv::processClientName(), isc::dhcp::Dhcpv6Srv::processRSOO(), isc::dhcp::queueNCR(), isc::dhcp::LeaseMgr::recountLeaseStats4(), isc::dhcp::LeaseMgr::recountLeaseStats6(), isc::dhcp::Dhcpv6Srv::requiredClassify(), isc::dhcp::Dhcpv4Srv::requiredClassify(), isc::dhcp::Dhcpv6Srv::selectSubnet(), isc::dhcp::Dhcpv4Srv::selectSubnet(), isc::dhcp::Dhcpv4Srv::selectSubnet4o6(), isc::dhcp::Dhcpv4Srv::setFixedFields(), isc::dhcp::Dhcpv6Srv::startD2(), isc::dhcp::Dhcpv4Srv::startD2(), isc::dhcp::Dhcpv6Srv::stopD2(), isc::dhcp::Dhcpv4Srv::stopD2(), isc::dhcp::ClientClassDef::toElement(), and isc::dhcp::SrvConfig::toElement().
void isc::dhcp::CfgMgr::mergeIntoCurrentCfg | ( | const uint32_t | seq | ) |
Merges external configuration with the given sequence number into the current configuration.
After the merge, the source configuration is discarded from the CfgMgr
as it should not be used anymore.
seq | Source configuration sequence number. |
BadValue | if the external configuration with the given sequence number doesn't exist. |
void isc::dhcp::CfgMgr::mergeIntoStagingCfg | ( | const uint32_t | seq | ) |
Merges external configuration with the given sequence number into the staging configuration.
After the merge, the source configuration is discarded from the CfgMgr
as it should not be used anymore.
seq | Source configuration sequence number. |
BadValue | if the external configuration with the given sequence number doesn't exist. |
void isc::dhcp::CfgMgr::revert | ( | const size_t | index | ) |
Reverts to one of the previous configurations.
This function reverts to selected previous configuration. The previous configuration is entirely copied to a new SrvConfig
instance. This new instance has a unique sequence id (sequence id is not copied). The previous configuration (being copied) is not modified by this operation.
The configuration to be copied is identified by the index value which is the distance between the current (most recent) and desired configuration. If the index is out of range an exception is thrown.
index | A distance from the current configuration to the past configuration to be reverted. The minimal value is 1 which points to the nearest configuration. |
isc::OutOfRange | if the specified index is out of range. |
Definition at line 128 of file cfgmgr.cc.
References isc_throw.
void isc::dhcp::CfgMgr::rollback | ( | ) |
Removes staging configuration.
This function should be called when there is a staging configuration (likely created in the previous configuration attempt) but the entirely new configuration should be created. It removes the existing staging configuration and the next call to CfgMgr::getStagingCfg
will return a fresh (default) configuration.
This function is exception safe.
void isc::dhcp::CfgMgr::setD2ClientConfig | ( | D2ClientConfigPtr & | new_config | ) |
Updates the DHCP-DDNS client configuration to the given value.
Passes the new configuration to the D2ClientMgr instance, d2_client_mgr_, which will attempt to apply the new configuration by shutting down its sender and opening a new connection per the new configuration (see D2ClientMgr::setD2ClientConfig()
).
new_config | pointer to the new client configuration. |
Underlying | method(s) will throw D2ClientError if given an empty pointer. |
void isc::dhcp::CfgMgr::setDataDir | ( | const std::string & | datadir, |
bool | unspecified = true |
||
) |
|
inline |
|
static |