mirror of
https://github.com/Icinga/icinga2.git
synced 2026-02-20 00:10:29 -05:00
I've used the following command to replace the original copyright header
lines in a C-style comment block:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f -exec perl -pi -e 's{/\*[^*]*\(\s*c\s*\)\s*(\d{4})\s*Icinga\s+GmbH[^*]*\*/}{// SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n// SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
For files that use shell-style comments (#) like CMakeLists.txt, I've
used this command:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f -exec perl -pi -e 's{#.*\(\s*c\s*\)\s(\d{4})\sIcinga\s+GmbH.*}{# SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n# SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
And for SQL files:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f \( -name '*.sql' \) -exec perl -pi -e 's{--.*\(c\)\s(\d{4})\sIcinga\sGmbH.*}{-- SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n-- SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f \( -name '*.sql' \) -exec perl -pi -e 's{-- Copyright \(c\)\s(\d{4})\sIcinga\s+Development\sTeam.*}{-- SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n-- SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
101 lines
2.3 KiB
C++
101 lines
2.3 KiB
C++
// SPDX-FileCopyrightText: 2012 Icinga GmbH <https://icinga.com>
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#ifndef TCPSOCKET_H
|
|
#define TCPSOCKET_H
|
|
|
|
#include "base/i2-base.hpp"
|
|
#include "base/io-engine.hpp"
|
|
#include "base/socket.hpp"
|
|
#include <boost/asio/error.hpp>
|
|
#include <boost/asio/ip/tcp.hpp>
|
|
#include <boost/asio/spawn.hpp>
|
|
#include <boost/system/system_error.hpp>
|
|
|
|
namespace icinga
|
|
{
|
|
|
|
/**
|
|
* A TCP socket. DEPRECATED - Use Boost ASIO instead.
|
|
*
|
|
* @ingroup base
|
|
*/
|
|
class TcpSocket final : public Socket
|
|
{
|
|
public:
|
|
DECLARE_PTR_TYPEDEFS(TcpSocket);
|
|
|
|
void Bind(const String& service, int family);
|
|
void Bind(const String& node, const String& service, int family);
|
|
|
|
void Connect(const String& node, const String& service);
|
|
};
|
|
|
|
/**
|
|
* TCP Connect based on Boost ASIO.
|
|
*
|
|
* @ingroup base
|
|
*/
|
|
template<class Socket>
|
|
void Connect(Socket& socket, const String& node, const String& service)
|
|
{
|
|
using boost::asio::ip::tcp;
|
|
|
|
tcp::resolver resolver (IoEngine::Get().GetIoContext());
|
|
auto result (resolver.resolve(node.GetData(), service.GetData()));
|
|
auto current (result.begin());
|
|
|
|
for (;;) {
|
|
try {
|
|
socket.open(current->endpoint().protocol());
|
|
socket.set_option(tcp::socket::keep_alive(true));
|
|
socket.connect(current->endpoint());
|
|
|
|
break;
|
|
} catch (const std::exception& ex) {
|
|
auto se (dynamic_cast<const boost::system::system_error*>(&ex));
|
|
|
|
if ((se && se->code() == boost::asio::error::operation_aborted) || ++current == result.end()) {
|
|
throw;
|
|
}
|
|
|
|
if (socket.is_open()) {
|
|
socket.close();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
template<class Socket>
|
|
void Connect(Socket& socket, const String& node, const String& service, boost::asio::yield_context yc)
|
|
{
|
|
using boost::asio::ip::tcp;
|
|
|
|
tcp::resolver resolver (IoEngine::Get().GetIoContext());
|
|
auto result (resolver.async_resolve(node.GetData(), service.GetData(), yc));
|
|
auto current (result.begin());
|
|
|
|
for (;;) {
|
|
try {
|
|
socket.open(current->endpoint().protocol());
|
|
socket.set_option(tcp::socket::keep_alive(true));
|
|
socket.async_connect(current->endpoint(), yc);
|
|
|
|
break;
|
|
} catch (const std::exception& ex) {
|
|
auto se (dynamic_cast<const boost::system::system_error*>(&ex));
|
|
|
|
if ((se && se->code() == boost::asio::error::operation_aborted) || ++current == result.end()) {
|
|
throw;
|
|
}
|
|
|
|
if (socket.is_open()) {
|
|
socket.close();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* TCPSOCKET_H */
|