HP-Socket/Windows/Src/SSLClient.h
2021-01-15 15:38:07 +08:00

100 lines
3.4 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 "TcpClient.h"
#include "SSLHelper.h"
#ifdef _SSL_SUPPORT
class CSSLClient : public CTcpClient
{
public:
virtual BOOL IsSecure() {return TRUE;}
virtual BOOL SendPackets(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)
{return m_sslCtx.Initialize(SSL_SM_CLIENT, iVerifyMode, FALSE, (LPVOID)lpszPemCertFile, (LPVOID)lpszPemKeyFile, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCertFileOrPath, nullptr);}
virtual BOOL SetupSSLContextByMemory(int iVerifyMode = SSL_VM_NONE, LPCSTR lpszPemCert = nullptr, LPCSTR lpszPemKey = nullptr, LPCSTR lpszKeyPassword = nullptr, LPCSTR lpszCAPemCert = nullptr)
{return m_sslCtx.Initialize(SSL_SM_CLIENT, iVerifyMode, TRUE, (LPVOID)lpszPemCert, (LPVOID)lpszPemKey, (LPVOID)lpszKeyPassword, (LPVOID)lpszCAPemCert, nullptr);}
virtual void CleanupSSLContext()
{m_sslCtx.Cleanup();}
virtual BOOL StartSSLHandShake();
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(EnSSLSessionInfo enInfo, LPVOID* lppInfo);
protected:
virtual EnHandleResult FireConnect();
virtual EnHandleResult FireReceive(const BYTE* pData, int iLength);
virtual BOOL CheckParams();
virtual void PrepareStart();
virtual void Reset();
virtual void OnWorkerThreadEnd(THR_ID dwThreadID);
protected:
virtual BOOL StartSSLHandShakeNoCheck();
private:
void DoSSLHandShake();
private:
friend EnHandleResult ProcessHandShake<>(CSSLClient* pThis, CSSLClient* pSocketObj, CSSLSession* pSession);
friend EnHandleResult ProcessReceive<>(CSSLClient* pThis, CSSLClient* pSocketObj, CSSLSession* pSession, const BYTE* pData, int iLength);
friend BOOL ProcessSend<>(CSSLClient* pThis, CSSLClient* pSocketObj, CSSLSession* pSession, const WSABUF * pBuffers, int iCount);
public:
CSSLClient(ITcpClientListener* pListener)
: CTcpClient (pListener)
, m_sslSession (m_itPool)
, m_dwMainThreadID (0)
, m_bSSLAutoHandShake (TRUE)
{
}
virtual ~CSSLClient()
{
ENSURE_STOP();
}
private:
DWORD m_dwMainThreadID;
BOOL m_bSSLAutoHandShake;
CSSLContext m_sslCtx;
CSSLSession m_sslSession;
};
#endif