176 lines
4.9 KiB
C
176 lines
4.9 KiB
C
|
/*++
|
||
|
|
||
|
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 <windef.h> // IN, DWORD, etc.
|
||
|
#include <lmcons.h> // LM20_ equates, NET_API_STATUS, etc.
|
||
|
|
||
|
// These may be included in any order:
|
||
|
|
||
|
#include <apinums.h> // API_ equates.
|
||
|
#include <lmapibuf.h> // NetApiBufferAllocate(), NetApiBufferFree().
|
||
|
#include <lmerr.h> // ERROR_ and NERR_ equates.
|
||
|
#include <netdebug.h> // NetpKdPrint(()), FORMAT_ equates, etc.
|
||
|
#include <prefix.h> // PREFIX_ equates.
|
||
|
#include <rap.h> // LPDESC.
|
||
|
#include <remdef.h> // REM16_, REM32_, REMSmb_ equates.
|
||
|
#include <rx.h> // RxRemoteApi().
|
||
|
#include <rxpdebug.h> // IF_DEBUG().
|
||
|
#include <rxconfig.h> // My prototype.
|
||
|
#include <tstring.h> // 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
|