Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

90 lines
3.0 KiB

//---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995
//
// File: globals.hxx
//
// Contents:
//
// History:
//----------------------------------------------------------------------------
extern TCHAR *szProviderName;
extern TCHAR *szLDAPNamespaceName;
extern TCHAR *szGCNamespaceName;
//
// Need these for groups related functionality.
//
#define SERVER_TYPE_UNKNOWN 0
#define SERVER_TYPE_AD 1
#define SERVER_TYPE_NOT_AD 2
//
// Global variables to keep track of dynamically loaded functions.
//
extern BOOL g_fDllsLoaded;
extern HANDLE g_hDllSecur32;
//
// This cs is also used for the dynamically loading functions.
//
extern CRITICAL_SECTION g_ServerListCritSect;
#define ENTER_SERVERLIST_CRITICAL_SECTION() EnterCriticalSection(&g_ServerListCritSect);
#define LEAVE_SERVERLIST_CRITICAL_SECTION() LeaveCriticalSection(&g_ServerListCritSect);
//
// Definitions for the wrapper functions loaded dynamically.
//
#define ACQUIRECREDENTIALSHANDLE_API "AcquireCredentialsHandleW"
#define FREECREDENTIALSHANDLE_API "FreeCredentialsHandle"
//
// AcquireCredentialsHandle definition.
//
typedef SECURITY_STATUS (*PF_AcquireCredentialsHandleW) (
#if ISSP_MODE == 0 // For Kernel mode
PSECURITY_STRING pPrincipal,
PSECURITY_STRING pPackage,
#else
SEC_WCHAR SEC_FAR * pszPrincipal, // Name of principal
SEC_WCHAR SEC_FAR * pszPackage, // Name of package
#endif
unsigned long fCredentialUse, // Flags indicating use
void SEC_FAR * pvLogonId, // Pointer to logon ID
void SEC_FAR * pAuthData, // Package specific data
SEC_GET_KEY_FN pGetKeyFn, // Pointer to GetKey() func
void SEC_FAR * pvGetKeyArgument, // Value to pass to GetKey()
PCredHandle phCredential, // (out) Cred Handle
PTimeStamp ptsExpiry // (out) Lifetime (optional)
);
SECURITY_STATUS
AcquireCredentialsHandleWrapper(
#if ISSP_MODE == 0 // For Kernel mode
PSECURITY_STRING pPrincipal,
PSECURITY_STRING pPackage,
#else
SEC_WCHAR SEC_FAR * pszPrincipal, // Name of principal
SEC_WCHAR SEC_FAR * pszPackage, // Name of package
#endif
unsigned long fCredentialUse, // Flags indicating use
void SEC_FAR * pvLogonId, // Pointer to logon ID
void SEC_FAR * pAuthData, // Package specific data
SEC_GET_KEY_FN pGetKeyFn, // Pointer to GetKey() func
void SEC_FAR * pvGetKeyArgument, // Value to pass to GetKey()
PCredHandle phCredential, // (out) Cred Handle
PTimeStamp ptsExpiry // (out) Lifetime (optional)
);
//
// FreeCredentials Handle Wrapper.
//
typedef SECURITY_STATUS (*PF_FreeCredentialsHandle)(
PCredHandle phCredential // Handle to free
);
SECURITY_STATUS
FreeCredentialsHandleWrapper(
PCredHandle phCredential // Handle to free
);