|
|
/*++
Copyright (c) 1991-1993 Microsoft Corporation
Module Name:
NetLib.h
Abstract:
This header file declares various common routines for use in the networking code.
Author:
John Rogers (JohnRo) 14-Mar-1991
Environment:
Portable to any flat, 32-bit environment. (Uses Win32 typedefs.) Requires ANSI C extensions: slash-slash comments, long external names.
Notes:
You must include <windows.h> and <lmcons.h> before this file.
Revision History:
14-Mar-1991 JohnRo Created. 20-Mar-1991 JohnRo Moved NetpPackString here (was NetapipPackString). Removed tabs. 21-Mar-1991 RitaW Added NetpCopyStringToBuffer. 02-Apr-1991 JohnRo Moved NetpRdrFsControlTree to <netlibnt.h>. 03-Apr-1991 JohnRo Fixed types for NetpCopyStringToBuffer. 08-Apr-1991 CliffV Added NetpCopyDataToBuffer 10-Apr-1991 JohnRo Added NetpSetParmError (descended from CliffV's SetParmError). 10-Apr-1991 Danl Added NetpGetComputerName 24-Apr-1991 JohnRo Avoid conflicts with MIDL-generated files. Added NetpAdjustPreferedMaximum(). NetpCopyStringToBuffer's input string ptr is optional. 26-Apr-1991 CliffV Added NetpAllocateEnumBuffer. Added typedefs PTRDIFF_T and BUFFER_DESCRIPTOR. 16-Apr-1991 JohnRo Clarify UNICODE handling of pack and copy routines. 24-Jul-1991 JohnRo Provide NetpIsServiceStarted() for use by <netrpc.h> macros. 29-Oct-1991 JohnRo Added NetpChangeNullCharToNullPtr() macro. 29-Oct-1991 Danhi Add function prototypes for DosxxxMessage Api's 20-Nov-1991 JohnRo Removed NT dependencies to reduce recompiles. 09-Jan-1992 JohnRo Added NetpGetDomainName(). 23-Jan-1992 JohnRo Added IN_RANGE() macro based on MadanA's RANGECHECK(). 25-Mar-1992 RitaW Added SET_SERVICE_EXITCODE() macro for setting Win32 vs service specific exitcode. 06-May-1992 JohnRo Added NetpGetLocalDomainId() for PortUAS. Added NetpTranslateServiceName() for service controller APIs. 27-Jul-1992 Madana Added NetpWriteEventlog function proto type. 05-Aug-1992 JohnRo RAID 3021: NetService APIs don't always translate svc names. 09-Sep-1992 JohnRo RAID 1090: net start/stop "" causes assertion. 14-Oct-1992 JohnRo RAID 9020: setup: PortUas fails ("prompt on conflicts" version). 02-Nov-1992 JohnRo Added NetpIsRemoteServiceStarted(). 15-Feb-1993 JohnRo RAID 10685: user name not in repl event log. 24-Mar-1993 JohnRo Repl svc shuold use DBFlag in registry. 05-Aug-1993 JohnRo RAID 17010: Implement per-first-level-directory change notify. 19-Aug-1993 JohnRo RAID 2822: PortUAS maps chars funny. (Workaround FormatMessageA bug.) RAID 3094: PortUAS displays chars incorrectly.
--*/
#ifndef _NETLIB_ #define _NETLIB_
// These may be included in any order:
#include <string.h> // memcpy().
// Don't complain about "unneeded" includes of this file: /*lint -efile(764,wchar.h) */ /*lint -efile(766,wchar.h) */ #include <wchar.h> // iswdigit().
#ifdef CDEBUG // Debug in ANSI C environment?
#include <netdebug.h> // NetpAssert().
#endif // ndef CDEBUG
#ifdef __cplusplus extern "C" { #endif
// // IN_RANGE(): Make sure SomeValue is between SomeMin and SomeMax. // Beware side-effects (SomeValue is evaluated twice). // Created by JohnRo from MadanA's RANGECHECK(). // // BOOL // IN_RANGE( // IN DWORD SomeValue, // IN DWORD SomeMin, // IN DWORD SomeMax // ); // #define IN_RANGE(SomeValue, SomeMin, SomeMax) \ ( ((SomeValue) >= (SomeMin)) && ((SomeValue) <= (SomeMax)) )
// // SET_SERVICE_EXITCODE() sets the SomeApiStatus to NetCodeVariable // if it is within the NERR_BASE and NERR_MAX range. Otherwise, // Win32CodeVariable is set. This original code came from JohnRo. // #define SET_SERVICE_EXITCODE(SomeApiStatus, Win32CodeVariable, NetCodeVariable) \ { \ if ((SomeApiStatus) == NERR_Success) { \ (Win32CodeVariable) = NO_ERROR; \ (NetCodeVariable) = NERR_Success; \ } else if (! IN_RANGE((SomeApiStatus), MIN_LANMAN_MESSAGE_ID, MAX_LANMAN_MESSAGE_ID)) { \ (Win32CodeVariable) = (DWORD) (SomeApiStatus); \ (NetCodeVariable) = (DWORD) (SomeApiStatus); \ } else { \ (Win32CodeVariable) = ERROR_SERVICE_SPECIFIC_ERROR; \ (NetCodeVariable) = (DWORD) (SomeApiStatus); \ } \ }
VOID NetpAdjustPreferedMaximum ( IN DWORD PreferedMaximum, IN DWORD EntrySize, IN DWORD Overhead, OUT LPDWORD BytesToAllocate OPTIONAL, OUT LPDWORD EntriesToAllocate OPTIONAL );
// Portable memory move/copy routine: This is intended to have exactly // the semantics of ANSI C's memcpy() routine, except that the byte count // is 32 bits long. // // VOID // NetpMoveMemory( // OUT LPBYTE Dest, // Destination (must not be NULL). // IN LPBYTE Src, // Source // IN DWORD Size // Byte count // );
#ifdef CDEBUG
// Note that C6 version doesn't allow 32-bit Size, hence the // assertion. Replace this macro with another if this is a problem.
#define NetpMoveMemory(Dest,Src,Size) \ { \ NetpAssert( (Size) == (DWORD) (size_t) (Size)); \ (void) memcpy( (Dest), (Src), (size_t) (Size) ); \ }
#else // ndef CDEBUG
#define NetpMoveMemory(Dest,Src,Size) \ (void) memcpy( (Dest), (Src), (size_t) (Size) )
#endif // ndef CDEBUG
DWORD NetpPackString( IN OUT LPWSTR * string, // pointer by reference: string to be copied. IN LPBYTE dataend, // pointer to end of fixed size data. IN OUT LPWSTR * laststring // pointer by reference: top of string data. );
// // This routine is like NetpPackString, except that it does not expect the // caller to assign the pointer of the source string to the variable in the // fixed size structure before the call. It also takes a string character // count parameter instead of calling strlen on String. //
BOOL NetpCopyStringToBuffer ( IN LPWSTR String OPTIONAL, IN DWORD CharacterCount, IN LPBYTE FixedDataEnd, IN OUT LPWSTR *EndOfVariableData, OUT LPWSTR *VariableDataPointer );
// // This routine is like NetpCopyStringToBuffer except it copies any data // (not just strings), it does not put a zero byte at the end of the // data, and it allows the alignment of the resultant copied data to be // specified. //
BOOL NetpCopyDataToBuffer ( IN LPBYTE Data, IN DWORD ByteCount, IN LPBYTE FixedDataEnd, IN OUT LPBYTE *EndOfVariableData, OUT LPBYTE *VariableDataPointer, IN DWORD Alignment );
// // Declare a type for the difference between two pointers. // // This must be at least as long as a ptrdiff_t but we don't want to // add a dependency on <stddef.h> here. //
typedef DWORD_PTR PTRDIFF_T;
// // Declare a description of an enumeration buffer. //
typedef struct _BUFFER_DESCRIPTOR { LPBYTE Buffer; // Pointer to the allocated buffer. DWORD AllocSize; // Current size of the allocated buffer. DWORD AllocIncrement; // Amount to increment size by on each reallocate.
LPBYTE EndOfVariableData;// Pointer past last avaliable byte of string space LPBYTE FixedDataEnd; // Pointer past last used byte of fixed data space
} BUFFER_DESCRIPTOR, *PBUFFER_DESCRIPTOR;
// // This routine handles all the details of allocating and growing a // buffer returned from an enumeration function. It takes the users // prefered maximum size into consideration. //
#define NETP_ENUM_GUESS 16384 // Initial guess for enumeration buffer size
NET_API_STATUS NetpAllocateEnumBuffer( IN OUT PBUFFER_DESCRIPTOR BufferDescriptor, // Caller must deallocate BD->Buffer using MIDL_user_free.
IN BOOL IsGet, IN DWORD PrefMaxSize, IN DWORD NeededSize, IN VOID (*RelocationRoutine)( IN DWORD RelocationParameter, IN OUT PBUFFER_DESCRIPTOR BufferDescriptor, IN PTRDIFF_T Offset ), IN DWORD RelocationParameter );
NET_API_STATUS NetpAllocateEnumBufferEx( IN OUT PBUFFER_DESCRIPTOR BufferDescriptor, IN BOOL IsGet, IN DWORD PrefMaxSize, IN DWORD NeededSize, IN VOID (*RelocationRoutine)( IN DWORD RelocationParameter, IN OUT PBUFFER_DESCRIPTOR BufferDescriptor, IN PTRDIFF_T Offset ), IN DWORD RelocationParameter, IN DWORD IncrementalSize );
BOOL NetpIsServiceStarted( IN LPWSTR ServiceName );
// // Portable memory allocation routines. Memory is per-process only. //
// Allocate memory, or return NULL if not available.
LPVOID NetpMemoryAllocate( IN DWORD Size );
// Free memory at Address (must have been gotten from NetpMemoryAllocate or // NetpMemoryReallocate). (Address may be NULL.)
VOID NetpMemoryFree( IN LPVOID Address OPTIONAL );
// Reallocate block (now at OldAddress) to NewSize. OldAddress may be NULL. // Contents of block are copied if necessary. Returns NULL if unable to // allocate additional storage.
LPVOID NetpMemoryReallocate( IN LPVOID OldAddress OPTIONAL, IN DWORD NewSize );
// // Random handy macros: // #define NetpPointerPlusSomeBytes(p,n) \ (LPBYTE) ( ( (LPBYTE) (p)) + (n) )
#define NetpSetOptionalArg(arg, value) \ { \ if ((arg) != NULL) { \ *(arg) = (value); \ } \ }
// // Set the optional ParmError parameter //
#define NetpSetParmError( _ParmNumValue ) \ if ( ParmError != NULL ) { \ *ParmError = (_ParmNumValue); \ }
#if defined(lint) || defined(_lint) #define UNUSED(x) { (x) = (x); } #else #define UNUSED(x) { (void) (x); } #endif
// // NetpGetComputerName retrieves the local computername from the local // configuration database. //
NET_API_STATUS NetpGetComputerName ( IN LPWSTR *ComputerNamePtr);
NET_API_STATUS NetpGetComputerNameEx ( IN LPWSTR *ComputerNamePtr, IN BOOL PhysicalNetbiosName );
NET_API_STATUS NetpGetDomainName ( OUT LPWSTR *DomainNamePtr // alloc and set ptr (free with NetApiBufferFree) );
NET_API_STATUS NetpGetDomainNameEx ( OUT LPWSTR *DomainNamePtr, // alloc and set ptr (free with NetApiBufferFree) OUT PBOOLEAN IsWorkgroupName );
NET_API_STATUS NetpGetDomainNameExEx ( OUT LPWSTR *DomainNamePtr, OUT LPWSTR *DnsDomainNamePtr OPTIONAL, OUT PBOOLEAN IsWorkgroupName );
#ifndef GUID_DEFINED #define GUID_DEFINED typedef struct _GUID { DWORD Data1; WORD Data2; WORD Data3; BYTE Data4[ 8 ]; } GUID;
#endif // !GUID_DEFINED
NET_API_STATUS NetpGetDomainNameExExEx ( OUT LPTSTR *DomainNamePtr, OUT LPTSTR *DnsDomainNamePtr OPTIONAL, OUT LPTSTR *DnsForestNamePtr OPTIONAL, OUT GUID **DomainGuidPtr OPTIONAL, OUT PBOOLEAN IsWorkgroupName );
typedef enum _LOCAL_DOMAIN_TYPE { LOCAL_DOMAIN_TYPE_ACCOUNTS, LOCAL_DOMAIN_TYPE_BUILTIN, LOCAL_DOMAIN_TYPE_PRIMARY } LOCAL_DOMAIN_TYPE, *PLOCAL_DOMAIN_TYPE, *LPLOCAL_DOMAIN_TYPE;
NET_API_STATUS NetpGetLocalDomainId ( IN LOCAL_DOMAIN_TYPE TypeWanted, OUT PSID *RetDomainId // alloc and set ptr (free with LocalFree) );
// // NetService API helpers //
// BOOL // NetpIsServiceLevelValid( // IN DWORD Level // ); // #define NetpIsServiceLevelValid( Level ) \ ( ((Level)==0) || ((Level)==1) || ((Level)==2) )
NET_API_STATUS NetpTranslateNamesInServiceArray( IN DWORD Level, IN LPVOID ArrayBase, IN DWORD EntryCount, IN BOOL PreferNewStyle, OUT LPVOID * NewArrayBase );
NET_API_STATUS NetpTranslateServiceName( IN LPWSTR GivenServiceName, IN BOOL PreferNewStyle, OUT LPWSTR * TranslatedName );
// // Mapping routines to map DosxxxMessage API's to FormatMessage //
WORD DosGetMessage( IN LPSTR * InsertionStrings, IN WORD NumberofStrings, OUT LPBYTE Buffer, IN WORD BufferLength, IN WORD MessageId, IN LPWSTR FileName, OUT PWORD pMessageLength );
DWORD NetpGetPrivilege( IN DWORD numPrivileges, IN PULONG pulPrivileges );
DWORD NetpReleasePrivilege( VOID );
DWORD NetpWriteEventlog( LPWSTR Source, DWORD EventID, DWORD EventType, DWORD NumStrings, LPWSTR *Strings, DWORD DataLength, LPVOID Data );
DWORD NetpRaiseAlert( IN LPWSTR ServiceName, IN DWORD alert_no, IN LPWSTR *string_array );
// // Special flags to NetpEventlogWrite //
#define NETP_LAST_MESSAGE_IS_NTSTATUS 0x80000000 #define NETP_LAST_MESSAGE_IS_NETSTATUS 0x40000000 #define NETP_ALLOW_DUPLICATE_EVENTS 0x20000000 #define NETP_RAISE_ALERT_TOO 0x10000000 #define NETP_STRING_COUNT_MASK 0x000FFFFF
HANDLE NetpEventlogOpen ( IN LPWSTR Source, IN ULONG DuplicateEventlogTimeout );
DWORD NetpEventlogWrite ( IN HANDLE NetpEventHandle, IN DWORD EventId, IN DWORD EventType, IN LPBYTE RawDataBuffer OPTIONAL, IN DWORD RawDataSize, IN LPWSTR *StringArray, IN DWORD StringCount );
// // extended version with re-arranged parameters + category, to be more // compatible with ReportEvent(). //
DWORD NetpEventlogWriteEx ( IN HANDLE NetpEventHandle, IN DWORD EventType, IN DWORD EventCategory, IN DWORD EventId, IN DWORD StringCount, IN DWORD RawDataSize, IN LPWSTR *StringArray, IN LPVOID RawDataBuffer OPTIONAL );
// // even more extended version to allow specifying // arbitrary message index for the status code //
DWORD NetpEventlogWriteEx2 ( IN HANDLE NetpEventHandle, IN DWORD EventType, IN DWORD EventCategory, IN DWORD EventId, IN DWORD StringCount, IN DWORD StatusMessageIndex, IN DWORD RawDataSize, IN LPWSTR *StringArray, IN LPVOID pvRawDataBuffer OPTIONAL );
VOID NetpEventlogClearList ( IN HANDLE NetpEventHandle );
VOID NetpEventlogSetTimeout ( IN HANDLE NetpEventHandle, IN ULONG DuplicateEventlogTimeout );
VOID NetpEventlogClose ( IN HANDLE NetpEventHandle );
#ifdef __cplusplus } #endif
#endif // ndef _NETLIB_
|