51#include <boost/algorithm/string.hpp>
52#include <boost/lexical_cast.hpp>
58#include <netinet/in.h>
106 bool echo_client_id = getBoolean(global,
"echo-client-id");
107 cfg->setEchoClientId(echo_client_id);
110 uint32_t probation_period =
111 getUint32(global,
"decline-probation-period");
112 cfg->setDeclinePeriod(probation_period);
115 uint16_t dhcp4o6_port = getUint16(global,
"dhcp4o6-port");
116 cfg->setDhcp4o6Port(dhcp4o6_port);
121 cfg->setContext(user_context);
125 std::string server_tag = getString(global,
"server-tag");
126 cfg->setServerTag(server_tag);
142 bool ip_reservations_unique = getBoolean(global,
"ip-reservations-unique");
143 cfg->setIPReservationsUnique(ip_reservations_unique);
155 if (!dest || !from) {
167 for (
auto const& net : *networks) {
178 for (
auto const& subnet : *subnets) {
196 cfg->sanityChecksLifetime(
"valid-lifetime");
199 cfg->sanityChecksDdnsTtlParameters();
204 sharedNetworksSanityChecks(*networks, global->get(
"shared-networks"));
226 std::set<string> names;
229 for (
auto const& net : networks) {
234 bool authoritative = net->getAuthoritative();
235 string iface = net->getIface();
240 for (
auto const& subnet : *subnets) {
241 if (subnet->getAuthoritative() != authoritative) {
244 <<
" has different authoritative setting "
245 << subnet->getAuthoritative()
246 <<
" than the shared-network itself: "
251 iface = subnet->getIface();
255 if (subnet->getIface().empty()) {
259 if (subnet->getIface() != iface) {
261 <<
" has specified interface " << subnet->getIface()
262 <<
", but earlier subnet in the same shared-network"
263 <<
" or the shared-network itself used " << iface);
268 txt += subnet->toText() +
" ";
273 if (net->getName().empty()) {
275 << txt <<
" is missing mandatory 'name' parameter");
279 if (names.find(net->getName()) != names.end()) {
281 "name " << net->getName() <<
" defined twice.");
283 names.insert(net->getName());
313 bool sock_changed = (sock_cfg && current_sock_cfg &&
314 !sock_cfg->equals(*current_sock_cfg));
321 if (!sock_cfg || !current_sock_cfg || sock_changed) {
358 string parameter_name;
368 mutable_cfg = boost::const_pointer_cast<Element>(config_set);
383 Dhcp4ConfigParser global_parser;
386 global_parser.parseEarly(srv_config, mutable_cfg);
391 parameter_name =
"option-def";
394 parser.
parse(cfg_option_def, option_defs);
399 parameter_name =
"option-data";
402 parser.
parse(cfg_option, option_datas);
406 if (control_socket) {
407 mutable_cfg->remove(
"control-socket");
410 mutable_cfg->set(
"control-sockets", l);
414 if (control_sockets) {
415 parameter_name =
"control-sockets";
417 parser.
parse(*srv_config, control_sockets);
421 if (multi_threading) {
422 parameter_name =
"multi-threading";
424 parser.
parse(*srv_config, multi_threading);
427 bool multi_threading_enabled =
true;
428 uint32_t thread_count = 0;
429 uint32_t queue_size = 0;
431 multi_threading_enabled, thread_count, queue_size);
434 ConstElementPtr queue_control = mutable_cfg->get(
"dhcp-queue-control");
436 parameter_name =
"dhcp-queue-control";
438 srv_config->setDHCPQueueControl(parser.
parse(queue_control, multi_threading_enabled));
442 ConstElementPtr reservations_lookup_first = mutable_cfg->get(
"reservations-lookup-first");
443 if (reservations_lookup_first) {
444 parameter_name =
"reservations-lookup-first";
445 if (multi_threading_enabled) {
448 srv_config->setReservationsLookupFirst(reservations_lookup_first->boolValue());
452 mutable_cfg->get(
"host-reservation-identifiers");
453 if (hr_identifiers) {
454 parameter_name =
"host-reservation-identifiers";
456 parser.
parse(hr_identifiers);
461 parameter_name =
"sanity-checks";
463 parser.
parse(*srv_config, sanity_checks);
467 mutable_cfg->get(
"expired-leases-processing");
468 if (expiration_cfg) {
469 parameter_name =
"expired-leases-processing";
478 if (hooks_libraries) {
479 parameter_name =
"hooks-libraries";
481 HooksConfig& libraries = srv_config->getHooksConfig();
482 hooks_parser.
parse(libraries, hooks_libraries);
484 multi_threading_enabled);
493 parameter_name =
"dhcp-ddns";
497 d2_client_cfg = parser.
parse(dhcp_ddns);
501 if (client_classes) {
502 parameter_name =
"client-classes";
505 parser.
parse(client_classes, AF_INET);
506 srv_config->setClientClassDictionary(dictionary);
511 if (lease_database) {
512 parameter_name =
"lease-database";
514 std::string access_string;
515 parser.
parse(access_string, lease_database);
517 cfg_db_access->setLeaseDbAccessString(access_string);
521 if (hosts_database) {
522 parameter_name =
"hosts-database";
524 std::string access_string;
525 parser.
parse(access_string, hosts_database);
527 cfg_db_access->setHostDbAccessString(access_string);
531 if (hosts_databases) {
532 parameter_name =
"hosts-databases";
534 for (
auto const& it : hosts_databases->listValue()) {
536 std::string access_string;
537 parser.
parse(access_string, it);
538 cfg_db_access->setHostDbAccessString(access_string);
544 if (shared_networks) {
545 parameter_name =
"shared-networks";
553 parser.
parse(cfg, shared_networks);
557 global_parser.copySubnets4(srv_config->getCfgSubnets4(), cfg);
562 parameter_name =
"subnet4";
565 subnets_parser.
parse(srv_config, subnet4);
570 parameter_name =
"reservations";
573 parser.
parse(SUBNET_ID_GLOBAL, reservations, hosts);
574 for (
auto const& h : hosts) {
575 srv_config->getCfgHosts()->add(h);
580 if (config_control) {
581 parameter_name =
"config-control";
594 const std::map<std::string, ConstElementPtr>& values_map =
595 mutable_cfg->mapValue();
597 for (
auto const& config_pair : values_map) {
598 parameter_name = config_pair.first;
601 if ((config_pair.first ==
"option-def") ||
602 (config_pair.first ==
"option-data") ||
603 (config_pair.first ==
"control-socket") ||
604 (config_pair.first ==
"control-sockets") ||
605 (config_pair.first ==
"multi-threading") ||
606 (config_pair.first ==
"dhcp-queue-control") ||
607 (config_pair.first ==
"host-reservation-identifiers") ||
608 (config_pair.first ==
"interfaces-config") ||
609 (config_pair.first ==
"sanity-checks") ||
610 (config_pair.first ==
"expired-leases-processing") ||
611 (config_pair.first ==
"hooks-libraries") ||
612 (config_pair.first ==
"dhcp-ddns") ||
613 (config_pair.first ==
"client-classes") ||
614 (config_pair.first ==
"lease-database") ||
615 (config_pair.first ==
"hosts-database") ||
616 (config_pair.first ==
"hosts-databases") ||
617 (config_pair.first ==
"subnet4") ||
618 (config_pair.first ==
"shared-networks") ||
619 (config_pair.first ==
"reservations") ||
620 (config_pair.first ==
"config-control") ||
621 (config_pair.first ==
"loggers") ||
622 (config_pair.first ==
"compatibility")) {
636 if ( (config_pair.first ==
"renew-timer") ||
637 (config_pair.first ==
"rebind-timer") ||
638 (config_pair.first ==
"valid-lifetime") ||
639 (config_pair.first ==
"min-valid-lifetime") ||
640 (config_pair.first ==
"max-valid-lifetime") ||
641 (config_pair.first ==
"decline-probation-period") ||
642 (config_pair.first ==
"dhcp4o6-port") ||
643 (config_pair.first ==
"echo-client-id") ||
644 (config_pair.first ==
"match-client-id") ||
645 (config_pair.first ==
"authoritative") ||
646 (config_pair.first ==
"next-server") ||
647 (config_pair.first ==
"server-hostname") ||
648 (config_pair.first ==
"boot-file-name") ||
649 (config_pair.first ==
"server-tag") ||
650 (config_pair.first ==
"reservations-global") ||
651 (config_pair.first ==
"reservations-in-subnet") ||
652 (config_pair.first ==
"reservations-out-of-pool") ||
653 (config_pair.first ==
"calculate-tee-times") ||
654 (config_pair.first ==
"t1-percent") ||
655 (config_pair.first ==
"t2-percent") ||
656 (config_pair.first ==
"cache-threshold") ||
657 (config_pair.first ==
"cache-max-age") ||
658 (config_pair.first ==
"hostname-char-set") ||
659 (config_pair.first ==
"hostname-char-replacement") ||
660 (config_pair.first ==
"ddns-send-updates") ||
661 (config_pair.first ==
"ddns-override-no-update") ||
662 (config_pair.first ==
"ddns-override-client-update") ||
663 (config_pair.first ==
"ddns-replace-client-name") ||
664 (config_pair.first ==
"ddns-generated-prefix") ||
665 (config_pair.first ==
"ddns-qualifying-suffix") ||
666 (config_pair.first ==
"ddns-update-on-renew") ||
667 (config_pair.first ==
"ddns-use-conflict-resolution") ||
668 (config_pair.first ==
"ddns-conflict-resolution-mode") ||
669 (config_pair.first ==
"ddns-ttl-percent") ||
670 (config_pair.first ==
"store-extended-info") ||
671 (config_pair.first ==
"statistic-default-sample-count") ||
672 (config_pair.first ==
"statistic-default-sample-age") ||
673 (config_pair.first ==
"early-global-reservations-lookup") ||
674 (config_pair.first ==
"ip-reservations-unique") ||
675 (config_pair.first ==
"reservations-lookup-first") ||
676 (config_pair.first ==
"parked-packet-limit") ||
677 (config_pair.first ==
"allocator") ||
678 (config_pair.first ==
"offer-lifetime") ||
679 (config_pair.first ==
"ddns-ttl") ||
680 (config_pair.first ==
"ddns-ttl-min") ||
681 (config_pair.first ==
"ddns-ttl-max") ||
682 (config_pair.first ==
"stash-agent-options")) {
689 if (config_pair.first ==
"user-context") {
695 "unsupported global configuration parameter: " << config_pair.first
696 <<
" (" << config_pair.second->getPosition() <<
")");
700 parameter_name =
"<post parsing>";
703 global_parser.parse(srv_config, mutable_cfg);
708 global_parser.sanityChecks(srv_config, mutable_cfg);
711 if (!d2_client_cfg) {
714 d2_client_cfg->validateContents();
715 srv_config->setD2ClientConfig(d2_client_cfg);
718 .arg(parameter_name).arg(ex.
what());
729 "Control-socket, hook-libraries, and D2 configuration "
730 "were sanity checked, but not applied.");
738 bool check_only,
bool extra_checks) {
741 "Can't parse NULL config");
762 std::ostringstream err;
772 }
catch (
const std::exception& ex) {
773 err <<
"Error setting packet queue controls after server reconfiguration: "
796 string parameter_name;
805 mutable_cfg = boost::const_pointer_cast<Element>(config_set);
809 parameter_name =
"interfaces-config";
813 parser.
parse(cfg_iface, ifaces_config);
817 .arg(parameter_name).arg(ex.
what());
824 " processing error");
884 bool multi_threading_enabled =
true;
885 uint32_t thread_count = 0;
886 uint32_t queue_size = 0;
888 multi_threading_enabled, thread_count, queue_size);
909 string params =
"universe=4 persist=false";
910 cfg_db->setAppendedParameters(params);
911 cfg_db->createManagers();
912 }
catch (
const std::exception& ex) {
930 CBControlDHCPv4::FetchMode::FETCH_ALL);
932 std::ostringstream err;
933 err <<
"during update from config backend database: " << ex.
what();
939 std::ostringstream err;
940 err <<
"during update from config backend database: "
941 <<
"undefined configuration parsing error";
956 if (notify_libraries) {
957 return (notify_libraries);
964 }
catch (
const std::exception& ex) {
965 std::ostringstream err;
966 err <<
"Error initializing hooks: "
A generic exception that is thrown if a parameter given to a method is considered invalid in that con...
This is a base class for exceptions thrown from the DNS library module.
virtual const char * what() const
Returns a C-style character string of the cause of the exception.
void clearIOServices()
Clear the list of IOService objects.
static IOServiceMgr & instance()
Access the IOServiceMgr singleton instance.
void pollIOServices()
Poll IOService objects.
static std::string getHash(const isc::data::ConstElementPtr &config)
returns a hash of a given Element structure
static HttpCommandMgr & instance()
HttpCommandMgr is a singleton class.
void configure(HttpCommandConfigPtr config)
Configure http control socket from configuration.
static UnixCommandMgr & instance()
UnixCommandMgr is a singleton class.
void closeCommandSocket()
Shuts down any open unix control sockets.
void openCommandSocket(const isc::data::ConstElementPtr &socket_info)
Opens unix control socket with parameters specified in socket_info (required parameters: socket-type:...
static ElementPtr create(const Position &pos=ZERO_POSITION())
static ElementPtr createMap(const Position &pos=ZERO_POSITION())
Creates an empty MapElement type ElementPtr.
static ElementPtr createList(const Position &pos=ZERO_POSITION())
Creates an empty ListElement type ElementPtr.
Parse Database Parameters.
void parse(std::string &access_string, isc::data::ConstElementPtr database_config)
Parse configuration value.
void setD2ClientConfig(D2ClientConfigPtr &new_config)
Updates the DHCP-DDNS client configuration to the given value.
static CfgMgr & instance()
returns a single instance of Configuration Manager
SrvConfigPtr getStagingCfg()
Returns a pointer to the staging configuration.
SrvConfigPtr getCurrentCfg()
Returns a pointer to the current configuration.
static void extract(data::ConstElementPtr value, bool &enabled, uint32_t &thread_count, uint32_t &queue_size)
Extract multi-threading parameters from a given configuration.
Parser for a list of client class definitions.
ClientClassDictionaryPtr parse(isc::data::ConstElementPtr class_def_list, uint16_t family, bool check_dependencies=true)
Parse configuration entries.
void parse(isc::data::ConstElementPtr cfg, isc::dhcp::SrvConfig &srv_cfg)
Parse compatibility flags.
Parser for the control-sockets structure.
void parse(SrvConfig &srv_cfg, isc::data::ConstElementPtr value)
"Parses" control-sockets structure
static isc::data::ConstElementPtr finishConfigHookLibraries(isc::data::ConstElementPtr config)
Configuration checker for hook libraries.
Parser for D2ClientConfig.
D2ClientConfigPtr parse(isc::data::ConstElementPtr d2_client_cfg)
Parses a given dhcp-ddns element into D2ClientConfig.
static size_t setAllDefaults(isc::data::ConstElementPtr d2_config)
Sets all defaults for D2 client configuration.
Acts as a storage vault for D2 client configuration.
Parser for the configuration of DHCP packet queue controls.
data::ElementPtr parse(const isc::data::ConstElementPtr &control_elem, bool multi_threading_enabled)
Parses content of the "dhcp-queue-control".
To be removed. Please use ConfigError instead.
CBControlDHCPv4Ptr getCBControl() const
Returns an object which controls access to the configuration backends.
void discardPackets()
Discards parked packets Clears the packet parking lots of all packets.
Parser for the configuration parameters pertaining to the processing of expired leases.
void parse(isc::data::ConstElementPtr expiration_config, isc::dhcp::CfgExpirationPtr expiration)
Parses parameters in the JSON map, pertaining to the processing of the expired leases.
static void logRegistered()
Logs out all registered backends.
Parser for a list of host identifiers for DHCPv4.
void parse(isc::data::ConstElementPtr ids_list)
Parses a list of host identifiers.
Parser for a list of host reservations for a subnet.
void parse(const SubnetID &subnet_id, isc::data::ConstElementPtr hr_list, HostCollection &hosts_list)
Parses a list of host reservation entries for a subnet.
static IfaceMgr & instance()
IfaceMgr is a singleton class.
void closeSockets()
Closes all open sockets.
Parser for the configuration of interfaces.
void parse(const CfgIfacePtr &config, const isc::data::ConstElementPtr &values)
Parses content of the "interfaces-config".
static void logRegistered()
Logs out all registered backends.
static void setRuntimeOptionDefs(const OptionDefSpaceContainer &defs)
Copies option definitions created at runtime.
static void revertRuntimeOptionDefs()
Reverts uncommitted changes to runtime option definitions.
Simple parser for multi-threading structure.
void parse(SrvConfig &srv_cfg, const isc::data::ConstElementPtr &value)
parses JSON structure.
Parser for option data values within a subnet.
void parse(const CfgOptionPtr &cfg, isc::data::ConstElementPtr option_data_list, bool encapsulate=true)
Parses a list of options, instantiates them and stores in cfg.
Parser for a list of option definitions.
void parse(CfgOptionDefPtr cfg, isc::data::ConstElementPtr def_list)
Parses a list of option definitions, create them and store in cfg.
Class of option definition space container.
Simple parser for sanity-checks structure.
void parse(SrvConfig &srv_cfg, const isc::data::ConstElementPtr &value)
parses JSON structure
Parser for a list of shared networks.
void parse(CfgSharedNetworksTypePtr &cfg, const data::ConstElementPtr &shared_networks_list_data)
Parses a list of shared networks.
static size_t deriveParameters(isc::data::ElementPtr global)
Derives (inherits) all parameters from global to more specific scopes.
static size_t setAllDefaults(isc::data::ElementPtr global)
Sets all defaults for DHCPv4 configuration.
static const uint32_t CFGSEL_ALL4
IPv4 related config.
this class parses list of DHCP4 subnets
size_t parse(SrvConfigPtr cfg, data::ConstElementPtr subnets_list, bool encapsulate_options=true)
parses contents of the list
static const TimerMgrPtr & instance()
Returns pointer to the sole instance of the TimerMgr.
Wrapper class that holds hooks libraries configuration.
void verifyLibraries(const isc::data::Element::Position &position, bool multi_threading_enabled) const
Verifies that libraries stored in libraries_ are valid.
void loadLibraries(bool multi_threading_enabled) const
Commits hooks libraries configuration.
Parser for hooks library list.
void parse(HooksConfig &libraries, isc::data::ConstElementPtr value)
Parses parameters value.
static bool unloadLibraries()
Unload libraries.
static void prepareUnloadLibraries()
Prepare the unloading of libraries.
Implements parser for config control information, "config-control".
ConfigControlInfoPtr parse(const data::ConstElementPtr &config_control)
Parses a configuration control Element.
isc::data::ConstElementPtr redactConfig(isc::data::ConstElementPtr const &config)
Redact a configuration.
static MultiThreadingMgr & instance()
Returns a single instance of Multi Threading Manager.
void setTestMode(const bool test_mode)
Sets or clears the test mode for MultiThreadingMgr.
void apply(bool enabled, uint32_t thread_count, uint32_t queue_size)
Apply the multi-threading related settings.
Parsers for client class definitions.
This file contains several functions and constants that are used for handling commands and responses ...
Contains declarations for loggers used by the DHCPv4 server component.
#define isc_throw(type, stream)
A shortcut macro to insert known values into exception arguments.
#define LOG_ERROR(LOGGER, MESSAGE)
Macro to conveniently test error output and log it.
#define LOG_INFO(LOGGER, MESSAGE)
Macro to conveniently test info output and log it.
#define LOG_WARN(LOGGER, MESSAGE)
Macro to conveniently test warn output and log it.
#define LOG_DEBUG(LOGGER, LEVEL, MESSAGE)
Macro to conveniently test debug output and log it.
ConstElementPtr parseAnswer(int &rcode, const ConstElementPtr &msg)
Parses a standard config/command level answer and returns arguments or text status code.
const int CONTROL_RESULT_ERROR
Status code indicating a general failure.
ConstElementPtr createAnswer()
Creates a standard config/command level success answer message (i.e.
boost::shared_ptr< HttpCommandConfig > HttpCommandConfigPtr
Pointer to a HttpCommandConfig object.
const int CONTROL_RESULT_SUCCESS
Status code indicating a successful operation.
boost::shared_ptr< const Element > ConstElementPtr
boost::shared_ptr< Element > ElementPtr
void configureCommandChannel()
Initialize the command channel based on the staging configuration.
const isc::log::MessageID DHCP4_CONFIG_START
boost::shared_ptr< D2ClientConfig > D2ClientConfigPtr
Defines a pointer for D2ClientConfig instances.
const isc::log::MessageID DHCP4_PARSER_EXCEPTION
boost::shared_ptr< CfgOption > CfgOptionPtr
Non-const pointer.
boost::shared_ptr< CfgOptionDef > CfgOptionDefPtr
Non-const pointer.
boost::shared_ptr< CfgDbAccess > CfgDbAccessPtr
A pointer to the CfgDbAccess.
const isc::log::MessageID DHCP4_RESERVATIONS_LOOKUP_FIRST_ENABLED
isc::data::ConstElementPtr processDhcp4Config(isc::data::ConstElementPtr config_set)
Process a DHCPv4 confguration and return an answer stating if the configuration is valid,...
boost::shared_ptr< CfgIface > CfgIfacePtr
A pointer to the CfgIface .
const isc::log::MessageID DHCP4_CONFIG_PACKET_QUEUE
const isc::log::MessageID DHCP4_PARSER_COMMIT_EXCEPTION
boost::shared_ptr< SrvConfig > SrvConfigPtr
Non-const pointer to the SrvConfig.
const isc::log::MessageID DHCP4_PARSER_FAIL
std::vector< HostPtr > HostCollection
Collection of the Host objects.
boost::multi_index_container< Subnet4Ptr, boost::multi_index::indexed_by< boost::multi_index::ordered_unique< boost::multi_index::tag< SubnetSubnetIdIndexTag >, boost::multi_index::const_mem_fun< Subnet, SubnetID, &Subnet::getID > >, boost::multi_index::ordered_unique< boost::multi_index::tag< SubnetPrefixIndexTag >, boost::multi_index::const_mem_fun< Subnet, std::string, &Subnet::toText > > > > Subnet4SimpleCollection
A simple collection of Subnet4 objects.
const int DBG_DHCP4_COMMAND
Debug level used to log receiving commands.
const isc::log::MessageID DHCP4_PARSER_COMMIT_FAIL
boost::shared_ptr< ClientClassDictionary > ClientClassDictionaryPtr
Defines a pointer to a ClientClassDictionary.
isc::data::ConstElementPtr configureDhcp4Server(Dhcpv4Srv &server, isc::data::ConstElementPtr config_set, bool check_only, bool extra_checks)
Configure DHCPv4 server (Dhcpv4Srv) with a set of configuration values.
boost::shared_ptr< CfgSubnets4 > CfgSubnets4Ptr
Non-const pointer.
const isc::log::MessageID DHCP4_CONFIG_COMPLETE
boost::multi_index_container< SharedNetwork4Ptr, boost::multi_index::indexed_by< boost::multi_index::random_access< boost::multi_index::tag< SharedNetworkRandomAccessIndexTag > >, boost::multi_index::hashed_non_unique< boost::multi_index::tag< SharedNetworkIdIndexTag >, boost::multi_index::const_mem_fun< data::BaseStampedElement, uint64_t, &data::BaseStampedElement::getId > >, boost::multi_index::ordered_unique< boost::multi_index::tag< SharedNetworkNameIndexTag >, boost::multi_index::const_mem_fun< SharedNetwork4, std::string, &SharedNetwork4::getName > >, boost::multi_index::ordered_non_unique< boost::multi_index::tag< SharedNetworkServerIdIndexTag >, boost::multi_index::const_mem_fun< Network4, asiolink::IOAddress, &Network4::getServerId > >, boost::multi_index::ordered_non_unique< boost::multi_index::tag< SharedNetworkModificationTimeIndexTag >, boost::multi_index::const_mem_fun< data::BaseStampedElement, boost::posix_time::ptime, &data::BaseStampedElement::getModificationTime > > > > SharedNetwork4Collection
Multi index container holding shared networks.
boost::shared_ptr< CfgSharedNetworks4 > CfgSharedNetworks4Ptr
Pointer to the configuration of IPv4 shared networks.
isc::log::Logger dhcp4_logger(DHCP4_APP_LOGGER_NAME)
Base logger for DHCPv4 server.
boost::shared_ptr< ConfigControlInfo > ConfigControlInfoPtr
Defines a pointer to a ConfigControlInfo.
Defines the logger used by the top-level component of kea-lfc.
static data::ElementPtr toElement(data::ConstElementPtr map)
Copy an Element map.