/*++ Copyright (c) 1991-1992 Microsoft Corporation Module Name: ConfGet.c Abstract: This file contains the RpcXlate code to handle the NetConfigGet API. Author: John Rogers (JohnRo) 24-Oct-1991 Environment: Portable to any flat, 32-bit environment. (Uses Win32 typedefs.) Requires ANSI C extensions: slash-slash comments, long external names. Revision History: 24-Oct-1991 JohnRo Created. 28-Oct-1991 JohnRo Made changes suggested by PC-LINT. (Only affects UNICODE option.) 01-Apr-1992 JohnRo Use NetApiBufferAllocate() instead of private version. 05-Jun-1992 JohnRo RAID 11253: NetConfigGetAll fails when remoted to downlevel. Use PREFIX_ equates. 23-Oct-1992 JohnRo RAID 9357: server mgr: can't add to alerts list on downlevel. Fixed __stdcall for RpcXlate workers. --*/ // These must be included first: #include // IN, DWORD, etc. #include // LM20_ equates, NET_API_STATUS, etc. // These may be included in any order: #include // API_ equates. #include // NetApiBufferAllocate(), NetApiBufferFree(). #include // ERROR_ and NERR_ equates. #include // NetpKdPrint(()), FORMAT_ equates, etc. #include // PREFIX_ equates. #include // LPDESC. #include // REM16_, REM32_, REMSmb_ equates. #include // RxRemoteApi(). #include // IF_DEBUG(). #include // My prototype. #include // NetpCopyStrToTStr(). NET_API_STATUS RxNetConfigGet ( IN LPTSTR UncServerName, IN LPTSTR Component, IN LPTSTR Parameter, OUT LPBYTE *BufPtr ) /*++ Routine Description: RxNetConfigGet performs the same function as NetConfigGet, except that the server name is known to refer to a downlevel server. Arguments: (Same as NetConfigGet, except UncServerName must not be null, and must not refer to the local computer.) Return Value: (Same as NetConfigGet.) --*/ { const DWORD BufSize = 65535; NET_API_STATUS Status; DWORD TotalAvail; IF_DEBUG(CONFIG) { NetpKdPrint(( PREFIX_NETAPI "RxNetConfigGet: starting, server=" FORMAT_LPTSTR ", component=" FORMAT_LPTSTR ", parm=" FORMAT_LPTSTR ".\n", UncServerName, Component, Parameter )); } // // Error check DLL stub and the app. // NetpAssert(UncServerName != NULL); if (BufPtr == NULL) { return (ERROR_INVALID_PARAMETER); } *BufPtr = NULL; // assume error; it makes error handlers easy to code. // This also forces possible GP fault before we allocate memory. // // Actually remote the API, which will get back the // data in native format. // Status = RxRemoteApi( API_WConfigGet2, // API number UncServerName, // Required, with \\name. REMSmb_NetConfigGet_P, // parm desc REM16_configget_info, // data desc 16 REM32_configget_info, // data desc 32 REMSmb_configget_info, // data desc SMB NULL, // no aux data desc 16 NULL, // no aux data desc 32 NULL, // no aux data desc SMB ALLOCATE_RESPONSE, // Flags: alloc mem for us. // rest of API's arguments, in 32-bit LM 2.x format: NULL, // reserved (must be null pointer) Component, Parameter, BufPtr, // pbBuffer (will be set) BufSize, // cbBuffer & TotalAvail); // total size (meaningless!) NetpAssert( Status != ERROR_MORE_DATA ); NetpAssert( Status != NERR_BufTooSmall ); if (Status == NERR_Success) { #ifdef UNICODE DWORD SrcByteCount = strlen((LPSTR) *BufPtr)+1; // Bytes for 8-bit str. LPVOID TempBuff = *BufPtr; // non-UNICODE version of string. LPVOID UnicodeBuff; // // Allocate space for UNICODE version of string. // Status = NetApiBufferAllocate( SrcByteCount * sizeof(TCHAR), & UnicodeBuff); if (Status != NERR_Success) { return (Status); } NetpAssert(UnicodeBuff != NULL); // // Translate result string to Unicode. // NetpCopyStrToTStr( UnicodeBuff, // dest (in UNICODE) TempBuff); // src string (in codepage) (void) NetApiBufferFree( TempBuff ); *BufPtr = UnicodeBuff; #else // not UNICODE // BufPtr should already point at non-UNICODE string. NetpAssert( *BufPtr != NULL); #endif // not UNICODE } else { *BufPtr = NULL; } return (Status); } // RxNetConfigGet