Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

78 lines
1.8 KiB

#include "stdafx.h"
#include "mswmdm.h"
#include "loghelp.h"
#include "scpinfo.h"
// We don't want to dll's using our lib to link to drmutil2.lib.
// So disable DRM logging.
#define DISABLE_DRM_LOG
#include "drmerr.h"
#include "key.h"
#include "wmsstd.h"
#define MIN_SCP_APPSEC 1000
CSCPInfo::CSCPInfo() : m_pSCP(NULL), m_pSCClient(NULL)
{
m_pSCClient = new CSecureChannelClient();
}
CSCPInfo::~CSCPInfo()
{
SAFE_DELETE(m_pSCClient);
SAFE_RELEASE(m_pSCP);
}
HRESULT CSCPInfo::hrInitialize(LPWSTR pwszProgID)
{
HRESULT hr;
CLSID clsid;
IComponentAuthenticate *pAuth = NULL;
DWORD dwLocalAppSec = 0;
DWORD dwRemoteAppSec = 0;
if (!m_pSCClient)
{
hr = E_FAIL;
goto Error;
}
CORg( m_pSCClient->SetCertificate(SAC_CERT_V1, (BYTE*)g_abAppCert, sizeof(g_abAppCert), (BYTE*)g_abPriv, sizeof(g_abPriv)) );
CORg( CLSIDFromProgID(pwszProgID, &clsid) );
CORg( CoCreateInstance(clsid, NULL, CLSCTX_INPROC_SERVER, IID_IComponentAuthenticate, (void**)&pAuth) );
m_pSCClient->SetInterface(pAuth);
CORg( m_pSCClient->Authenticate(SAC_PROTOCOL_V1) );
CORg( m_pSCClient->GetAppSec( &dwLocalAppSec, &dwRemoteAppSec ) );
// Only use SCP if appsec >= 1000
if( dwRemoteAppSec < MIN_SCP_APPSEC )
{
hrLogString( "Ignoring SCP with AppSec < 1000", S_FALSE );
hr = E_FAIL;
goto Error;
}
CORg( pAuth->QueryInterface(IID_ISCPSecureAuthenticate, (void**)&m_pSCP) );
Error:
if (pAuth)
pAuth->Release();
hrLogDWORD("CSCPInfo::hrInitialize returned 0x%08lx", hr, hr);
return hr;
}
HRESULT CSCPInfo::hrGetInterface(ISCPSecureAuthenticate **ppSCP)
{
m_pSCP->AddRef();
*ppSCP = m_pSCP;
return S_OK;
}
void CSCPInfo::GetSCClient(CSecureChannelClient **ppSCClient)
{
*ppSCClient = m_pSCClient;
}