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

174 lines
5.2 KiB
Plaintext

// Replace:
// {capgroup} is the name of group in caps as it appears in typedefs.
// {date} with today's date in dd-Mmm-yyyy form.
// {email} with your email ID.
// {filename} with name of this file (including .c at end)
// {fullname} with your full name
// {header} is the header file name part (e.g. "wksta" in lmwksta.h)
// {icgroup} is name of group with initial caps, e.g. "Server".
// Take care of all {expand} replacements.
// Delete these instructions.
/*++
Copyright (c) 1991-1992 Microsoft Corporation
Module Name:
{filename}
Abstract:
This file contains the RpcXlate code to handle the Net{icgroup}GetInfo API.
Author:
{fullname} ({email}) {date}
Environment:
Portable to any flat, 32-bit environment. (Uses Win32 typedefs.)
Requires ANSI C extensions: slash-slash comments, long external names.
Revision History:
{date} {email}
Created.
--*/
// 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> // NetapipBufferAllocate().
#include <lmerr.h> // ERROR_ and NERR_ equates.
#include <netdebug.h> // NetpDbgPrint(), FORMAT_ equates, etc.
#include <rap.h> // LPDESC.
#include <remdef.h> // REM16_, REM32_, REMSmb_ equates.
#include <rx.h> // RxRemoteApi().
#include <rxpdebug.h> // IF_DEBUG().
#include <rx{header}.h> // My prototype.
#include <strucinf.h> // Netp{icgroup}StructureInfo().
NET_API_STATUS
RxNet{icgroup}GetInfo (
IN LPTSTR UncServerName,
{expand}
IN DWORD Level,
OUT LPBYTE *BufPtr
)
/*++
Routine Description:
RxNet{icgroup}GetInfo performs the same function as Net{icgroup}GetInfo,
except that the server name is known to refer to a downlevel server.
Arguments:
(Same as Net{icgroup}GetInfo, except UncServerName must not be null, and
must not refer to the local computer.)
Return Value:
(Same as Net{icgroup}GetInfo.)
--*/
{
LPBYTE ApiBuffer32; // Buffer to be returned to caller.
DWORD ApiBufferSize32;
LPDESC DataDesc16, DataDesc32, DataDescSmb;
NET_API_STATUS Status;
DWORD TotalAvail;
IF_DEBUG({capgroup}) {
NetpDbgPrint("RxNet{icgroup}GetInfo: starting, server=" FORMAT_LPTSTR
", lvl=" FORMAT_DWORD ".\n", UncServerName, Level);
}
//
// 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.
//
// Learn about info level.
//
Status = Netp{icgroup}StructureInfo (
Level, // level to learn about
PARMNUM_ALL, // No parmnum with this.
TRUE, // Need native sizes.
& DataDesc16,
& DataDesc32,
& DataDescSmb,
& ApiBufferSize32, // max buffer size (native)
NULL, // don't need fixed size.
NULL // don't need string size.
);
if (Status != NERR_Success) {
return (Status);
}
//
// Allocate memory for 32-bit version of info, which we'll use to get
// data from the remote computer.
//
Status = NetapipBufferAllocate(
ApiBufferSize32,
(LPVOID *) & ApiBuffer32);
if (Status != NERR_Success) {
return (Status);
}
IF_DEBUG({capgroup}) {
NetpDbgPrint( "RxNet{icgroup}GetInfo: allocated buffer at "
FORMAT_LPVOID "\n", (LPVOID) ApiBuffer32 );
}
//
// Actually remote the API, which will get back the
// data in native format.
//
Status = RxRemoteApi(
API_W{icgroup}GetInfo, // API number
UncServerName, // Required, with \\name.
REMSmb_Net{icgroup}GetInfo_P, // parm desc
DataDesc16,
DataDesc32,
DataDescSmb,
NULL, // no aux data desc 16
NULL, // no aux data desc 32
NULL, // no aux data desc SMB
0, // Flags: normal
// rest of API's arguments, in 32-bit LM 2.x format:
{expand},
Level,
ApiBuffer32,
ApiBufferSize32,
& TotalAvail); // total size (BUGBUG meaningless?)
NetpAssert( Status != ERROR_MORE_DATA );
NetpAssert( Status != NERR_BufTooSmall );
if (Status == NERR_Success) {
*BufPtr = ApiBuffer32;
} else {
(void) NetApiBufferFree( ApiBuffer32 );
}
return (Status);
} // RxNet{icgroup}GetInfo