52namespace ph = std::placeholders;
57struct CtrlDhcp6Hooks {
58 int hooks_index_dhcp6_srv_configured_;
74static const char* SERVER_DUID_FILE =
"kea-dhcp6-serverid";
85void signalHandler(
int signo) {
87 if (signo == SIGHUP) {
89 }
else if ((signo == SIGTERM) || (signo == SIGINT)) {
104 start_ = boost::posix_time::second_clock::universal_time();
112 string reason = comment ? comment->stringValue() :
113 "no details available";
142 if (file_name.empty()) {
145 " Please use -c command line option.");
159 "a map, i.e., start with { and end with } and contain "
160 "at least an entry called 'Dhcp6' that itself is a map. "
162 <<
" is a valid JSON, but its top element is not a map."
163 " Did you forget to add { } around your configuration?");
173 "process command \"config-set\"");
181 string reason = comment ? comment->stringValue() :
182 "no details available";
185 }
catch (
const std::exception& ex) {
191 .arg(file_name).arg(ex.what());
193 << file_name <<
"': " << ex.what());
227 "parameter 'exit-value' is not an integer"));
230 exit_value = param->intValue();
243 "Illegal operation executing 'config-reload' on a different thread than main thread"));
252 }
catch (
const std::exception& ex) {
259 "Config reload failed: " +
string(ex.what())));
295 if (filename_param) {
298 "passed parameter 'filename' is not a string"));
300 filename = filename_param->stringValue();
304 if (filename.empty()) {
308 if (filename.empty()) {
310 "Please specify filename explicitly."));
316 std::ostringstream msg;
317 msg <<
"not allowed to write config into " << filename
318 <<
": " << ex.
what();
343 + filename +
" successful", params));
351 "Illegal operation executing 'config-set' on a different thread than main thread"));
360 message =
"Missing mandatory 'arguments' parameter.";
362 dhcp6 = args->get(
"Dhcp6");
364 message =
"Missing mandatory 'Dhcp6' parameter.";
366 message =
"'Dhcp6' parameter expected to be a map.";
371 if (message.empty()) {
372 for (
auto const& obj : args->mapValue()) {
373 const string& obj_name = obj.first;
374 if (obj_name !=
"Dhcp6") {
377 if (message.empty()) {
378 message =
"Unsupported '" + obj_name +
"' parameter";
380 message +=
" (and '" + obj_name +
"')";
384 if (!message.empty()) {
389 if (!message.empty()) {
402 "Can not update configuration while lease file cleanup process is running."));
435 message =
"Reconfiguration triggered a fatal error: shutting down.";
464 }
catch (
const std::exception& ex) {
468 std::ostringstream err;
469 err <<
"Error initializing hooks: "
482 "Illegal operation executing 'config-test' on a different thread than main thread"));
491 message =
"Missing mandatory 'arguments' parameter.";
493 dhcp6 = args->get(
"Dhcp6");
495 message =
"Missing mandatory 'Dhcp6' parameter.";
497 message =
"'Dhcp6' parameter expected to be a map.";
502 if (message.empty()) {
503 for (
auto const& obj : args->mapValue()) {
504 const string& obj_name = obj.first;
505 if (obj_name !=
"Dhcp6") {
508 if (message.empty()) {
509 message =
"Unsupported '" + obj_name +
"' parameter";
511 message +=
" (and '" + obj_name +
"')";
515 if (!message.empty()) {
520 if (!message.empty()) {
542 std::ostringstream message;
543 int64_t max_period = 0;
555 message <<
"arguments for the 'dhcp-disable' command must be a map";
560 if (max_period_element) {
563 message <<
"'max-period' argument must be a number";
567 max_period = max_period_element->intValue();
568 if (max_period <= 0) {
569 message <<
"'max-period' must be positive integer";
582 if (origin_id_element) {
584 type = origin_id_element->intValue();
586 message <<
"'origin-id' argument must be a number";
588 }
else if (origin_element) {
589 switch (origin_element->getType()) {
591 origin = origin_element->stringValue();
592 if (origin ==
"ha-partner") {
594 }
else if (origin !=
"user") {
595 if (origin.empty()) {
596 origin =
"(empty string)";
598 message <<
"invalid value used for 'origin' parameter: "
603 type = origin_element->intValue();
607 message <<
"'origin' argument must be a string or a number";
614 if (message.tellp() == 0) {
615 message <<
"DHCPv6 service disabled";
616 if (max_period > 0) {
617 message <<
" for " << max_period <<
" seconds";
622 network_state_->delayedEnableService(
static_cast<unsigned>(max_period),
638 std::ostringstream message;
649 message <<
"arguments for the 'dhcp-enable' command must be a map";
661 if (origin_id_element) {
663 type = origin_id_element->intValue();
665 message <<
"'origin-id' argument must be a number";
667 }
else if (origin_element) {
668 switch (origin_element->getType()) {
670 origin = origin_element->stringValue();
671 if (origin ==
"ha-partner") {
673 }
else if (origin !=
"user") {
674 if (origin.empty()) {
675 origin =
"(empty string)";
677 message <<
"invalid value used for 'origin' parameter: "
682 type = origin_element->intValue();
686 message <<
"'origin' argument must be a string or a number";
693 if (message.tellp() == 0) {
698 "DHCP service successfully enabled"));
713 }
catch (
const std::exception& ex) {
718 message =
"unknown error";
724 <<
" interfaces detected.";
727 msg <<
"Unexpected error while retrieving the list of detected interfaces: " << message;
737 "Illegal operation executing 'interface-redetect' on a different thread than main thread"));
746 }
catch (
const std::exception& ex) {
751 message =
"unknown error";
758 msg <<
"Unexpected error while retrieving the list of detected interfaces: " << message;
768 "Illegal operation executing 'interface-add' on a different thread than main thread"));
773 message =
"Missing mandatory 'arguments' parameter.";
776 message =
"arguments for the 'interface-add' command must be a map";
778 ifaces_config = args->get(
"interfaces");
779 if (!ifaces_config) {
780 message =
"Missing mandatory 'interfaces' map parameter in 'arguments'.";
782 auto map = args->mapValue();
783 for (
auto const& key : map) {
784 if (key.first !=
"interfaces") {
785 message =
"Unsupported '" + key.first +
"' map parameter in 'arguments'.";
792 if (!message.empty()) {
795 if (!ifaces_config->size()) {
802 std::set<std::string> seen;
803 auto running_ifaces = running_cfg->toElement()->get(
"interfaces");
804 if (running_ifaces && (running_ifaces->getType() ==
Element::list)) {
805 for (
auto const& item : running_ifaces->listValue()) {
806 seen.insert(item->stringValue());
810 for (
auto const& item : ifaces_config->listValue()) {
811 auto const&
str = item->stringValue();
812 if (seen.find(item->stringValue()) != seen.end()) {
815 seen.insert(item->stringValue());
821 running_cfg->update(*cfg_iface);
822 running_cfg->triggerOpenSocketsWithRetry(AF_INET6,
getServerPort());
823 }
catch (
const std::exception& ex) {
828 message =
"unknown error";
838 msg <<
"Updating used interfaces failed: " << message;
847 arguments->set(
"extended", extended);
870 message =
"Missing mandatory 'remove' parameter.";
874 message =
"Missing mandatory 'remove' parameter.";
876 message =
"'remove' parameter expected to be a boolean.";
878 bool remove_lease = remove_name->boolValue();
879 server_->alloc_engine_->reclaimExpiredLeases6(0, 0, remove_lease);
881 message =
"Reclamation of expired leases is complete.";
899 for (
auto const& entry : args->mapValue()) {
900 ostringstream errmsg;
901 if (entry.first ==
"interface") {
903 errmsg <<
"'interface' entry must be a string";
906 selector.
iface_name_ = entry.second->stringValue();
908 }
if (entry.first ==
"interface-id") {
910 errmsg <<
"'interface-id' entry must be a string";
914 string str = entry.second->stringValue();
920 errmsg <<
"'interface-id' must be not empty";
928 errmsg <<
"value of 'interface-id' was not recognized";
931 }
else if (entry.first ==
"remote") {
933 errmsg <<
"'remote' entry must be a string";
937 IOAddress addr(entry.second->stringValue());
939 errmsg <<
"bad 'remote' entry: not IPv6";
944 }
catch (
const exception& ex) {
945 errmsg <<
"bad 'remote' entry: " << ex.what();
948 }
else if (entry.first ==
"link") {
950 errmsg <<
"'link' entry must be a string";
954 IOAddress addr(entry.second->stringValue());
956 errmsg <<
"bad 'link' entry: not IPv6";
961 }
catch (
const exception& ex) {
962 errmsg <<
"bad 'link' entry: " << ex.what();
965 }
else if (entry.first ==
"classes") {
968 "'classes' entry must be a list"));
970 for (
auto const& item : entry.second->listValue()) {
972 errmsg <<
"'classes' entry must be a list of strings";
976 if (!item->stringValue().empty()) {
982 errmsg <<
"unknown entry '" << entry.first <<
"'";
987 getCfgSubnets6()->selectSubnet(selector);
992 subnet->getSharedNetwork(network);
995 msg <<
"selected shared network '" << network->getName()
996 <<
"' starting with subnet '" << subnet->toText()
997 <<
"' id " << subnet->getID();
999 msg <<
"selected subnet '" << subnet->toText()
1000 <<
"' id " << subnet->getID();
1008 const std::string& tag =
1021 "Illegal operation executing 'config-backend-pull' on a different thread than main thread"));
1042 auto mode = CBControlDHCPv6::FetchMode::FETCH_UPDATE;
1043 server_->getCBControl()->databaseConfigFetch(srv_cfg, mode);
1044 }
catch (
const std::exception& ex) {
1048 "On demand configuration update failed: " +
1049 string(ex.what())));
1052 "On demand configuration update successful."));
1061 auto now = boost::posix_time::second_clock::universal_time();
1063 if (!
start_.is_not_a_date_time()) {
1064 auto uptime = now -
start_;
1069 if (!last_commit.is_not_a_date_time()) {
1070 auto reload = now - last_commit;
1075 if (mt_mgr.getMode()) {
1079 status->set(
"packet-queue-size",
Element::create(
static_cast<int32_t
>(
1082 queue_stats->add(
Element::create(mt_mgr.getThreadPool().getQueueStat(10)));
1083 queue_stats->add(
Element::create(mt_mgr.getThreadPool().getQueueStat(100)));
1084 queue_stats->add(
Element::create(mt_mgr.getThreadPool().getQueueStat(1000)));
1085 status->set(
"packet-queue-statistics", queue_stats);
1097 for (
auto const& entry : lm_info->mapValue()) {
1098 status->set(entry.first, entry.second);
1103 CfgMgr::instance().getCurrentCfg()->getCfgDbAccess()->getExtendedInfoTablesEnabled()));
1108 for (std::string
const&
error : interface->getErrors()) {
1115 if (socket_errors->empty()) {
1120 if (reconnect_ctl && reconnect_ctl->retriesLeft()) {
1125 sockets->set(
"errors", socket_errors);
1127 status->set(
"sockets", sockets);
1165 "no lease backend"));
1177 std::ostringstream err;
1180 err <<
"Server object not initialized, can't process config.";
1197 }
catch (
const std::exception& ex) {
1198 err <<
"Failed to process configuration:" << ex.what();
1208 std::bind(&ControlledDhcpv6Srv::dbLostCallback, srv, ph::_1);
1211 std::bind(&ControlledDhcpv6Srv::dbRecoveredCallback, srv, ph::_1);
1214 std::bind(&ControlledDhcpv6Srv::dbFailedCallback, srv, ph::_1);
1217 string params =
"universe=6";
1218 if (cfg_db->getExtendedInfoTablesEnabled()) {
1219 params +=
" extended-info-tables=true";
1221 cfg_db->setAppendedParameters(params);
1222 cfg_db->createManagers();
1227 }
catch (
const std::exception& ex) {
1228 err <<
"Unable to open database: " << ex.what();
1234 const std::string duid_file =
1236 std::string(SERVER_DUID_FILE);
1241 .arg(duid->toText())
1245 }
catch (
const std::exception& ex) {
1246 err <<
"unable to configure server identifier: " << ex.what();
1253 }
catch (
const std::exception& ex) {
1254 err <<
"Error starting DHCP_DDNS client after server reconfiguration: "
1262 }
catch (
const std::exception& ex) {
1263 err <<
"error starting DHCPv4-over-DHCPv6 IPC "
1264 " after server reconfiguration: " << ex.what();
1277 }
catch (
const std::exception& ex) {
1278 err <<
"Error setting packet queue controls after server reconfiguration: "
1286 std::bind(&ControlledDhcpv6Srv::openSocketsFailedCallback, srv, ph::_1);
1301 setupTimers(&ControlledDhcpv6Srv::reclaimExpiredLeases,
1302 &ControlledDhcpv6Srv::deleteExpiredReclaimedLeases,
1305 }
catch (
const std::exception& ex) {
1306 err <<
"unable to setup timers for periodically running the"
1307 " reclamation of the expired leases: "
1308 << ex.what() <<
".";
1315 long fetch_time =
static_cast<long>(ctl_info->getConfigFetchWaitTime());
1318 if (fetch_time > 0) {
1324 if (!server_->inTestMode()) {
1325 fetch_time = 1000 * fetch_time;
1328 boost::shared_ptr<unsigned> failure_count(
new unsigned(0));
1330 registerTimer(
"Dhcp6CBFetchTimer",
1331 std::bind(&ControlledDhcpv6Srv::cbFetchUpdates,
1345 if (notify_libraries) {
1346 return (notify_libraries);
1355 }
catch (
const std::exception& ex) {
1356 err <<
"Error applying multi threading settings: "
1375 callout_handle->setArgument(
"io_context", srv->
getIOService());
1377 callout_handle->setArgument(
"json_config",
config);
1378 callout_handle->setArgument(
"server_config",
CfgMgr::instance().getStagingCfg());
1387 callout_handle->getArgument(
"error",
error);
1389 error =
"unknown error";
1404 "Server object not initialized, can't process config.");
1415 uint16_t client_port )
1419 "There is another Dhcpv6Srv instance already.");
1560 timer_mgr_->unregisterTimers();
1613ControlledDhcpv6Srv::reclaimExpiredLeases(
const size_t max_leases,
1614 const uint16_t timeout,
1615 const bool remove_lease,
1616 const uint16_t max_unwarned_cycles) {
1619 server_->
alloc_engine_->reclaimExpiredLeases6(max_leases, timeout,
1621 max_unwarned_cycles);
1625 getCfgExpiration()->getReclaimTimerWaitTime());
1627 }
catch (
const std::exception& ex) {
1636ControlledDhcpv6Srv::deleteExpiredReclaimedLeases(
const uint32_t secs) {
1638 server_->alloc_engine_->deleteExpiredReclaimedLeases6(secs);
1646ControlledDhcpv6Srv::dbLostCallback(
ReconnectCtlPtr db_reconnect_ctl) {
1647 if (!db_reconnect_ctl) {
1654 if (db_reconnect_ctl->retriesLeft() == db_reconnect_ctl->maxRetries() &&
1655 db_reconnect_ctl->alterServiceState()) {
1660 .arg(db_reconnect_ctl->id())
1661 .arg(db_reconnect_ctl->timerName());
1665 if (!db_reconnect_ctl->retriesLeft() ||
1666 !db_reconnect_ctl->retryInterval()) {
1668 .arg(db_reconnect_ctl->retriesLeft())
1669 .arg(db_reconnect_ctl->retryInterval())
1670 .arg(db_reconnect_ctl->id())
1671 .arg(db_reconnect_ctl->timerName());
1672 if (db_reconnect_ctl->exitOnFailure()) {
1682ControlledDhcpv6Srv::dbRecoveredCallback(
ReconnectCtlPtr db_reconnect_ctl) {
1683 if (!db_reconnect_ctl) {
1690 if (db_reconnect_ctl->retriesLeft() != db_reconnect_ctl->maxRetries() &&
1691 db_reconnect_ctl->alterServiceState()) {
1696 .arg(db_reconnect_ctl->id())
1697 .arg(db_reconnect_ctl->timerName());
1699 db_reconnect_ctl->resetRetries();
1705ControlledDhcpv6Srv::dbFailedCallback(
ReconnectCtlPtr db_reconnect_ctl) {
1706 if (!db_reconnect_ctl) {
1713 .arg(db_reconnect_ctl->maxRetries())
1714 .arg(db_reconnect_ctl->id())
1715 .arg(db_reconnect_ctl->timerName());
1717 if (db_reconnect_ctl->exitOnFailure()) {
1725ControlledDhcpv6Srv::openSocketsFailedCallback(
ReconnectCtlPtr reconnect_ctl) {
1726 if (!reconnect_ctl) {
1732 if (reconnect_ctl->exitOnFailure()) {
1734 .arg(reconnect_ctl->maxRetries());
1738 .arg(reconnect_ctl->maxRetries());
1743ControlledDhcpv6Srv::cbFetchUpdates(
const SrvConfigPtr& srv_cfg,
1744 boost::shared_ptr<unsigned> failure_count) {
1746 MultiThreadingCriticalSection cs;
1750 server_->getCBControl()->databaseConfigFetch(srv_cfg,
1751 CBControlDHCPv6::FetchMode::FETCH_UPDATE);
1752 (*failure_count) = 0;
1754 }
catch (
const std::exception& ex) {
1761 if (++(*failure_count) > 10) {
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.
A generic exception that is thrown if a function is called in a prohibited way.
The IOAddress class represents an IP addresses (version agnostic).
bool isV6() const
Convenience function to check for an IPv6 address.
static const IOAddress & IPV6_ZERO_ADDRESS()
Returns an IPv6 zero address.
static IOServiceMgr & instance()
Access the IOServiceMgr singleton instance.
size_t pollIOServices()
Poll IOService objects.
Implements an asynchronous "signal" for IOService driven processing.
static void setIOService(isc::asiolink::IOServicePtr io_service)
Set the I/O service.
virtual isc::data::ConstElementPtr processCommand(const isc::data::ConstElementPtr &cmd)
Triggers command processing.
void registerCommand(const std::string &cmd, CommandHandler handler)
Registers specified command handler for a given command.
static std::string getHash(const isc::data::ConstElementPtr &config)
returns a hash of a given Element structure
void deregisterCommand(const std::string &cmd)
Deregisters specified command handler.
static CommandMgr & instance()
CommandMgr is a singleton class.
static std::string DEFAULT_AUTHENTICATION_REALM
Default HTTP authentication realm.
static isc::asiolink::IOAddress DEFAULT_SOCKET_ADDRESS
Default socket address (127.0.0.1).
static std::string SUPPORTED_SERVICE
Supported service.
void closeCommandSockets()
Close http control sockets.
static HttpCommandMgr & instance()
HttpCommandMgr is a singleton class.
void setIOService(const asiolink::IOServicePtr &io_service)
Sets IO service to be used by the http command manager.
static UnixCommandMgr & instance()
UnixCommandMgr is a singleton class.
void setIOService(const asiolink::IOServicePtr &io_service)
Sets IO service to be used by the unix command manager.
void closeCommandSockets()
Shuts down any open unix control sockets.
static ElementPtr create(const Position &pos=ZERO_POSITION())
Create a NullElement.
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.
static void setIOService(const isc::asiolink::IOServicePtr &io_service)
Sets IO service to be used by the database backends.
static DbCallback db_recovered_callback_
Optional callback function to invoke if an opened connection recovery succeeded.
static DbCallback db_failed_callback_
Optional callback function to invoke if an opened connection recovery failed.
static DbCallback db_lost_callback_
Optional callback function to invoke if an opened connection is lost.
RAII class to enable DB reconnect retries on server startup.
static const std::string FLUSH_RECLAIMED_TIMER_NAME
Name of the timer for flushing reclaimed leases.
static const std::string RECLAIM_EXPIRED_TIMER_NAME
Name of the timer for reclaiming expired leases.
Represents selection of interfaces for DHCP server.
static OpenSocketsFailedCallback open_sockets_failed_callback_
Optional callback function to invoke if all retries of the opening sockets fail.
static CfgMgr & instance()
returns a single instance of Configuration Manager
SrvConfigPtr getStagingCfg()
Returns a pointer to the staging configuration.
void commit()
Commits the staging configuration.
void clearStagingConfiguration()
Remove staging configuration.
SrvConfigPtr getCurrentCfg()
Returns a pointer to the current configuration.
static void apply(data::ConstElementPtr value)
apply multi threading configuration
void insert(const ClientClass &class_name)
Insert an element.
Controlled version of the DHCPv6 server.
bool getShutdown() const
Return the server shutdown flag value.
isc::data::ConstElementPtr commandVersionGetHandler(const std::string &command, isc::data::ConstElementPtr args)
@Brief handler for processing 'version-get' command
void init(const std::string &config_file)
Initializes the server.
void cleanup()
Performs cleanup, immediately before termination.
isc::data::ConstElementPtr commandConfigSetHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'config-set' command
isc::data::ConstElementPtr commandInterfaceAddHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'interface-add' command.
isc::data::ConstElementPtr commandInterfaceRedetectHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'interface-redetect' command.
isc::data::ConstElementPtr commandShutdownHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'shutdown' command.
isc::data::ConstElementPtr commandConfigBackendPullHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for config-backend-pull command
isc::data::ConstElementPtr commandLfcStartHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'kea-lfc-start' command
isc::data::ConstElementPtr commandConfigHashGetHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'config-hash-get' command
isc::data::ConstElementPtr commandServerTagGetHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for server-tag-get command
isc::data::ConstElementPtr commandStatisticSetMaxSampleCountAllHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'statistic-sample-count-set-all' command
isc::data::ConstElementPtr commandStatisticSetMaxSampleAgeAllHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'statistic-sample-age-set-all' command
isc::data::ConstElementPtr commandStatusGetHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'status-get' command
isc::data::ConstElementPtr commandDhcpEnableHandler(const std::string &command, isc::data::ConstElementPtr args)
A handler for processing 'dhcp-enable' command.
isc::data::ConstElementPtr commandConfigReloadHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'config-reload' command.
isc::data::ConstElementPtr commandLeasesReclaimHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'leases-reclaim' command.
isc::data::ConstElementPtr commandConfigWriteHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'config-write' command
isc::data::ConstElementPtr commandBuildReportHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'build-report' command
static isc::data::ConstElementPtr finishConfigHookLibraries(isc::data::ConstElementPtr config)
Configuration checker for hook libraries.
virtual ~ControlledDhcpv6Srv()
Destructor.
static isc::data::ConstElementPtr processConfig(isc::data::ConstElementPtr config)
Configuration processor.
isc::data::ConstElementPtr commandConfigGetHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'config-get' command
virtual void shutdownServer(int exit_value)
Initiates shutdown procedure for the whole DHCPv6 server.
static ControlledDhcpv6Srv * getInstance()
Returns pointer to the sole instance of Dhcpv6Srv.
isc::data::ConstElementPtr loadConfigFile(const std::string &file_name)
Configure DHCPv6 server using the configuration file specified.
static isc::data::ConstElementPtr checkConfig(isc::data::ConstElementPtr config)
Configuration checker.
isc::data::ConstElementPtr commandInterfaceListHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'interface-list' command.
isc::data::ConstElementPtr commandSubnet6SelectTestHandler(const std::string &command, isc::data::ConstElementPtr args)
Handler for processing 'subnet6-select-test' command.
ControlledDhcpv6Srv(uint16_t server_port=DHCP6_SERVER_PORT, uint16_t client_port=0)
Constructor.
isc::data::ConstElementPtr commandDhcpDisableHandler(const std::string &command, isc::data::ConstElementPtr args)
A handler for processing 'dhcp-disable' command.
isc::data::ConstElementPtr commandConfigTestHandler(const std::string &command, isc::data::ConstElementPtr args)
handler for processing 'config-test' command
virtual void open()
Open communication socket.
static Dhcp6to4Ipc & instance()
Returns pointer to the sole instance of Dhcp6to4Ipc.
void shutdown() override
Instructs the server to shut down.
boost::shared_ptr< AllocEngine > alloc_engine_
Allocation Engine.
uint16_t getServerPort() const
Get UDP port on which server should listen.
NetworkStatePtr & getNetworkState()
Returns pointer to the network state used by the server.
NetworkStatePtr network_state_
Holds information about disabled DHCP service and/or disabled subnet/network scopes.
Dhcpv6Srv(uint16_t server_port=DHCP6_SERVER_PORT, uint16_t client_port=0)
Default constructor.
static std::string getVersion(bool extended)
returns Kea version on stdout and exit.
asiolink::IOServicePtr & getIOService()
Returns pointer to the IO service used by the server.
volatile bool shutdown_
Indicates if shutdown is in progress.
void startD2()
Starts DHCP_DDNS client IO if DDNS updates are enabled.
static void create()
Creates new instance of the HostMgr.
size_t size() const
Return the number of interfaces.
const IfaceCollection & getIfaces()
Returns container with all interfaces.
void detectIfaces(bool update_only=false)
Detects network interfaces.
static IfaceMgr & instance()
IfaceMgr is a singleton class.
Parser for the configuration of interfaces.
void parseInterfacesList(const CfgIfacePtr &cfg_iface, isc::data::ConstElementPtr ifaces_list)
parses interfaces-list structure
static TrackingLeaseMgr & instance()
Return current lease manager.
static bool init_allocators_
Flag which indicates if allocators must be initialized.
static void destroy()
Destroy lease manager.
static bool haveInstance()
Indicates if the lease manager has been instantiated.
virtual data::ElementPtr getStatus() const
Return status information.
static void commitRuntimeOptionDefs()
Commits runtime option definitions.
Concrete implementation of a lease database backend using flat file.
static bool isLFCProcessRunning(const std::string file_name, Universe u)
Check if LFC is running.
static const unsigned int DB_CONNECTION
The network state is being altered by the DB connection recovery mechanics.
static const unsigned int USER_COMMAND
Origin of the network state transition.
static const unsigned int HA_REMOTE_COMMAND
The network state is being altered by a "dhcp-disable" or "dhcp-enable" command sent by a HA partner.
Evaluation context, an interface to the expression evaluation.
isc::data::ElementPtr parseFile(const std::string &filename, ParserType parser_type)
Run the parser on the file specified.
@ PARSER_DHCP6
This parser will parse the content as Dhcp6 config wrapped in a map (that's the regular config file).
RAII class creating a critical section for the receiver thread.
Manages a pool of asynchronous interval timers.
static const TimerMgrPtr & instance()
Returns pointer to the sole instance of the TimerMgr.
@ NEXT_STEP_DROP
drop the packet
static int registerHook(const std::string &name)
Register Hook.
static bool calloutsPresent(int index)
Are callouts present?
static boost::shared_ptr< CalloutHandle > createCalloutHandle()
Return callout handle.
static void callCallouts(int index, CalloutHandle &handle)
Calls the callouts for a given hook.
std::string getConfigFile() const
Returns config file name.
virtual size_t writeConfigFile(const std::string &config_file, isc::data::ConstElementPtr cfg=isc::data::ConstElementPtr()) const
Writes current configuration to specified file.
isc::asiolink::IOSignalSetPtr signal_set_
A pointer to the object installing custom signal handlers.
boost::posix_time::ptime start_
Timestamp of the start of the daemon.
void checkWriteConfigFile(std::string &file)
Checks the to-be-written configuration file name.
void setExitValue(int value)
Sets the exit value.
isc::data::ConstElementPtr redactConfig(isc::data::ConstElementPtr const &config)
Redact a configuration.
Statistics Manager class.
static StatsMgr & instance()
Statistics Manager accessor method.
RAII class creating a critical section.
static MultiThreadingMgr & instance()
Returns a single instance of Multi Threading Manager.
void apply(bool enabled, uint32_t thread_count, uint32_t queue_size)
Apply the multi-threading related settings.
This file contains several functions and constants that are used for handling commands and responses ...
Defines the Dhcp6to4Ipc class.
#define isc_throw(type, stream)
A shortcut macro to insert known values into exception arguments.
isc::data::ConstElementPtr statisticSetMaxSampleCountAllHandler(const isc::data::ConstElementPtr ¶ms)
Handles statistic-sample-count-set-all command.
static isc::data::ConstElementPtr statisticResetHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-reset command.
static isc::data::ConstElementPtr statisticGetAllHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-get-all command.
static isc::data::ConstElementPtr statisticRemoveHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-remove command.
static isc::data::ConstElementPtr statisticGetHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-get command.
static isc::data::ConstElementPtr statisticGlobalGetAllHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-global-get-all command.
isc::data::ConstElementPtr statisticSetMaxSampleAgeAllHandler(const isc::data::ConstElementPtr ¶ms)
Handles statistic-sample-age-set-all command.
static isc::data::ConstElementPtr statisticResetAllHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-reset-all command.
static isc::data::ConstElementPtr statisticSetMaxSampleAgeHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-sample-age-set command.
static isc::data::ConstElementPtr statisticRemoveAllHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-remove-all command.
static isc::data::ConstElementPtr statisticSetMaxSampleCountHandler(const std::string &name, const isc::data::ConstElementPtr ¶ms)
Handles statistic-sample-count-set command.
uint32_t getMaxSampleCountDefault() const
Get default count limit.
const StatsDuration & getMaxSampleAgeDefault() const
Get default duration limit.
#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_FATAL(LOGGER, MESSAGE)
Macro to conveniently test fatal output and log it.
#define LOG_DEBUG(LOGGER, LEVEL, MESSAGE)
Macro to conveniently test debug output and log it.
boost::shared_ptr< IOService > IOServicePtr
Defines a smart pointer to an IOService instance.
const int CONTROL_RESULT_EMPTY
Status code indicating that the specified command was completed correctly, but failed to produce any ...
ConstElementPtr parseAnswer(int &rcode, const ConstElementPtr &msg)
Parses a standard config/command level answer and returns arguments or text status code.
ConstElementPtr createCommand(const std::string &command)
Creates a standard command message with no argument (of the form { "command": "my_command" }...
const int CONTROL_RESULT_ERROR
Status code indicating a general failure.
ConstElementPtr createAnswer(const int status_code, const std::string &text, const ConstElementPtr &arg)
Creates a standard config/command level answer message.
ConstElementPtr createAnswer()
Creates a standard config/command level success answer message (i.e.
const int CONTROL_RESULT_COMMAND_UNSUPPORTED
Status code indicating that the specified command is not supported.
const int CONTROL_RESULT_FATAL_ERROR
Status code indicating that the command was unsuccessful and the configuration could not be reverted ...
const int CONTROL_RESULT_SUCCESS
Status code indicating a successful operation.
boost::shared_ptr< const Element > ConstElementPtr
boost::shared_ptr< Element > ElementPtr
std::string getConfigReport()
const isc::log::MessageID DHCP6_DB_RECONNECT_NO_DB_CTL
const isc::log::MessageID DHCP6_OPEN_SOCKETS_NO_RECONNECT_CTL
const isc::log::MessageID DHCP6_USING_SERVERID
const isc::log::MessageID DHCP6_CONFIG_LOAD_FAIL
boost::shared_ptr< const Subnet6 > ConstSubnet6Ptr
A const pointer to a Subnet6 object.
const isc::log::MessageID DHCP6_DB_RECONNECT_SUCCEEDED
isc::data::ConstElementPtr configureDhcp6Server(Dhcpv6Srv &server, isc::data::ConstElementPtr config_set, bool check_only, bool extra_checks)
Configure DHCPv6 server (Dhcpv6Srv) with a set of configuration values.
const isc::log::MessageID DHCP6_RECLAIM_EXPIRED_LEASES_SKIPPED
boost::shared_ptr< CfgDbAccess > CfgDbAccessPtr
A pointer to the CfgDbAccess.
boost::shared_ptr< Iface > IfacePtr
Type definition for the pointer to an Iface object.
boost::shared_ptr< DUID > DuidPtr
const int DBG_DHCP6_COMMAND
Debug level used to log receiving commands.
const isc::log::MessageID DHCP6_CB_PERIODIC_FETCH_UPDATES_FAIL
const isc::log::MessageID DHCP6_RECLAIM_EXPIRED_LEASES_FAIL
boost::shared_ptr< CfgIface > CfgIfacePtr
A pointer to the CfgIface .
const isc::log::MessageID DHCP6_OPEN_SOCKETS_FAILED
boost::shared_ptr< SrvConfig > SrvConfigPtr
Non-const pointer to the SrvConfig.
const isc::log::MessageID DHCP6_DYNAMIC_RECONFIGURATION_SUCCESS
const isc::log::MessageID DHCP6_CB_ON_DEMAND_FETCH_UPDATES_FAIL
const isc::log::MessageID DHCP6_CB_PERIODIC_FETCH_UPDATES_RETRIES_EXHAUSTED
const isc::log::MessageID DHCP6_NOT_RUNNING
boost::shared_ptr< SharedNetwork6 > SharedNetwork6Ptr
Pointer to SharedNetwork6 object.
const isc::log::MessageID DHCP6_FATAL_OPEN_SOCKETS_FAILED
const isc::log::MessageID DHCP6_DYNAMIC_RECONFIGURATION_FAIL
const isc::log::MessageID DHCP6_CONFIG_UNSUPPORTED_OBJECT
const isc::log::MessageID DHCP6_CONFIG_UNRECOVERABLE_ERROR
const isc::log::MessageID DHCP6_CONFIG_RECEIVED
const isc::log::MessageID DHCP6_DB_RECONNECT_DISABLED
const isc::log::MessageID DHCP6_DYNAMIC_RECONFIGURATION
const isc::log::MessageID DHCP6_DB_RECONNECT_LOST_CONNECTION
const int DBG_DHCP6_BASIC
Debug level used to trace basic operations within the code.
isc::log::Logger dhcp6_logger(DHCP6_APP_LOGGER_NAME)
Base logger for DHCPv6 server.
const isc::log::MessageID DHCP6_MULTI_THREADING_INFO
const isc::log::MessageID DHCP6_DB_RECONNECT_FAILED
boost::shared_ptr< Option > OptionPtr
const isc::log::MessageID DHCP6_CONFIG_PACKET_QUEUE
boost::shared_ptr< CalloutHandle > CalloutHandlePtr
A shared pointer to a CalloutHandle object.
long toSeconds(const StatsDuration &dur)
Returns the number of seconds in a duration.
void decodeFormattedHexString(const string &hex_string, vector< uint8_t > &binary)
Converts a formatted string of hexadecimal digits into a vector.
vector< uint8_t > quotedStringToBinary(const string "ed_string)
Converts a string in quotes into vector.
boost::shared_ptr< ReconnectCtl > ReconnectCtlPtr
Pointer to an instance of ReconnectCtl.
Defines the logger used by the top-level component of kea-lfc.
Subnet selector used to specify parameters used to select a subnet.
std::string iface_name_
Name of the interface on which the message was received.
ClientClasses client_classes_
Classes that the client belongs to.
asiolink::IOAddress remote_address_
Source address of the message.
OptionPtr interface_id_
Interface id option.
asiolink::IOAddress first_relay_linkaddr_
First relay link address.