windows-nt/Source/XPSP1/NT/net/winnet/mprdata.h
2020-09-26 16:20:57 +08:00

508 lines
12 KiB
C

/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
mprdata.h
Abstract:
Contains data structures and function prototypes that are internal to
MPR.
Author:
Dan Lafferty (danl) 07-Sept-1991
Environment:
User Mode -Win32
Revision History:
05-May-1999 jschwart
Make provider addition/removal dynamic
01-Mar-1994 Danl
Created a separate location for the Credential Managers GetCaps()
function. This way if a provider has both a credential manager
dll and a network dll, we will be able to direct calls to the
correct GetCaps() function.
07-Jan-1993 Danl
Add NPLogonNotify and NPPasswordChangeNotify and AuthentDllName
to PROVIDER structure. Also added CREDENTIAL_TYPE InitClass.
04-Aug-1992 chuckc
added MprEnterLoadLibCritSect, MprLeaveLoadLibCritSect.
07-Sept-1991 danl
created
--*/
//
// Includes
//
//=======================
// Data Structures
//=======================
typedef struct _PROVIDER {
NETRESOURCE Resource;
DWORD Type; // WNNC_NET_MSNet, WNNC_NET_LanMan, WNNC_NET_NetWare
HMODULE Handle; // Handle to the provider DLL.
LPTSTR DllName; // set to NULL after loaded.
HMODULE AuthentHandle; // Handle to authenticator DLL.
LPTSTR AuthentDllName; // Authenticator Dll.
DWORD InitClass; // Network or Authentication provider.
DWORD ConnectCaps; // Cached result of GetCaps(WNNC_CONNECTION)
DWORD ConnectFlagCaps;// Cached result of GetCaps(WNNC_CONNECTION_FLAGS)
PF_NPAddConnection AddConnection;
PF_NPAddConnection3 AddConnection3;
PF_NPGetReconnectFlags GetReconnectFlags;
PF_NPCancelConnection CancelConnection;
PF_NPGetConnection GetConnection;
PF_NPGetConnection3 GetConnection3;
PF_NPGetUser GetUser;
PF_NPOpenEnum OpenEnum;
PF_NPEnumResource EnumResource;
PF_NPCloseEnum CloseEnum;
PF_NPGetCaps GetCaps;
PF_NPGetDirectoryType GetDirectoryType;
PF_NPDirectoryNotify DirectoryNotify;
PF_NPPropertyDialog PropertyDialog;
PF_NPGetPropertyText GetPropertyText;
PF_NPSearchDialog SearchDialog;
PF_NPFormatNetworkName FormatNetworkName;
PF_NPLogonNotify LogonNotify;
PF_NPPasswordChangeNotify PasswordChangeNotify;
PF_NPGetCaps GetAuthentCaps;
PF_NPFMXGetPermCaps FMXGetPermCaps;
PF_NPFMXEditPerm FMXEditPerm;
PF_NPFMXGetPermHelp FMXGetPermHelp;
PF_NPGetUniversalName GetUniversalName;
PF_NPGetResourceParent GetResourceParent;
PF_NPGetResourceInformation GetResourceInformation;
PF_NPGetConnectionPerformance GetConnectionPerformance;
}PROVIDER, *LPPROVIDER;
//=======================
// MACROS
//=======================
#define IS_EMPTY_STRING(pch) ( !pch || !*(pch) )
#define LENGTH(array) (sizeof(array)/sizeof((array)[0]))
#define INIT_IF_NECESSARY(level,status) ASSERT(MPRProviderLock.Have()); \
if(!(GlobalInitLevel & level)) { \
status = MprLevel2Init(level); \
if (status != WN_SUCCESS) { \
SetLastError(status); \
return(status); \
} \
}
#define MPR_IS_INITIALIZED(level) (GlobalInitLevel & level ## _LEVEL)
#define ASSERT_INITIALIZED(level) ASSERT(MPR_IS_INITIALIZED(level) && \
MPRProviderLock.Have());
//=======================
// INLINE FUNCTIONS
//=======================
inline void
PROBE_FOR_WRITE(
LPDWORD pdw
)
// WARNING: This function can throw an exception. It must be called from
// within a try-except block.
{
*(volatile DWORD *)pdw = *(volatile DWORD *)pdw;
}
inline BOOL
IS_BAD_BYTE_BUFFER(
LPVOID lpBuffer,
LPDWORD lpBufferSize // in bytes
)
// WARNING: This function can throw an exception. It must be called from
// within a try-except block.
{
PROBE_FOR_WRITE(lpBufferSize);
return IsBadWritePtr(lpBuffer, *lpBufferSize);
}
inline BOOL
IS_BAD_WCHAR_BUFFER(
LPVOID lpBuffer,
LPDWORD lpBufferSize // in Unicode characters
)
// WARNING: This function can throw an exception. It must be called from
// within a try-except block.
{
PROBE_FOR_WRITE(lpBufferSize);
return IsBadWritePtr(lpBuffer, *lpBufferSize * sizeof(WCHAR));
}
//=======================
// CONSTANTS
//=======================
#define DEFAULT_MAX_PROVIDERS 25
// Bit masks for remembering error codes
#define BAD_NAME 0x00000001
#define NO_NET 0x00000002
#define NOT_CONNECTED 0x00000004
#define NOT_CONTAINER 0x00000008
#define NO_DEVICES 0x00000010
#define OTHER_ERRS 0xFFFFFFFF
#define REDIR_DEVICE 0x00000001
#define REMOTE_NAME 0x00000002
#define LOCAL_NAME REDIR_DEVICE
#define DA_READ 0x00000001
#define DA_WRITE 0x00000002
#define DA_DELETE 0x00000004
//
// Timeout values for restoring connections and notifying
// Credential Managers.
//
#define DEFAULT_WAIT_TIME 60000 // Default timeout if providers don't
// specify.
#define MAX_ALLOWED_WAIT_TIME 300000 // Max timeout a provider can specify
#define RECONNECT_SLEEP_INCREMENT 3000 // number of seconds to sleep
#define PROVIDER_WILL_NOT_START 0x00000000 // The provider will not be starting
#define NO_TIME_ESTIMATE 0xffffffff // The provider cannot predict the
// amount of time it will take to
// start.
#define NET_PROVIDER_KEY TEXT("system\\CurrentControlSet\\Control\\NetworkProvider")
#define RESTORE_WAIT_VALUE TEXT("RestoreTimeout")
#define RESTORE_CONNECTION_VALUE TEXT("RestoreConnection")
#define DEFER_CONNECTION_VALUE TEXT("DeferConnection")
//
// GlobalInitLevels & InitClasses
//
// NOTE: The WN_???_CLASS values are bit masks.
//
// GlobalInitLevel
#define FIRST_LEVEL 0x00000001
#define NETWORK_LEVEL 0x00000002
#define CREDENTIAL_LEVEL 0x00000004
#define NOTIFIEE_LEVEL 0x00000008
//
//
// InitClasses
#define NETWORK_TYPE WN_NETWORK_CLASS
#define CREDENTIAL_TYPE (WN_CREDENTIAL_CLASS | WN_PRIMARY_AUTHENT_CLASS)
// The path in the registry for user's persistent connections is found in
// the following key:
//
// "\HKEY_CURRENT_USER\Network"
//
// Subkeys of the network section listed by local drive names. These
// keys contain the following values:
// RemotePath, Type, ProviderName, UserName
//
// d: RemotePath = \\cyclops\scratch
// Type = RESOURCE_TYPE_DISK
// ProviderName = LanMan
// UserName = Ernie
#define CONNECTION_KEY_NAME TEXT("Network")
#define REMOTE_PATH_NAME TEXT("RemotePath")
#define USER_NAME TEXT("UserName")
#define PROVIDER_NAME TEXT("ProviderName")
#define PROVIDER_TYPE TEXT("ProviderType")
#define PROVIDER_FLAGS TEXT("ProviderFlags")
#define DEFER_FLAGS TEXT("DeferFlags")
#define CONNECTION_TYPE TEXT("ConnectionType")
#define PRINT_CONNECTION_KEY_NAME TEXT("Printers\\RestoredConnections")
//=======================
// Global data
//=======================
extern LPPROVIDER GlobalProviderInfo; // pArray of PROVIDER Structures
extern DWORD GlobalNumProviders;
extern DWORD MprDebugLevel;
extern HANDLE MprLoadLibSemaphore; // used to protect DLL handles
extern volatile DWORD GlobalInitLevel;
extern CRITICAL_SECTION MprErrorRecCritSec;
extern WCHAR g_wszEntireNetwork[40];
//==========================
// Functions from support.c
//==========================
VOID
MprDeleteIndexArray(
VOID
);
DWORD
MprFindCallOrder(
IN LPTSTR NameInfo,
OUT LPDWORD *IndexArrayPtr,
OUT LPDWORD IndexArrayCount,
IN DWORD InitClass
);
DWORD
MprDeviceType(
IN LPCTSTR DeviceName
);
BOOL
MprGetProviderIndex(
IN LPCTSTR ProviderName,
OUT LPDWORD IndexPtr
);
LPPROVIDER
MprFindProviderByName(
IN LPCWSTR ProviderName
);
LPPROVIDER
MprFindProviderByType(
IN DWORD ProviderType
);
DWORD
MprFindProviderForPath(
IN LPWSTR lpPathName,
OUT LPDWORD lpProviderIndex
);
VOID
MprInitIndexArray(
LPDWORD IndexArray,
DWORD NumEntries
);
VOID
MprEndCallOrder(
VOID
);
VOID
MprFreeAllErrorRecords(
VOID
);
BOOL
MprNetIsAvailable(
VOID) ;
//=========================
// Functions from mprreg.c
//=========================
BOOL
MprOpenKey(
HKEY hKey,
LPTSTR lpSubKey,
PHKEY phKeyHandle,
DWORD desiredAccess
);
BOOL
MprGetKeyValue(
HKEY KeyHandle,
LPTSTR ValueName,
LPTSTR *ValueString
);
BOOL
MprGetKeyDwordValue(
IN HKEY KeyHandle,
IN LPCWSTR ValueName,
OUT DWORD * Value
);
LONG
MprGetKeyNumberValue(
IN HKEY KeyHandle,
IN LPCWSTR ValueName,
IN LONG Default
);
DWORD
MprEnumKey(
IN HKEY KeyHandle,
IN DWORD SubKeyIndex,
OUT LPTSTR *SubKeyName,
IN DWORD MaxSubKeyNameLen
);
BOOL
MprGetKeyInfo(
IN HKEY KeyHandle,
OUT LPDWORD TitleIndex OPTIONAL,
OUT LPDWORD NumSubKeys,
OUT LPDWORD MaxSubKeyLen,
OUT LPDWORD NumValues OPTIONAL,
OUT LPDWORD MaxValueLen
);
DWORD MprGetPrintKeyInfo(HKEY KeyHandle,
LPDWORD NumValueNames,
LPDWORD MaxValueNameLength,
LPDWORD MaxValueLen) ;
BOOL
MprFindDriveInRegistry (
IN LPCTSTR DriveName,
OUT LPTSTR *RemoteName
);
DWORD
MprSaveDeferFlags(
IN HKEY RegKey,
IN DWORD DeferFlags
);
DWORD
MprSetRegValue(
IN HKEY KeyHandle,
IN LPTSTR ValueName,
IN LPCTSTR ValueString,
IN DWORD LongValue
);
DWORD
MprCreateRegKey(
IN HKEY BaseKeyHandle,
IN LPCTSTR KeyName,
OUT PHKEY KeyHandlePtr
);
BOOL
MprReadConnectionInfo(
IN HKEY KeyHandle,
IN LPCTSTR DriveName,
IN DWORD Index,
OUT LPDWORD ProviderFlags,
OUT LPDWORD DeferFlags,
OUT LPTSTR *UserNamePtr,
OUT LPNETRESOURCEW NetResource,
OUT HKEY *SubKeyHandleOut,
IN DWORD MaxSubKeyLen
);
VOID
MprForgetRedirConnection(
IN LPCTSTR lpName
);
DWORD
MprForgetPrintConnection(
IN LPTSTR lpName
);
BOOL
MprGetRemoteName(
IN LPTSTR lpLocalName,
IN OUT LPDWORD lpBufferSize,
OUT LPTSTR lpRemoteName,
OUT LPDWORD lpStatus
) ;
//=========================
// Functions from strbuf.c
//=========================
BOOL
NetpCopyStringToBufferW (
IN LPTSTR String OPTIONAL,
IN DWORD CharacterCount,
IN LPTSTR FixedDataEnd,
IN OUT LPTSTR *EndOfVariableData,
OUT LPTSTR *VariableDataPointer
);
BOOL
NetpCopyStringToBufferA (
IN LPTSTR String OPTIONAL,
IN DWORD CharacterCount,
IN LPBYTE FixedDataEnd,
IN OUT LPTSTR *EndOfVariableData,
OUT LPTSTR *VariableDataPointer
);
#ifdef UNICODE
#define NetpCopyStringToBuffer NetpCopyStringToBufferW
#else
#define NetpCopyStringToBuffer NetpCopyStringToBufferA
#endif
//=========================
// Other functions
//=========================
VOID
MprCheckProviders(
VOID
);
DWORD
MprLevel1Init(
VOID
);
DWORD
MprLevel2Init(
DWORD InitClass
);
DWORD
MprEnterLoadLibCritSect (
VOID
) ;
DWORD
MprLeaveLoadLibCritSect (
VOID
) ;
VOID
MprClearString (
LPWSTR lpString
) ;
DWORD
MprGetConnection (
IN LPCWSTR lpLocalName,
OUT LPWSTR lpRemoteName,
IN OUT LPDWORD lpBufferSize,
OUT LPDWORD lpProviderIndex OPTIONAL
) ;
DWORD
OutputStringToAnsiInPlace(
IN LPWSTR UnicodeIn
);