mirror of
https://gitee.com/ldcsaa/HP-Socket.git
synced 2024-12-05 13:17:53 +08:00
108 lines
4.5 KiB
C++
108 lines
4.5 KiB
C++
/*
|
|
* Copyright: JessMA Open Source (ldcsaa@gmail.com)
|
|
*
|
|
* Author : Bruce Liang
|
|
* Website : https://github.com/ldcsaa
|
|
* Project : https://github.com/ldcsaa/HP-Socket
|
|
* Blog : http://www.cnblogs.com/ldcsaa
|
|
* Wiki : http://www.oschina.net/p/hp-socket
|
|
* QQ Group : 44636872, 75375912
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "TcpServer.h"
|
|
#include "SSLHelper.h"
|
|
|
|
#ifdef _SSL_SUPPORT
|
|
|
|
class CSSLServer : public CTcpServer
|
|
{
|
|
public:
|
|
virtual BOOL IsSecure() {return TRUE;}
|
|
virtual BOOL SendPackets(CONNID dwConnID, const WSABUF pBuffers[], int iCount);
|
|
|
|
virtual BOOL SetupSSLContext(int iVerifyMode = SSL_VM_NONE, LPCTSTR lpszPemCertFile = nullptr, LPCTSTR lpszPemKeyFile = nullptr, LPCTSTR lpszKeyPassword = nullptr, LPCTSTR lpszCAPemCertFileOrPath = nullptr, Fn_SNI_ServerNameCallback fnServerNameCallback = nullptr)
|
|
{return m_sslCtx.Initialize(SSL_SM_SERVER, iVerifyMode, FALSE, (LPVOID)lpszPemCertFile, (LPVOID)lpszPemKeyFile, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCertFileOrPath, fnServerNameCallback);}
|
|
|
|
virtual BOOL SetupSSLContextByMemory(int iVerifyMode = SSL_VM_NONE, LPCSTR lpszPemCert = nullptr, LPCSTR lpszPemKey = nullptr, LPCSTR lpszKeyPassword = nullptr, LPCSTR lpszCAPemCert = nullptr, Fn_SNI_ServerNameCallback fnServerNameCallback = nullptr)
|
|
{return m_sslCtx.Initialize(SSL_SM_SERVER, iVerifyMode, TRUE, (LPVOID)lpszPemCert, (LPVOID)lpszPemKey, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCert, fnServerNameCallback);}
|
|
|
|
virtual int AddSSLContext(int iVerifyMode = SSL_VM_NONE, LPCTSTR lpszPemCertFile = nullptr, LPCTSTR lpszPemKeyFile = nullptr, LPCTSTR lpszKeyPassword = nullptr, LPCTSTR lpszCAPemCertFileOrPath = nullptr)
|
|
{return m_sslCtx.AddServerContext(iVerifyMode, FALSE, (LPVOID)lpszPemCertFile, (LPVOID)lpszPemKeyFile, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCertFileOrPath);}
|
|
|
|
virtual int AddSSLContextByMemory(int iVerifyMode = SSL_VM_NONE, LPCSTR lpszPemCert = nullptr, LPCSTR lpszPemKey = nullptr, LPCSTR lpszKeyPassword = nullptr, LPCSTR lpszCAPemCert = nullptr)
|
|
{return m_sslCtx.AddServerContext(iVerifyMode, TRUE, (LPVOID)lpszPemCert, (LPVOID)lpszPemKey, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCert);}
|
|
|
|
virtual BOOL BindSSLServerName(LPCTSTR lpszServerName, int iContextIndex)
|
|
{return m_sslCtx.BindServerName(lpszServerName, iContextIndex);}
|
|
|
|
virtual void CleanupSSLContext()
|
|
{m_sslCtx.Cleanup();}
|
|
|
|
virtual BOOL StartSSLHandShake(CONNID dwConnID);
|
|
|
|
public:
|
|
virtual void SetSSLAutoHandShake(BOOL bAutoHandShake) {ENSURE_HAS_STOPPED(); m_bSSLAutoHandShake = bAutoHandShake;}
|
|
virtual void SetSSLCipherList (LPCTSTR lpszCipherList){ENSURE_HAS_STOPPED(); m_sslCtx.SetCipherList(lpszCipherList);}
|
|
virtual BOOL IsSSLAutoHandShake () {return m_bSSLAutoHandShake;}
|
|
virtual LPCTSTR GetSSLCipherList() {return m_sslCtx.GetCipherList();}
|
|
|
|
virtual BOOL GetSSLSessionInfo(CONNID dwConnID, EnSSLSessionInfo enInfo, LPVOID* lppInfo);
|
|
|
|
protected:
|
|
virtual EnHandleResult FireAccept(TSocketObj* pSocketObj);
|
|
virtual EnHandleResult FireReceive(TSocketObj* pSocketObj, const BYTE* pData, int iLength);
|
|
virtual EnHandleResult FireClose(TSocketObj* pSocketObj, EnSocketOperation enOperation, int iErrorCode);
|
|
|
|
virtual BOOL CheckParams();
|
|
virtual void PrepareStart();
|
|
virtual void Reset();
|
|
|
|
virtual void OnWorkerThreadEnd(THR_ID dwThreadID);
|
|
|
|
protected:
|
|
virtual BOOL StartSSLHandShake(TSocketObj* pSocketObj);
|
|
|
|
private:
|
|
void DoSSLHandShake(TSocketObj* pSocketObj);
|
|
|
|
private:
|
|
friend EnHandleResult ProcessHandShake<>(CSSLServer* pThis, TSocketObj* pSocketObj, CSSLSession* pSession);
|
|
friend EnHandleResult ProcessReceive<>(CSSLServer* pThis, TSocketObj* pSocketObj, CSSLSession* pSession, const BYTE* pData, int iLength);
|
|
friend BOOL ProcessSend<>(CSSLServer* pThis, TSocketObj* pSocketObj, CSSLSession* pSession, const WSABUF * pBuffers, int iCount);
|
|
|
|
public:
|
|
CSSLServer(ITcpServerListener* pListener)
|
|
: CTcpServer(pListener)
|
|
, m_sslPool(m_sslCtx)
|
|
, m_bSSLAutoHandShake(TRUE)
|
|
{
|
|
|
|
}
|
|
|
|
virtual ~CSSLServer()
|
|
{
|
|
ENSURE_STOP();
|
|
}
|
|
|
|
private:
|
|
BOOL m_bSSLAutoHandShake;
|
|
|
|
CSSLContext m_sslCtx;
|
|
CSSLSessionPool m_sslPool;
|
|
};
|
|
|
|
#endif |