Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

170 lines
4.9 KiB

/*++
Copyright (c) 1991-92 Microsoft Corporation
Module Name:
SessCopy.c
Abstract:
This file contains RxpCopyAndConvertSessions().
Author:
John Rogers (JohnRo) 17-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:
17-Oct-1991 JohnRo
Created.
21-Nov-1991 JohnRo
Removed NT dependencies to reduce recompiles.
07-Feb-1992 JohnRo
Fixed the infamous NetSessionEnum bug (where 1-2 sessions OK, 3 or
more results in first few being trashed).
Call NetApiBufferAllocate() instead of private version.
--*/
// These must be included first:
#include <windef.h> // IN, DWORD, etc.
#include <lmcons.h> // NET_API_STATUS, etc.
#include <lmshare.h> // Required by rxsess.h.
#include <rap.h> // LPDESC. (Needed by strucinf.h.)
// These may be included in any order:
#include <lmapibuf.h> // NetApiBufferAllocate().
#include <lmerr.h> // ERROR_ and NERR_ equates.
#include <netdebug.h> // DBGSTATIC, NetpKdPrint(()), FORMAT_ equates.
#include <netlib.h> // NetpPointerPlusSomeBytes, etc.
#include <rxpdebug.h> // IF_DEBUG().
#include <rxsess.h> // My prototype.
#include <strucinf.h> // NetpSessionStructureInfo().
NET_API_STATUS
RxpCopyAndConvertSessions(
IN LPSESSION_SUPERSET_INFO InStructureArray,
IN DWORD InEntryCount,
IN DWORD LevelWanted,
IN LPTSTR ClientName OPTIONAL,
IN LPTSTR UserName OPTIONAL,
OUT LPVOID * OutStructureArrayPtr, // alloc'ed by this routine
OUT LPDWORD OutEntryCountPtr OPTIONAL
)
{
LPSESSION_SUPERSET_INFO InEntry = InStructureArray;
DWORD InEntriesLeft;
const DWORD InFixedSize = sizeof(SESSION_SUPERSET_INFO);
LPVOID OutEntry; // Buffer to be returned to caller.
DWORD OutEntryCount;
LPBYTE OutFixedDataEnd;
DWORD OutFixedSize;
DWORD OutMaxSize;
LPTSTR OutStringLocation;
DWORD OutStringSize;
LPVOID OutStructureArray;
BOOL AnyMatchFound = FALSE; // not yet.
NET_API_STATUS Status;
NetpAssert( InEntryCount > 0 );
NetpAssert( InStructureArray != NULL );
*OutStructureArrayPtr = NULL;
NetpSetOptionalArg(OutEntryCountPtr, 0);
//
// Learn about info level that caller wants.
//
Status = NetpSessionStructureInfo (
LevelWanted, // level to learn about
PARMNUM_ALL, // No parmnum with this.
TRUE, // Need native sizes.
NULL, // don't need data desc 16
NULL, // don't need data desc 32
NULL, // don't need data desc SMB
& OutMaxSize, // max buffer size (native)
& OutFixedSize, // fixed size.
& OutStringSize // string size.
);
if (Status != NERR_Success) {
return (Status);
}
//
// Allocate memory for 32-bit version of caller's info level.
//
Status = NetApiBufferAllocate(
InEntryCount * OutMaxSize,
& OutStructureArray);
if (Status != NERR_Success) {
return (Status);
}
OutEntry = OutStructureArray;
IF_DEBUG(SESSION) {
NetpKdPrint(( "RxpCopyAndConvertSessions: allocated output buffer at "
FORMAT_LPVOID "\n", (LPVOID) OutStructureArray ));
}
OutEntryCount = 0;
OutStringLocation = (LPTSTR) NetpPointerPlusSomeBytes(
OutStructureArray, InEntryCount * OutMaxSize);
for (InEntriesLeft=InEntryCount; InEntriesLeft > 0; --InEntriesLeft) {
OutFixedDataEnd = NetpPointerPlusSomeBytes(
OutEntry, OutFixedSize);
if (RxpSessionMatches(
(LPSESSION_SUPERSET_INFO) InEntry, // candidate structure
ClientName,
UserName)) {
// Match!
AnyMatchFound = TRUE;
++OutEntryCount;
RxpConvertSessionInfo (
InEntry,
LevelWanted,
OutEntry,
OutFixedDataEnd,
& OutStringLocation); // string area top (updated)
OutEntry = (LPVOID) NetpPointerPlusSomeBytes(OutEntry,OutFixedSize);
}
InEntry = (LPVOID) NetpPointerPlusSomeBytes(InEntry, InFixedSize);
}
if (AnyMatchFound == FALSE) {
(void) NetApiBufferFree( OutStructureArray );
OutStructureArray = NULL;
Status = RxpSessionMissingErrorCode( ClientName, UserName);
} else {
Status = NERR_Success;
}
//
// Tell caller how things went.
//
*OutStructureArrayPtr = OutStructureArray;
NetpSetOptionalArg(OutEntryCountPtr, OutEntryCount);
return (Status);
}