2020-09-30 16:53:55 +02:00

307 lines
11 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
wsuse.h
Abstract:
Private header file to be included by Workstation service modules that
implement the NetUse APIs.
Author:
Rita Wong (ritaw) 05-Mar-1991
Revision History:
--*/
#ifndef _WSUSE_INCLUDED_
#define _WSUSE_INCLUDED_
#include <lmuse.h> // LAN Man Use API definitions
#include <dns.h> // DNS_MAX_NAME_LENGTH definition
//
// Length of fixed size portion of a use info structure
//
#define USE_FIXED_LENGTH(Level) \
(DWORD) \
((Level == 0) ? sizeof(USE_INFO_0) : \
((Level == 1) ? sizeof(USE_INFO_1) : \
((Level == 2) ? sizeof(USE_INFO_2) : \
sizeof(USE_INFO_3))))
//
// Total length of a use info structure (fixed and variable length portions)
//
#define USE_TOTAL_LENGTH(Level, LocalandUncNameLength, UserNameLength) \
(DWORD) \
((Level >= 2) ? (LocalandUncNameLength) + (UserNameLength) + \
((Level == 3) ? sizeof(USE_INFO_3) : sizeof(USE_INFO_2)) : \
(LocalandUncNameLength) + ((Level == 1) ? \
sizeof(USE_INFO_1) : \
sizeof(USE_INFO_0)))
//
// Hint size of an entry of use information from redirector
//
#define HINT_REDIR_INFO(Level) \
(DWORD) \
((Level == 1) ? sizeof(LMR_CONNECTION_INFO_1) + \
MAX_PATH * sizeof(WCHAR) : \
sizeof(LMR_CONNECTION_INFO_2) + \
(MAX_PATH + MAX_PATH) * sizeof(WCHAR))
//
// Length of fixed size portion of a redirector enumerate info structure
//
#define REDIR_ENUM_INFO_FIXED_LENGTH(Level) \
(DWORD) \
((Level == 0) ? sizeof(LMR_CONNECTION_INFO_0) : \
((Level == 1) ? sizeof(LMR_CONNECTION_INFO_1) : \
sizeof(LMR_CONNECTION_INFO_2)))
#define REDIR_LIST 0x80000000
//-----------------------------------------------------------------------//
// //
// Use Table //
// //
// +-----------------+ +-----------------+ //
// |TotalUseCount = 6| |TotalUseCount = 1| //
// +-----------------+ +-----------------+ //
// | RedirUseInfo | | RedirUseInfo | //
// +-----------------+ +-----------------+ //
// | UncNameLength | | UncNameLength | //
// +-----------------+ +-----------------+ //
// |\\POPCORN\RAZZLE | |\\FUZZY\PRINTER | //
// +-----------------+ +-----------------+ //
// ^ ^ ^ //
// | | | //
// +---+ +---+ | //
// | | | //
// +------------+ +--|--+------+ +--|--+------+ +--|--+------+ //
// | | | * | *---->| * | *---->| * | *---->... //
// | *-------->+-----+------+ +-----+------+ +-----+------+ //
// | | | P: |Local | |NULL |Local | |LPT1 |Local | //
// +------------+ | |Length| | |Length| | |Length| //
// | | +-----+------+ +-----+------+ +-----+------+ //
// | | |UseCount = 1| |UseCount = 5| |UseCount = 1| //
// 0 | LogonId | +------------+ +------------+ +------------+ //
// | | |Tree | |Tree | |Tree | //
// | | |Connection | |Connection | |Connection | //
// | | +------------+ +------------+ +------------+ //
// | | |ResumeKey | |ResumeKey | |ResumeKey | //
// | | +------------+ +------------+ +------------+ //
// | | |TreeConnStr | | NULL | |TreeConnStr | //
// | | +------------+ +------------+ +------------+ //
// | | //
// +============+ //
// | | //
// | *--------> ... //
// | | //
// +------------+ //
// | | //
// | LogonId | //
// 1 | | //
// | | //
// | | //
// | | //
// | | //
// | | //
// | | //
// | | //
// +============+ //
// | . | //
// | . | //
// | . | //
// //
// //
// The Use Table maintained by the Workstation service keeps a list of //
// explicit connections established by each user. A use entry is always //
// inserted into the end of the list. //
// //
// Implicit connections are not maintained in the Use Table. The //
// Workstation service has to ask the redirector to list all established //
// implicit connections when enumerating all active connections for a //
// user. //
// //
//-----------------------------------------------------------------------//
//
// The structure definition for the per user entry, which consists of a
// Logon Id and a pointer to a list, is defined in wsutil.h
//
//
// A remote entry for every unique shared resource name (\\server\share)
// of explicit connections.
//
typedef struct _UNC_NAME {
DWORD TotalUseCount;
DWORD UncNameLength;
LPTSTR UncName[1];
} UNC_NAME, *PUNC_NAME;
//
// A use entry in the linked list of connections.
//
typedef struct _USE_ENTRY {
struct _USE_ENTRY *Next;
PUNC_NAME Remote;
LPTSTR Local;
DWORD LocalLength;
DWORD UseCount;
HANDLE TreeConnection;
DWORD ResumeKey;
LPTSTR TreeConnectStr;
DWORD Flags;
} USE_ENTRY, *PUSE_ENTRY;
//
// Values for flags field
//
// USE_DEFAULT_CREDENTIALS 0x4 (defined in lmuse.h)
//
// Enumerated data type to say whether to pause or continue the redirection
//
typedef enum _REDIR_OPERATION {
PauseRedirection,
ContinueRedirection
} REDIR_OPERATION;
//-------------------------------------------------------------------//
// //
// Utility functions from useutil.c //
// //
//-------------------------------------------------------------------//
NET_API_STATUS
WsInitUseStructures(
VOID
);
VOID
WsDestroyUseStructures(
VOID
);
VOID
WsFindInsertLocation(
IN PUSE_ENTRY UseList,
IN LPTSTR UncName,
OUT PUSE_ENTRY *MatchedPointer,
OUT PUSE_ENTRY *InsertPointer
);
NET_API_STATUS
WsFindUse(
IN PLUID LogonId,
IN PUSE_ENTRY UseList,
IN LPTSTR UseName,
OUT PHANDLE TreeConnection,
OUT PUSE_ENTRY *MatchedPointer,
OUT PUSE_ENTRY *BackPointer OPTIONAL
);
VOID
WsFindUncName(
IN PUSE_ENTRY UseList,
IN LPTSTR UncName,
OUT PUSE_ENTRY *MatchedPointer,
OUT PUSE_ENTRY *BackPointer
);
NET_API_STATUS
WsCreateTreeConnectName(
IN LPTSTR UncName,
IN DWORD UncNameLength,
IN LPTSTR LocalName,
IN DWORD SessionId,
OUT PUNICODE_STRING TreeConnectStr
);
NET_API_STATUS
WsOpenCreateConnection(
IN PUNICODE_STRING TreeConnectionName,
IN LPTSTR UserName OPTIONAL,
IN LPTSTR DomainName OPTIONAL,
IN LPTSTR Password OPTIONAL,
IN ULONG CreateFlags,
IN ULONG CreateDisposition,
IN ULONG ConnectionType,
OUT PHANDLE TreeConnectionHandle,
OUT PULONG_PTR Information OPTIONAL
);
NET_API_STATUS
WsDeleteConnection(
IN PLUID LogonId,
IN HANDLE TreeConnection,
IN DWORD ForceLevel
);
BOOL
WsRedirectionPaused(
IN LPTSTR LocalDeviceName
);
VOID
WsPauseOrContinueRedirection(
IN REDIR_OPERATION OperationType
);
NET_API_STATUS
WsCreateSymbolicLink(
IN LPWSTR Local,
IN DWORD DeviceType,
IN LPWSTR TreeConnectStr,
IN PUSE_ENTRY UseList,
IN OUT LPWSTR *Session,
IN OUT HANDLE *lphToken
);
VOID
WsDeleteSymbolicLink(
IN LPWSTR LocalDeviceName,
IN LPWSTR TreeConnectStr,
IN LPWSTR SessionDeviceName,
IN HANDLE hToken
);
NET_API_STATUS
WsUseCheckRemote(
IN LPTSTR RemoteResource,
OUT LPTSTR UncName,
OUT LPDWORD UncNameLength
);
NET_API_STATUS
WsUseCheckLocal(
IN LPTSTR LocalDevice,
OUT LPTSTR Local,
OUT LPDWORD LocalLength
);
//-------------------------------------------------------------------//
// //
// External global variables //
// //
//-------------------------------------------------------------------//
//
// Use Table
//
extern USERS_OBJECT Use;
#endif // ifndef _WSUSE_INCLUDED_