/** \file SSLSocket.h ** \date 2004-02-13 ** \author grymse@alhem.net **/ /* Copyright (C) 2004,2005 Anders Hedstrom This library is made available under the terms of the GNU GPL. If you would like to use this library in a closed-source application, a separate license agreement is available. For information about the closed-source license agreement for the C++ sockets library, please visit http://www.alhem.net/Sockets/license.html and/or email license@alhem.net. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef _SSLSOCKET_H #define _SSLSOCKET_H #ifdef HAVE_OPENSSL //#include #include "SocketHandler.h" #include "TcpSocket.h" #ifdef _WIN32 #define RANDOM "systray.exe" #else #define RANDOM "/dev/urandom" #endif #ifdef SOCKETS_NAMESPACE namespace SOCKETS_NAMESPACE { #endif /** \defgroup deprecated Obsolete */ /** This class is no longer in active development. \deprecated Please use TcpSocket with EnableSSL instead \sa TcpSocket, EnableSSL \ingroup deprecated */ class SSLSocket : public TcpSocket { public: SSLSocket(SocketHandler&); ~SSLSocket(); virtual void InitAsClient(); virtual void InitAsServer(); void OnConnect(); // init as client void OnAccept(); // init as server bool SSLCheckConnect(); void OnRead(); void OnWrite(); int Close(); protected: SSLSocket(const SSLSocket& s) : TcpSocket(s) {} void InitializeContext(SSL_METHOD *meth_in = NULL); void InitializeContext(const std::string& keyfile,const std::string& password,SSL_METHOD *meth_in = NULL); SSL_CTX *GetSslContext() { return m_context; } SSL *GetSsl() { return m_ssl; } private: SSLSocket& operator=(const SSLSocket& ) { return *this; } bool CheckCertificateChain(const std::string& ); static int verify_cb(int ok, X509_STORE_CTX *store); static int password_cb(char *buf,int num,int rwflag,void *userdata); // SSL_CTX *m_context; bool is_client; bool is_server; SSL *m_ssl; BIO *m_sbio; static BIO *bio_err; static std::string m_password; }; #ifdef SOCKETS_NAMESPACE } #endif #endif // HAVE_OPENSSL #endif // _SSLSOCKET_H