From f5f56e1a1c4d9e9496fcb9d81131066a964ccd23 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 13 Apr 2024 14:15:43 +0200 Subject: Adding upstream version 2.4.1. Signed-off-by: Daniel Baumann --- src/lib/http/connection_pool.cc | 74 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 src/lib/http/connection_pool.cc (limited to 'src/lib/http/connection_pool.cc') diff --git a/src/lib/http/connection_pool.cc b/src/lib/http/connection_pool.cc new file mode 100644 index 0000000..de92eb2 --- /dev/null +++ b/src/lib/http/connection_pool.cc @@ -0,0 +1,74 @@ +// Copyright (C) 2017-2021 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#include + +#include +#include +#include + +namespace isc { +namespace http { + +void +HttpConnectionPool::start(const HttpConnectionPtr& connection) { + if (util::MultiThreadingMgr::instance().getMode()) { + std::lock_guard lk(mutex_); + connections_.insert(connections_.end(), connection); + } else { + connections_.insert(connections_.end(), connection); + } + + connection->asyncAccept(); +} + +void +HttpConnectionPool::stop(const HttpConnectionPtr& connection) { + if (util::MultiThreadingMgr::instance().getMode()) { + std::lock_guard lk(mutex_); + connections_.remove(connection); + } else { + connections_.remove(connection); + } + + connection->close(); +} + +void +HttpConnectionPool::shutdown(const HttpConnectionPtr& connection) { + if (util::MultiThreadingMgr::instance().getMode()) { + std::lock_guard lk(mutex_); + connections_.remove(connection); + } else { + connections_.remove(connection); + } + + connection->shutdown(); +} + +void +HttpConnectionPool::stopAll() { + if (util::MultiThreadingMgr::instance().getMode()) { + std::lock_guard lk(mutex_); + stopAllInternal(); + } else { + stopAllInternal(); + } +} + +void +HttpConnectionPool::stopAllInternal() { + for (auto connection = connections_.begin(); + connection != connections_.end(); + ++connection) { + (*connection)->close(); + } + + connections_.clear(); +} + +} +} -- cgit v1.2.3