Files
@ 0729d364ca25
Branch filter:
Location: libtransport.git/include/Swiften/TLS/Schannel/SchannelServerContext.h - annotation
0729d364ca25
2.0 KiB
text/plain
Fix double free in DummyConnectionServer
Do not create shared ptr from this as this lead to double free in
UserRegistryTest::login test. Shared ptr was needed to set event
owner in acceptConnection, actually it is never needed as events
are never filtered by owner. Thus it was removed and there is no
need to create shared ptr from this.
Do not create shared ptr from this as this lead to double free in
UserRegistryTest::login test. Shared ptr was needed to set event
owner in acceptConnection, actually it is never needed as events
are never filtered by owner. Thus it was removed and there is no
need to create shared ptr from this.
959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 6d2f8c192761 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 959e023ec839 | /*
* Copyright (c) 2011 Soren Dreijer
* Licensed under the simplified BSD license.
* See Documentation/Licenses/BSD-simplified.txt for more information.
*/
#pragma once
#include "Swiften/TLS/TLSServerContext.h"
#include "Swiften/TLS/Schannel/SchannelUtil.h"
#include <Swiften/TLS/CertificateWithKey.h>
#include "Swiften/Base/ByteArray.h"
#define SECURITY_WIN32
#include <Windows.h>
#include <Schannel.h>
#include <security.h>
#include <schnlsp.h>
#include <boost/noncopyable.hpp>
namespace Swift
{
class SchannelServerContext : public TLSServerContext, boost::noncopyable
{
public:
typedef SWIFTEN_SHRPTR_NAMESPACE::shared_ptr<SchannelServerContext> sp_t;
public:
SchannelServerContext();
~SchannelServerContext();
//
// TLSContext
//
virtual void connect();
virtual bool setServerCertificate(CertificateWithKey::ref cert);
virtual void handleDataFromNetwork(const SafeByteArray& data);
virtual void handleDataFromApplication(const SafeByteArray& data);
virtual Certificate::ref getPeerCertificate() const;
virtual CertificateVerificationError::ref getPeerCertificateVerificationError() const;
virtual ByteArray getFinishMessage() const;
private:
void determineStreamSizes();
void continueHandshake(const SafeByteArray& data);
void indicateError();
void sendDataOnNetwork(const void* pData, size_t dataSize);
void forwardDataToApplication(const void* pData, size_t dataSize);
void decryptAndProcessData(const SafeByteArray& data);
void encryptAndSendData(const SafeByteArray& data);
void appendNewData(const SafeByteArray& data);
private:
enum SchannelState
{
Start,
Connecting,
Connected,
Error
};
SchannelState m_state;
CertificateVerificationError m_verificationError;
ULONG m_secContext;
ScopedCredHandle m_credHandle;
ScopedCtxtHandle m_ctxtHandle;
DWORD m_ctxtFlags;
SecPkgContext_StreamSizes m_streamSizes;
std::vector<char> m_receivedData;
HCERTSTORE m_my_cert_store;
std::string m_cert_store_name;
std::string m_cert_name;
};
}
|