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

1436 lines
34 KiB
C

/*++
Copyright (c) 1993 Microsoft Corporation
Module Name:
ncpstub.c
Abstract:
Contains NCP Server APIs.
Author:
Yi-Hsin Sung (yihsins) 11-Sept-1993
Andy Herron (andyhe)
Revision History:
--*/
#include <nt.h>
#include <ntrtl.h>
#include <rpc.h>
#include <ncpsvc.h>
#include <nwstruct.h>
DWORD NwpMapRpcError(
IN DWORD RpcError
);
DWORD
FpnwApiBufferFree(
IN LPVOID pBuffer
)
/*++
Routine Description:
This API frees the memory allocated by all enumeration and getinfo APIs.
Arguments:
pBuffer - A pointer to an API information buffer previously returned
on an API call.
Return Value:
Error.
--*/
{
if ( pBuffer == NULL )
return NO_ERROR;
MIDL_user_free( pBuffer );
return NO_ERROR;
}
DWORD
NwApiBufferFree(
IN LPVOID pBuffer
)
{ return(FpnwApiBufferFree( pBuffer ));
}
DWORD
FpnwServerGetInfo(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT LPBYTE *ppServerInfo
)
/*++
Routine Description:
This API returns the information about the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the server structure requested, use
1 for now.
ppServerInfo - Place to store a pointer pointing to the returned
NWSERVERINFO structure.
Return Value:
Error.
--*/
{
DWORD err;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if ( ppServerInfo == NULL )
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrServerGetInfo( pServerName,
dwLevel,
(PFPNWSERVERINFO *) ppServerInfo );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwServerGetInfo(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT PNWSERVERINFO *ppServerInfo
)
{ return(FpnwServerGetInfo( pServerName,
dwLevel,
(LPBYTE *) ppServerInfo));
}
DWORD
FpnwServerSetInfo(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPBYTE pServerInfo
)
/*++
Routine Description:
This API sets the information about the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the server structure contained in
pServerInfo, use 1 for now.
pServerInfo - Points to a NWSERVERINFO structure which contains the server
properties to set to.
Return Value:
Error.
--*/
{
DWORD err;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if ( pServerInfo == NULL )
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrServerSetInfo( pServerName,
dwLevel,
(PNWSERVERINFO) pServerInfo );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwServerSetInfo(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN PNWSERVERINFO pServerInfo
)
{ return( FpnwServerSetInfo( pServerName,
dwLevel,
(LPBYTE) pServerInfo ));
}
DWORD
FpnwVolumeAdd(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPBYTE pVolumeInfo
)
/*++
Routine Description:
This API adds a volume to the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the volume structure contained in
pVolumeInfo, use 1 & 2 for now.
pVolumeInfo - Points to a NWVOLUMEINFO structure which contains the
information about the volume to be added, i.e. the volume name, path,
type, user limit and description. dwCurrentUses will be ignored.
Return Value:
Error.
--*/
{
DWORD err;
ULONG SDLength = 0;
ULONG oldSDLength;
PSECURITY_DESCRIPTOR fileSecurityDescriptor = NULL;
PSECURITY_DESCRIPTOR oldFileSecurityDescriptor = NULL;
PFPNWVOLUMEINFO_2 volInfo = (PFPNWVOLUMEINFO_2) pVolumeInfo;
if ( dwLevel != 1 && dwLevel != 2 )
return ERROR_INVALID_LEVEL;
if ( pVolumeInfo == NULL )
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
if ( dwLevel == 2 ) {
//
// Save this. We need to restore this later.
//
oldFileSecurityDescriptor = volInfo->FileSecurityDescriptor;
oldSDLength = volInfo->dwFileSecurityDescriptorLength;
if ( oldFileSecurityDescriptor != NULL ) {
if ( !RtlValidSecurityDescriptor( oldFileSecurityDescriptor ) ) {
return ERROR_INVALID_PARAMETER;
}
//
// Make a self relative security descriptor for use in the
// RPC call..
//
err = RtlMakeSelfRelativeSD(
oldFileSecurityDescriptor,
NULL,
&SDLength
);
if (err != STATUS_BUFFER_TOO_SMALL) {
return(ERROR_INVALID_PARAMETER);
} else {
fileSecurityDescriptor = MIDL_user_allocate( SDLength );
if ( fileSecurityDescriptor == NULL) {
return ERROR_NOT_ENOUGH_MEMORY;
} else {
//
// make an appropriate self-relative security descriptor
//
err = RtlMakeSelfRelativeSD(
oldFileSecurityDescriptor,
(PSECURITY_DESCRIPTOR) fileSecurityDescriptor,
&SDLength
);
if ( !NT_SUCCESS(err) ) {
MIDL_user_free( fileSecurityDescriptor );
return(ERROR_INVALID_PARAMETER);
}
volInfo->FileSecurityDescriptor = fileSecurityDescriptor;
volInfo->dwFileSecurityDescriptorLength = SDLength;
}
}
} else {
volInfo->dwFileSecurityDescriptorLength = 0;
}
}
err = NwrVolumeAdd( pServerName,
dwLevel,
(LPVOLUME_INFO) pVolumeInfo );
if ( fileSecurityDescriptor != NULL ) {
//
// restore old values
//
volInfo->dwFileSecurityDescriptorLength = oldSDLength;
volInfo->FileSecurityDescriptor = oldFileSecurityDescriptor;
MIDL_user_free( fileSecurityDescriptor );
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeAdd(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN PNWVOLUMEINFO pVolumeInfo
)
{ return( FpnwVolumeAdd( pServerName, dwLevel, (LPBYTE) pVolumeInfo ));
}
DWORD
FpnwVolumeDel(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName
)
/*++
Routine Description:
This API deletes a volume from the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pVolumeName - Specifies teh volume name that is to be deleted.
Return Value:
Error.
--*/
{
DWORD err;
if ( (pVolumeName == NULL) || (pVolumeName[0] == 0 ))
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrVolumeDel( pServerName,
pVolumeName );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeDel(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName
)
{ return( FpnwVolumeDel( pServerName, pVolumeName ));
}
DWORD
FpnwVolumeEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT LPBYTE *ppVolumeInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
/*++
Routine Description:
This enumerates all volumes on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the volume structure contained in
*ppVolumeInfo, use 1 for now.
ppVolumeInfo - On return, this will point to an array of NWVOLUMEINFO
structures, one for each volume on the server.
pEntriesRead - On return, this will specify the number of volumes returned
resumeHandle - On return, a resume handle is stored in the DWORD pointed
to by resumeHandle, and is used to continue an existing server search.
The handle should be zero on the first call and left unchanged for
subsequent calls. If the resumeHandle is NULL, then no resume
handle is stored.
Return Value:
Error.
--*/
{
DWORD err;
FPNWVOLUMEINFO_CONTAINER NwVolumeInfoContainer;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if ( ppVolumeInfo == NULL || pEntriesRead == NULL )
return ERROR_INVALID_PARAMETER;
NwVolumeInfoContainer.Buffer = NULL;
RpcTryExcept
{
err = NwrVolumeEnum( pServerName,
dwLevel,
&NwVolumeInfoContainer,
resumeHandle );
*ppVolumeInfo = (LPBYTE) NwVolumeInfoContainer.Buffer;
if ( NwVolumeInfoContainer.Buffer != NULL ) {
*pEntriesRead = NwVolumeInfoContainer.EntriesRead;
} else {
*pEntriesRead = 0;
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT PNWVOLUMEINFO *ppVolumeInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
{ return(FpnwVolumeEnum( pServerName,
dwLevel,
(LPBYTE *)ppVolumeInfo,
pEntriesRead,
resumeHandle ));
}
DWORD
FpnwVolumeGetInfo(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName,
IN DWORD dwLevel,
OUT LPBYTE *ppVolumeInfo
)
/*++
Routine Description:
This querys the information about the given volume on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pVolumeName - A pointer to a UNICODE string containing the name of the
volume we want to get information on.
dwLevel - Reserved for the level of the volume structure contained in
*ppVolumeInfo, use 1 for now.
ppVolumeInfo - On return, this will point to a NWVOLUMEINFO structure
which contains information on the given volume on the given server.
Return Value:
Error.
--*/
{
DWORD err;
if ( dwLevel != 1 && dwLevel != 2 ) {
return ERROR_INVALID_LEVEL;
}
if ((pVolumeName == NULL) ||
(pVolumeName[0] == 0 ) ||
(ppVolumeInfo == NULL) ) {
return ERROR_INVALID_PARAMETER;
}
*ppVolumeInfo = NULL ;
RpcTryExcept
{
err = NwrVolumeGetInfo( pServerName,
pVolumeName,
dwLevel,
(LPVOLUME_INFO *) ppVolumeInfo );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeGetInfo(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName,
IN DWORD dwLevel,
OUT PNWVOLUMEINFO *ppVolumeInfo
)
{ return(FpnwVolumeGetInfo( pServerName,
pVolumeName,
dwLevel,
(LPBYTE *)ppVolumeInfo ));
}
DWORD
FpnwVolumeSetInfo(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName,
IN DWORD dwLevel,
IN LPBYTE pVolumeInfo
)
/*++
Routine Description:
This sets the information about the given volume on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pVolumeName - A pointer to a UNICODE string containing the name of the
volume we want to set information on.
dwLevel - Reserved for the level of the volume structure contained in
pVolumeInfo, use 1 for now.
pVolumeInfo - Points to a NWVOLUMEINFO structure which contains
information on the given volume to set to. Only dwMaxUses can be
set. All the other fields in this structure will be ignored.
Return Value:
Error.
--*/
{
DWORD err;
ULONG SDLength = 0;
ULONG oldSDLength;
PFPNWVOLUMEINFO_2 volInfo = (PFPNWVOLUMEINFO_2) pVolumeInfo;
PSECURITY_DESCRIPTOR fileSecurityDescriptor = NULL;
PSECURITY_DESCRIPTOR oldFileSecurityDescriptor = NULL;
if ( dwLevel != 1 && dwLevel != 2 )
return ERROR_INVALID_LEVEL;
if ( ((pVolumeName == NULL) ||
( pVolumeName[0] == 0 )) ||
( pVolumeInfo == NULL )
) {
return ERROR_INVALID_PARAMETER;
}
RpcTryExcept
{
if ( dwLevel == 2 ) {
//
// Save this. We need to restore this later.
//
oldFileSecurityDescriptor = volInfo->FileSecurityDescriptor;
oldSDLength = volInfo->dwFileSecurityDescriptorLength;
if ( oldFileSecurityDescriptor != NULL ) {
if ( !RtlValidSecurityDescriptor( oldFileSecurityDescriptor ) ) {
return ERROR_INVALID_PARAMETER;
}
//
// Make a self relative security descriptor for use in the
// RPC call..
//
err = RtlMakeSelfRelativeSD(
oldFileSecurityDescriptor,
NULL,
&SDLength
);
if (err != STATUS_BUFFER_TOO_SMALL) {
return(ERROR_INVALID_PARAMETER);
} else {
fileSecurityDescriptor = MIDL_user_allocate( SDLength );
if ( fileSecurityDescriptor == NULL) {
return ERROR_NOT_ENOUGH_MEMORY;
} else {
//
// make an appropriate self-relative security descriptor
//
err = RtlMakeSelfRelativeSD(
oldFileSecurityDescriptor,
(PSECURITY_DESCRIPTOR) fileSecurityDescriptor,
&SDLength
);
if ( !NT_SUCCESS(err) ) {
MIDL_user_free( fileSecurityDescriptor );
return(ERROR_INVALID_PARAMETER);
}
volInfo->FileSecurityDescriptor = fileSecurityDescriptor;
volInfo->dwFileSecurityDescriptorLength = SDLength;
}
}
} else {
volInfo->dwFileSecurityDescriptorLength = 0;
}
}
err = NwrVolumeSetInfo( pServerName,
pVolumeName,
dwLevel,
(LPVOLUME_INFO) pVolumeInfo );
if ( fileSecurityDescriptor != NULL ) {
//
// restore old values
//
volInfo->dwFileSecurityDescriptorLength = oldSDLength;
volInfo->FileSecurityDescriptor = oldFileSecurityDescriptor;
MIDL_user_free( fileSecurityDescriptor );
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeSetInfo(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pVolumeName,
IN DWORD dwLevel,
IN PNWVOLUMEINFO pVolumeInfo
)
{ return( FpnwVolumeSetInfo( pServerName,
pVolumeName,
dwLevel,
(LPBYTE) pVolumeInfo ));
}
DWORD
FpnwConnectionEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT LPBYTE *ppConnectionInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
/*++
Routine Description:
This enumerates all connections on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the volume structure contained in
*ppConnectionInfo, use 1 for now.
ppConnectionInfo - On return, this will point to an array of
NWCONNECTIONINFO structures, one for each volume on the server.
pEntriesRead - On return, this will specify the number of current
connecitons.
resumeHandle - On return, a resume handle is stored in the DWORD pointed
to by resumeHandle, and is used to continue an existing server search.
The handle should be zero on the first call and left unchanged for
subsequent calls. If the resumeHandle is NULL, then no resume
handle is stored.
Return Value:
Error.
--*/
{
DWORD err;
FPNWCONNECTIONINFO_CONTAINER NwConnectionInfoContainer;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if (( ppConnectionInfo == NULL ) || ( pEntriesRead == NULL ))
return ERROR_INVALID_PARAMETER;
NwConnectionInfoContainer.Buffer = NULL;
RpcTryExcept
{
err = NwrConnectionEnum( pServerName,
dwLevel,
&NwConnectionInfoContainer,
resumeHandle );
*ppConnectionInfo = (LPBYTE) NwConnectionInfoContainer.Buffer;
if ( NwConnectionInfoContainer.Buffer != NULL ) {
*pEntriesRead = NwConnectionInfoContainer.EntriesRead;
} else {
*pEntriesRead = 0;
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwConnectionEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
OUT PNWCONNECTIONINFO *ppConnectionInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
{ return(FpnwConnectionEnum( pServerName,
dwLevel,
(LPBYTE *) ppConnectionInfo,
pEntriesRead,
resumeHandle ));
}
DWORD
FpnwConnectionDel(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwConnectionId
)
/*++
Routine Description:
This delete the connection with the given connection id on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwConnectionId - The identification number of the connection to tear down.
Return Value:
Error.
--*/
{
DWORD err;
RpcTryExcept
{
err = NwrConnectionDel( pServerName,
dwConnectionId );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwConnectionDel(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwConnectionId
)
{ return( FpnwConnectionDel( pServerName, dwConnectionId ));
}
DWORD
FpnwVolumeConnEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPWSTR pVolumeName OPTIONAL,
IN DWORD dwConnectionId,
OUT LPBYTE *ppVolumeConnInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
/*++
Routine Description:
This enumerates all connections to a volume or list all volumes used by
a particular connection on the given server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the volume structure contained in
*ppVolumeConnInfo, use 1 for now.
pVolumeName - Specifies the volume name which we want to get all opened
resources. This must be NULL if dwConnectionId is not 0.
dwConnectionId - Specifies the connection id on which we want to get all
opened resources. This must be 0 if pVolumeName is not NULL.
ppVolumeConnInfo - On return, this will point to an array of
NWVOLUMECONNINFO structures.
pEntriesRead - On return, this will specify the number of NWVOLUMECONNINFO
returned.
resumeHandle - On return, a resume handle is stored in the DWORD pointed
to by resumeHandle, and is used to continue an existing server search.
The handle should be zero on the first call and left unchanged for
subsequent calls. If the resumeHandle is NULL, then no resume
handle is stored.
Return Value:
Error.
--*/
{
DWORD err;
FPNWVOLUMECONNINFO_CONTAINER NwVolumeConnInfoContainer;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if ( ( dwConnectionId == 0 )
&& (( pVolumeName == NULL ) || ( *pVolumeName == 0 ))
)
{
return ERROR_INVALID_PARAMETER;
}
if ( ( dwConnectionId != 0 )
&& (( pVolumeName != NULL) && ( *pVolumeName != 0 ))
)
{
return ERROR_INVALID_PARAMETER;
}
if (( ppVolumeConnInfo == NULL ) || ( pEntriesRead == NULL ))
return ERROR_INVALID_PARAMETER;
NwVolumeConnInfoContainer.Buffer = NULL;
RpcTryExcept
{
err = NwrVolumeConnEnum( pServerName,
dwLevel,
pVolumeName,
dwConnectionId,
&NwVolumeConnInfoContainer,
resumeHandle );
*ppVolumeConnInfo = (LPBYTE) NwVolumeConnInfoContainer.Buffer;
if ( NwVolumeConnInfoContainer.Buffer != NULL ) {
*pEntriesRead = NwVolumeConnInfoContainer.EntriesRead;
} else {
*pEntriesRead = 0;
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwVolumeConnEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPWSTR pVolumeName OPTIONAL,
IN DWORD dwConnectionId,
OUT PNWVOLUMECONNINFO *ppVolumeConnInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
{ return( FpnwVolumeConnEnum( pServerName,
dwLevel,
pVolumeName,
dwConnectionId,
(LPBYTE *) ppVolumeConnInfo,
pEntriesRead,
resumeHandle ));
}
DWORD
FpnwFileEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPWSTR pPathName OPTIONAL,
OUT LPBYTE *ppFileInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
/*++
Routine Description:
This enumerates files opened on the server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwLevel - Reserved for the level of the volume structure contained in
*ppFileInfo, use 1 for now.
pPathName - If this is not NULL, this means that we want to filter
on the path. We only want entries with this path, i.e., all users that
currently opened the file. If this is NULL, then all files that are
opened are returned along with the user information.
ppFileInfo - On return, this will point to an array of NWFILEINFO structures
pEntriesRead - On return, this will specify the number of NWFILEINFO
returned.
resumeHandle - On return, a resume handle is stored in the DWORD pointed
to by resumeHandle, and is used to continue an existing server search.
The handle should be zero on the first call and left unchanged for
subsequent calls. If the resumeHandle is NULL, then no resume
handle is stored.
Return Value:
Error.
--*/
{
DWORD err;
FPNWFILEINFO_CONTAINER NwFileInfoContainer;
if ( dwLevel != 1 )
return ERROR_INVALID_LEVEL;
if (( ppFileInfo == NULL ) || ( pEntriesRead == NULL ))
return ERROR_INVALID_PARAMETER;
NwFileInfoContainer.Buffer = NULL;
RpcTryExcept
{
err = NwrFileEnum( pServerName,
dwLevel,
pPathName,
&NwFileInfoContainer,
resumeHandle );
*ppFileInfo = (LPBYTE) NwFileInfoContainer.Buffer;
if ( NwFileInfoContainer.Buffer != NULL ) {
*pEntriesRead = NwFileInfoContainer.EntriesRead;
} else {
*pEntriesRead = 0;
}
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwFileEnum(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwLevel,
IN LPWSTR pPathName OPTIONAL,
OUT PNWFILEINFO *ppFileInfo,
OUT PDWORD pEntriesRead,
IN OUT PDWORD resumeHandle OPTIONAL
)
{ return(FpnwFileEnum( pServerName,
dwLevel,
pPathName,
(LPBYTE *) ppFileInfo,
pEntriesRead,
resumeHandle ));
}
DWORD
FpnwFileClose(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwFileId
)
/*++
Routine Description:
This closes the file with the given identification number.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwFileId - The identification number of the file to close.
Return Value:
Error.
--*/
{
DWORD err;
RpcTryExcept
{
err = NwrFileClose( pServerName,
dwFileId );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwFileClose(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwFileId
)
{ return(FpnwFileClose( pServerName, dwFileId ));
}
DWORD
FpnwMessageBufferSend(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwConnectionId,
IN DWORD fConsoleBroadcast,
IN LPBYTE pbBuffer,
IN DWORD cbBuffer
)
/*++
Routine Description:
This sends the message to the given connection id.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
dwConnectionId - The id of the connection to send message to.
fConsoleBroadcast - If this is TRUE, that means use console broadcast. If
FALSE, use user broadcast.
pbBuffer - Points to the message buffer to be sent.
cbBuffer - The size of the pbBuffer in bytes.
Return Value:
Error.
--*/
{
DWORD err;
if (( pbBuffer == NULL ) || ( cbBuffer == 0 ))
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrMessageBufferSend( pServerName,
dwConnectionId,
fConsoleBroadcast,
pbBuffer,
cbBuffer );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwMessageBufferSend(
IN LPWSTR pServerName OPTIONAL,
IN DWORD dwConnectionId,
IN DWORD fConsoleBroadcast,
IN LPBYTE pbBuffer,
IN DWORD cbBuffer
)
{ return( FpnwMessageBufferSend( pServerName,
dwConnectionId,
fConsoleBroadcast,
pbBuffer,
cbBuffer ));
}
DWORD
FpnwSetDefaultQueue(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pQueueName
)
/*++
Routine Description:
This sets the default queue on the server.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pQueueName - The name of the queue that will become the default
Return Value:
Error.
--*/
{
DWORD err;
if (( pQueueName == NULL ) || ( *pQueueName == 0 ))
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrSetDefaultQueue( pServerName,
pQueueName );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwSetDefaultQueue(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pQueueName
)
{ return(FpnwSetDefaultQueue( pServerName, pQueueName ));
}
DWORD
FpnwAddPServer(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pPServerName
)
/*++
Routine Description:
This adds a pserver.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pPServerName - The name of the PServer.
Return Value:
Error.
--*/
{
DWORD err;
if (( pPServerName == NULL ) || ( *pPServerName == 0 ))
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrAddPServer( pServerName,
pPServerName );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwAddPServer(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pPServerName
)
{ return( FpnwAddPServer( pServerName, pPServerName ));
}
DWORD
FpnwRemovePServer(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pPServerName
)
/*++
Routine Description:
This removes a pserver.
Arguments:
pServerName - A pointer to a UNICODE string containing the name of the
remote server on which the function is to execute. A NULL pointer
or string specifies the local machine.
pPServerName - The name of the PServer.
Return Value:
Error.
--*/
{
DWORD err;
if (( pPServerName == NULL ) || ( *pPServerName == 0 ))
return ERROR_INVALID_PARAMETER;
RpcTryExcept
{
err = NwrRemovePServer( pServerName,
pPServerName );
}
RpcExcept(1)
{
err = NwpMapRpcError( RpcExceptionCode() );
}
RpcEndExcept
return err;
}
DWORD
NwRemovePServer(
IN LPWSTR pServerName OPTIONAL,
IN LPWSTR pPServerName
)
{ return( FpnwRemovePServer( pServerName, pPServerName ));
}
DWORD NwpMapRpcError(
IN DWORD RpcError
)
/*++
Routine Description:
This routine maps the RPC error into a more meaningful windows
error for the caller.
Arguments:
RpcError - Supplies the exception error raised by RPC
Return Value:
Returns the mapped error.
--*/
{
switch (RpcError)
{
case RPC_S_INVALID_BINDING:
case RPC_X_SS_IN_NULL_CONTEXT:
case RPC_X_SS_CONTEXT_DAMAGED:
case RPC_X_SS_HANDLES_MISMATCH:
case ERROR_INVALID_HANDLE:
return ERROR_INVALID_HANDLE;
case RPC_X_NULL_REF_POINTER:
return ERROR_INVALID_PARAMETER;
case STATUS_ACCESS_VIOLATION:
return ERROR_INVALID_ADDRESS;
default:
return RpcError;
}
}
// ncpstub.c eof.