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.
 
 
 
 
 
 

454 lines
12 KiB

//+-------------------------------------------------------------------------
//
// Microsoft Windows
//
// Copyright (C) Microsoft Corporation, 1997 - 1999
//
// File: catdbcli.cpp
//
//--------------------------------------------------------------------------
#include <windows.h>
#include <wincrypt.h>
#include "unicode.h"
#include "catdb.h"
#include "catdbcli.h"
#include "..\..\cryptsvc\service.h"
#include "errlog.h"
#include "waitsvc.h"
#ifndef KEYSVC_LOCAL_ENDPOINT
#define KEYSVC_LOCAL_ENDPOINT (L"keysvc")
#endif
#ifndef KEYSVC_LOCAL_PROT_SEQ
#define KEYSVC_LOCAL_PROT_SEQ (L"ncalrpc")
#endif
#define CATDBCLI_LOGERR_LASTERR() ErrLog_LogError(NULL, \
ERRLOG_CLIENT_ID_CATDBCLI, \
__LINE__, \
0, \
FALSE, \
FALSE);
#define CATDBCLI_LOGERR(x) ErrLog_LogError(NULL, \
ERRLOG_CLIENT_ID_CATDBCLI, \
__LINE__, \
x, \
FALSE, \
FALSE);
#define MAX_RPCRETRIES 20
void
_SSCatDBTeardownRPCConnection(
RPC_BINDING_HANDLE *phRPCBinding)
{
RpcBindingFree(phRPCBinding);
}
DWORD
_SSCatDBSetupRPCConnection(
RPC_BINDING_HANDLE *phRPCBinding)
{
unsigned short *pStringBinding = NULL;
RPC_STATUS rpcStatus = RPC_S_OK;
static BOOL fDone = FALSE;
RPC_SECURITY_QOS RpcSecurityQOS;
SID_IDENTIFIER_AUTHORITY SIDAuth = SECURITY_NT_AUTHORITY;;
PSID pSID = NULL;
WCHAR szName[64];
DWORD cbName = 64;
WCHAR szDomainName[256]; // max domain is 255
DWORD cbDomainName = 256;
SID_NAME_USE Use;
//
// wait for the service to be available before attempting bind
//
if (!WaitForCryptService(SZSERVICENAME, &fDone, TRUE))
{
CATDBCLI_LOGERR_LASTERR()
if (GetLastError() == ERROR_SERVICE_DISABLED)
{
return ERROR_SERVICE_DISABLED;
}
else
{
return ERROR_SERVICE_NOT_ACTIVE;
}
}
//
// get a binding handle
//
if (RPC_S_OK != (rpcStatus = RpcStringBindingComposeW(
NULL,
(unsigned short *)KEYSVC_LOCAL_PROT_SEQ,
NULL, //LPC - no machine name
(unsigned short *)KEYSVC_LOCAL_ENDPOINT,
0,
&pStringBinding)))
{
CATDBCLI_LOGERR(rpcStatus)
goto Ret;
}
if (RPC_S_OK != (rpcStatus = RpcBindingFromStringBindingW(
pStringBinding,
phRPCBinding)))
{
CATDBCLI_LOGERR(rpcStatus)
goto Ret;
}
if (RPC_S_OK != (rpcStatus = RpcEpResolveBinding(
*phRPCBinding,
ICatDBSvc_v1_0_c_ifspec)))
{
CATDBCLI_LOGERR(rpcStatus)
_SSCatDBTeardownRPCConnection(phRPCBinding);
goto Ret;
}
//
// Set the autorization so that we will only call a Local Service process
//
memset(&RpcSecurityQOS, 0, sizeof(RpcSecurityQOS));
RpcSecurityQOS.Version = RPC_C_SECURITY_QOS_VERSION;
RpcSecurityQOS.Capabilities = RPC_C_QOS_CAPABILITIES_MUTUAL_AUTH;
RpcSecurityQOS.IdentityTracking = RPC_C_QOS_IDENTITY_DYNAMIC;
RpcSecurityQOS.ImpersonationType = RPC_C_IMP_LEVEL_IMPERSONATE;
if (AllocateAndInitializeSid(&SIDAuth, 1,
SECURITY_LOCAL_SYSTEM_RID,
0, 0, 0, 0, 0, 0, 0,
&pSID) == 0)
{
CATDBCLI_LOGERR_LASTERR()
goto Ret;
}
if (LookupAccountSidW(NULL,
pSID,
szName,
&cbName,
szDomainName,
&cbDomainName,
&Use) == 0)
{
CATDBCLI_LOGERR_LASTERR()
goto Ret;
}
if (RPC_S_OK != (rpcStatus = RpcBindingSetAuthInfoExW(
*phRPCBinding,
szName,
RPC_C_AUTHN_LEVEL_PKT,
RPC_C_AUTHN_WINNT,
NULL,
0,
&RpcSecurityQOS)))
{
CATDBCLI_LOGERR(rpcStatus)
goto Ret;
}
Ret:
if (pStringBinding != NULL)
{
RpcStringFreeW(&pStringBinding);
}
if (pSID != NULL)
{
FreeSid( pSID );
}
return ((DWORD) rpcStatus);
}
DWORD
Client_SSCatDBAddCatalog(
/* [in] */ DWORD dwFlags,
/* [in] */ LPCWSTR pwszSubSysGUID,
/* [in] */ LPCWSTR pwszCatalogFile,
/* [in] */ LPCWSTR pwszCatName,
/* [out] */ LPWSTR *ppwszCatalogNameUsed)
{
RPC_BINDING_HANDLE hRPCBinding;
DWORD dwErr = 0;
DWORD dwRetryCount = 0;
dwErr = _SSCatDBSetupRPCConnection(&hRPCBinding);
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
return dwErr;
}
dwErr = RPC_S_SERVER_TOO_BUSY;
while ( (dwErr == RPC_S_SERVER_TOO_BUSY) &&
(dwRetryCount < MAX_RPCRETRIES))
{
__try
{
dwErr = SSCatDBAddCatalog(
hRPCBinding,
dwFlags,
pwszSubSysGUID,
pwszCatalogFile,
pwszCatName,
ppwszCatalogNameUsed);
}
__except ( EXCEPTION_EXECUTE_HANDLER )
{
dwErr = _exception_code();
if (dwErr == RPC_S_SERVER_TOO_BUSY)
{
Sleep(100);
}
}
dwRetryCount++;
}
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
}
_SSCatDBTeardownRPCConnection(&hRPCBinding);
return dwErr;
}
DWORD Client_SSCatDBDeleteCatalog(
/* [in] */ DWORD dwFlags,
/* [in] */ LPCWSTR pwszSubSysGUID,
/* [in] */ LPCWSTR pwszCatalogFile)
{
RPC_BINDING_HANDLE hRPCBinding;
DWORD dwErr = 0;
DWORD dwRetryCount = 0;
dwErr = _SSCatDBSetupRPCConnection(&hRPCBinding);
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
return dwErr;
}
dwErr = RPC_S_SERVER_TOO_BUSY;
while ( (dwErr == RPC_S_SERVER_TOO_BUSY) &&
(dwRetryCount < MAX_RPCRETRIES))
{
__try
{
dwErr = SSCatDBDeleteCatalog(
hRPCBinding,
dwFlags,
pwszSubSysGUID,
pwszCatalogFile);
}
__except ( EXCEPTION_EXECUTE_HANDLER )
{
dwErr = _exception_code();
if (dwErr == RPC_S_SERVER_TOO_BUSY)
{
Sleep(100);
}
}
dwRetryCount++;
}
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
}
_SSCatDBTeardownRPCConnection(&hRPCBinding);
return dwErr;
}
DWORD
Client_SSCatDBEnumCatalogs(
/* [in] */ DWORD dwFlags,
/* [in] */ LPCWSTR pwszSubSysGUID,
/* [size_is][in] */ BYTE *pbHash,
/* [in] */ DWORD cbHash,
/* [out] */ DWORD *pdwNumCatalogNames,
/* [size_is][size_is][out] */ LPWSTR **pppwszCatalogNames)
{
RPC_BINDING_HANDLE hRPCBinding;
DWORD dwErr = 0;
DWORD dwRetryCount = 0;
dwErr = _SSCatDBSetupRPCConnection(&hRPCBinding);
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
return dwErr;
}
dwErr = RPC_S_SERVER_TOO_BUSY;
while ( (dwErr == RPC_S_SERVER_TOO_BUSY) &&
(dwRetryCount < MAX_RPCRETRIES))
{
__try
{
dwErr = SSCatDBEnumCatalogs(
hRPCBinding,
dwFlags,
pwszSubSysGUID,
cbHash,
pbHash,
pdwNumCatalogNames,
pppwszCatalogNames);
}
__except ( EXCEPTION_EXECUTE_HANDLER )
{
dwErr = _exception_code();
if (dwErr == RPC_S_SERVER_TOO_BUSY)
{
Sleep(100);
}
}
dwRetryCount++;
}
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
}
_SSCatDBTeardownRPCConnection(&hRPCBinding);
return dwErr;
}
DWORD
Client_SSCatDBRegisterForChangeNotification(
/* [in] */ DWORD_PTR EventHandle,
/* [in] */ DWORD dwFlags,
/* [in] */ LPCWSTR pwszSubSysGUID,
/* [in] */ BOOL fUnRegister)
{
RPC_BINDING_HANDLE hRPCBinding;
DWORD dwErr = 0;
DWORD dwRetryCount = 0;
dwErr = _SSCatDBSetupRPCConnection(&hRPCBinding);
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
return dwErr;
}
dwErr = RPC_S_SERVER_TOO_BUSY;
while ( (dwErr == RPC_S_SERVER_TOO_BUSY) &&
(dwRetryCount < MAX_RPCRETRIES))
{
__try
{
dwErr = SSCatDBRegisterForChangeNotification(
hRPCBinding,
EventHandle,
dwFlags,
pwszSubSysGUID,
fUnRegister);
}
__except ( EXCEPTION_EXECUTE_HANDLER )
{
dwErr = _exception_code();
if (dwErr == RPC_S_SERVER_TOO_BUSY)
{
Sleep(100);
}
}
dwRetryCount++;
}
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
}
_SSCatDBTeardownRPCConnection(&hRPCBinding);
return dwErr;
}
DWORD
Client_SSCatDBPauseResumeService(
/* [in] */ DWORD dwFlags,
/* [in] */ BOOL fResume)
{
RPC_BINDING_HANDLE hRPCBinding;
DWORD dwErr = 0;
DWORD dwRetryCount = 0;
dwErr = _SSCatDBSetupRPCConnection(&hRPCBinding);
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
return dwErr;
}
dwErr = RPC_S_SERVER_TOO_BUSY;
while ( (dwErr == RPC_S_SERVER_TOO_BUSY) &&
(dwRetryCount < MAX_RPCRETRIES))
{
__try
{
dwErr = SSCatDBPauseResumeService(
hRPCBinding,
dwFlags,
fResume);
}
__except ( EXCEPTION_EXECUTE_HANDLER )
{
dwErr = _exception_code();
if (dwErr == RPC_S_SERVER_TOO_BUSY)
{
Sleep(100);
}
}
dwRetryCount++;
}
if (dwErr != 0)
{
CATDBCLI_LOGERR(dwErr)
}
_SSCatDBTeardownRPCConnection(&hRPCBinding);
return dwErr;
}