summaryrefslogtreecommitdiffstats
path: root/src/lib/dhcpsrv/d2_client_mgr.cc
diff options
context:
space:
mode:
authorRazvan Becheriu <razvan@isc.org>2024-03-16 00:44:37 +0100
committerRazvan Becheriu <razvan@isc.org>2024-04-04 07:26:51 +0200
commit94fa86e3c03d763cc5a1f45a902e024a1aa88f8e (patch)
tree63d77ccd153e12d462b4166d06214a0025a9906a /src/lib/dhcpsrv/d2_client_mgr.cc
parent[#3281] use shared_from_this (diff)
downloadkea-94fa86e3c03d763cc5a1f45a902e024a1aa88f8e.tar.xz
kea-94fa86e3c03d763cc5a1f45a902e024a1aa88f8e.zip
[#3281] use shared_from_this
Diffstat (limited to 'src/lib/dhcpsrv/d2_client_mgr.cc')
-rw-r--r--src/lib/dhcpsrv/d2_client_mgr.cc28
1 files changed, 19 insertions, 9 deletions
diff --git a/src/lib/dhcpsrv/d2_client_mgr.cc b/src/lib/dhcpsrv/d2_client_mgr.cc
index 575b6f395e..022e01212c 100644
--- a/src/lib/dhcpsrv/d2_client_mgr.cc
+++ b/src/lib/dhcpsrv/d2_client_mgr.cc
@@ -25,7 +25,8 @@ D2ClientMgr::D2ClientMgr() : d2_client_config_(new D2ClientConfig()),
// Default constructor initializes with a disabled configuration.
}
-D2ClientMgr::~D2ClientMgr(){
+D2ClientMgr::~D2ClientMgr() {
+ stop();
stopSender();
}
@@ -177,7 +178,6 @@ D2ClientMgr::generateFqdn(const asiolink::IOAddress& address,
return (qualifyName(gen_name.str(), ddns_params, trailing_dot));
}
-
std::string
D2ClientMgr::qualifyName(const std::string& partial_name,
const DdnsParams& ddns_params,
@@ -312,6 +312,14 @@ D2ClientMgr::stopSender() {
name_change_sender_->stopSending();
LOG_INFO(dhcpsrv_logger, DHCPSRV_DHCP_DDNS_SENDER_STOPPED);
}
+
+ if (private_io_service_) {
+ private_io_service_->restart();
+ try {
+ private_io_service_->poll();
+ } catch (...) {
+ }
+ }
}
void
@@ -354,7 +362,7 @@ D2ClientMgr::getQueueSize() const {
isc_throw(D2ClientError, "D2ClientMgr::getQueueSize sender is null");
}
- return(name_change_sender_->getQueueSize());
+ return (name_change_sender_->getQueueSize());
}
size_t
@@ -363,11 +371,9 @@ D2ClientMgr::getQueueMaxSize() const {
isc_throw(D2ClientError, "D2ClientMgr::getQueueMaxSize sender is null");
}
- return(name_change_sender_->getQueueMaxSize());
+ return (name_change_sender_->getQueueMaxSize());
}
-
-
const dhcp_ddns::NameChangeRequestPtr&
D2ClientMgr::peekAt(const size_t index) const {
if (!name_change_sender_) {
@@ -397,6 +403,11 @@ D2ClientMgr::operator()(const dhcp_ddns::NameChangeSender::Result result,
}
}
+void
+D2ClientMgr::stop() {
+ name_change_sender_.reset();
+}
+
int
D2ClientMgr::getSelectFd() {
if (!amSending()) {
@@ -418,6 +429,5 @@ D2ClientMgr::runReadyIO() {
name_change_sender_->runReadyIO();
}
-}; // namespace dhcp
-
-}; // namespace isc
+} // namespace dhcp
+} // namespace isc