mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-11-15 20:24:07 +00:00
b79ead9c84
* Replicate poco into base/poco/ * De-register poco submodule * Build poco from ClickHouse * Exclude poco from stylecheck * Exclude poco from whitespace check * Exclude poco from typo check * Remove x bit from sources/headers (the style check complained) * Exclude poco from duplicate include check * Fix fasttest * Remove contrib/poco-cmake/* * Simplify poco build descriptions * Remove poco stuff not used by ClickHouse * Glob poco sources * Exclude poco from clang-tidy
122 lines
2.8 KiB
C++
122 lines
2.8 KiB
C++
//
|
|
// SecureServerSocket.cpp
|
|
//
|
|
// Library: NetSSL_OpenSSL
|
|
// Package: SSLSockets
|
|
// Module: SecureServerSocket
|
|
//
|
|
// Copyright (c) 2006-2009, Applied Informatics Software Engineering GmbH.
|
|
// and Contributors.
|
|
//
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
//
|
|
|
|
|
|
#include "Poco/Net/SecureServerSocket.h"
|
|
#include "Poco/Net/SecureServerSocketImpl.h"
|
|
#include "Poco/Net/SecureStreamSocket.h"
|
|
#include "Poco/Net/SSLManager.h"
|
|
#include "Poco/Exception.h"
|
|
|
|
|
|
using Poco::InvalidArgumentException;
|
|
|
|
|
|
namespace Poco {
|
|
namespace Net {
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket():
|
|
ServerSocket(new SecureServerSocketImpl(SSLManager::instance().defaultServerContext()), true)
|
|
{
|
|
}
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket(Context::Ptr pContext):
|
|
ServerSocket(new SecureServerSocketImpl(pContext), true)
|
|
{
|
|
}
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket(const Socket& socket):
|
|
ServerSocket(socket)
|
|
{
|
|
if (!dynamic_cast<SecureServerSocketImpl*>(impl()))
|
|
throw InvalidArgumentException("Cannot assign incompatible socket");
|
|
}
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket(const SocketAddress& address, int backlog):
|
|
ServerSocket(new SecureServerSocketImpl(SSLManager::instance().defaultServerContext()), true)
|
|
{
|
|
impl()->bind(address, true);
|
|
impl()->listen(backlog);
|
|
}
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket(const SocketAddress& address, int backlog, Context::Ptr pContext):
|
|
ServerSocket(new SecureServerSocketImpl(pContext), true)
|
|
{
|
|
impl()->bind(address, true);
|
|
impl()->listen(backlog);
|
|
}
|
|
|
|
|
|
SecureServerSocket::SecureServerSocket(Poco::UInt16 port, int backlog):
|
|
ServerSocket(new SecureServerSocketImpl(SSLManager::instance().defaultServerContext()), true)
|
|
{
|
|
IPAddress wildcardAddr;
|
|
SocketAddress address(wildcardAddr, port);
|
|
impl()->bind(address, true);
|
|
impl()->listen(backlog);
|
|
}
|
|
|
|
SecureServerSocket::SecureServerSocket(Poco::UInt16 port, int backlog, Context::Ptr pContext):
|
|
ServerSocket(new SecureServerSocketImpl(pContext), true)
|
|
{
|
|
IPAddress wildcardAddr;
|
|
SocketAddress address(wildcardAddr, port);
|
|
impl()->bind(address, true);
|
|
impl()->listen(backlog);
|
|
}
|
|
|
|
|
|
SecureServerSocket::~SecureServerSocket()
|
|
{
|
|
}
|
|
|
|
|
|
SecureServerSocket& SecureServerSocket::operator = (const Socket& socket)
|
|
{
|
|
if (&socket != this)
|
|
{
|
|
if (dynamic_cast<SecureServerSocketImpl*>(socket.impl()))
|
|
ServerSocket::operator = (socket);
|
|
else
|
|
throw InvalidArgumentException("Cannot assign incompatible socket");
|
|
}
|
|
return *this;
|
|
}
|
|
|
|
|
|
StreamSocket SecureServerSocket::acceptConnection(SocketAddress& clientAddr)
|
|
{
|
|
return SecureStreamSocket(impl()->acceptConnection(clientAddr));
|
|
}
|
|
|
|
|
|
StreamSocket SecureServerSocket::acceptConnection()
|
|
{
|
|
SocketAddress clientAddr;
|
|
return SecureStreamSocket(impl()->acceptConnection(clientAddr));
|
|
}
|
|
|
|
|
|
Context::Ptr SecureServerSocket::context() const
|
|
{
|
|
return static_cast<SecureServerSocketImpl*>(impl())->context();
|
|
}
|
|
|
|
|
|
} } // namespace Poco::Net
|