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.
372 lines
7.2 KiB
372 lines
7.2 KiB
/*++
|
|
|
|
Copyright (c) 1991 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
rpcbind.c
|
|
|
|
Abstract:
|
|
|
|
LSA - Client RPC Binding Routines
|
|
|
|
Author:
|
|
|
|
Scott Birrell (ScottBi) April 30, 1991
|
|
|
|
Environment:
|
|
|
|
Revision History:
|
|
|
|
--*/
|
|
|
|
#include "lsaclip.h"
|
|
|
|
#include <ntrpcp.h> // prototypes for MIDL user functions
|
|
|
|
#include "adtgen.h"
|
|
|
|
handle_t
|
|
PLSAPR_SERVER_NAME_bind (
|
|
IN OPTIONAL PLSAPR_SERVER_NAME ServerName
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to bind to the LSA on some server.
|
|
|
|
Arguments:
|
|
|
|
ServerName - A pointer to a string containing the name of the server
|
|
to bind with.
|
|
|
|
Return Value:
|
|
|
|
The binding handle is returned to the stub routine. If the
|
|
binding is unsuccessful, a NULL will be returned.
|
|
|
|
--*/
|
|
|
|
{
|
|
handle_t BindingHandle;
|
|
NTSTATUS Status;
|
|
|
|
Status = RpcpBindRpc (
|
|
ServerName,
|
|
L"lsarpc",
|
|
0,
|
|
&BindingHandle
|
|
);
|
|
|
|
if (!NT_SUCCESS(Status)) {
|
|
|
|
// DbgPrint("PLSAPR_SERVER_NAME_bind: RpcpBindRpc failed 0x%lx\n", Status);
|
|
|
|
}
|
|
|
|
return( BindingHandle);
|
|
}
|
|
|
|
|
|
VOID
|
|
PLSAPR_SERVER_NAME_unbind (
|
|
IN OPTIONAL PLSAPR_SERVER_NAME ServerName,
|
|
IN handle_t BindingHandle
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to unbind from the LSA server.
|
|
|
|
|
|
Arguments:
|
|
|
|
ServerName - This is the name of the server from which to unbind.
|
|
|
|
BindingHandle - This is the binding handle that is to be closed.
|
|
|
|
Return Value:
|
|
|
|
none.
|
|
|
|
--*/
|
|
{
|
|
RpcpUnbindRpc ( BindingHandle );
|
|
return;
|
|
|
|
UNREFERENCED_PARAMETER( ServerName ); // This parameter is not used
|
|
}
|
|
|
|
|
|
|
|
DWORD
|
|
LsaNtStatusToWinError(
|
|
IN NTSTATUS Status
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine converts and NTSTATUS to an win32 error code. It is used
|
|
by people who want to call the LSA APIs but are writing for a win32
|
|
environment.
|
|
|
|
Arguments:
|
|
|
|
Status - The status code to be mapped
|
|
|
|
Return Value:
|
|
|
|
The return from RtlNtStatusToDosError. If the error could not be
|
|
mapped, then ERROR_MR_MID_NOT_FOUND is returned.
|
|
|
|
--*/
|
|
|
|
{
|
|
return(RtlNtStatusToDosError(Status));
|
|
}
|
|
|
|
|
|
|
|
NTSTATUS
|
|
LsapApiReturnResult(
|
|
ULONG ExceptionCode
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This function converts an exception code or status value returned
|
|
from the client stub to a value suitable for return by the API to
|
|
the client.
|
|
|
|
Arguments:
|
|
|
|
ExceptionCode - The exception code to be converted.
|
|
|
|
Return Value:
|
|
|
|
NTSTATUS - The converted Nt Status code.
|
|
|
|
--*/
|
|
|
|
{
|
|
//
|
|
// Return the actual value if compatible with Nt status codes,
|
|
// otherwise, return STATUS_UNSUCCESSFUL.
|
|
//
|
|
|
|
if (!NT_SUCCESS((NTSTATUS) ExceptionCode)) {
|
|
|
|
return (NTSTATUS) ExceptionCode;
|
|
|
|
} else {
|
|
|
|
return STATUS_UNSUCCESSFUL;
|
|
}
|
|
}
|
|
|
|
handle_t
|
|
PAUTHZ_AUDIT_EVENT_TYPE_OLD_bind (
|
|
IN PAUTHZ_AUDIT_EVENT_TYPE_OLD pAuditEventType
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to bind to local LSA.
|
|
|
|
Arguments:
|
|
|
|
AuditInfo -- ignored
|
|
|
|
Return Value:
|
|
|
|
The binding handle is returned to the stub routine.
|
|
If the binding is unsuccessful, a NULL will be returned.
|
|
|
|
--*/
|
|
|
|
{
|
|
handle_t hBinding=NULL;
|
|
NTSTATUS Status;
|
|
PWSTR pszBinding;
|
|
RPC_STATUS RpcStatus;
|
|
|
|
//
|
|
// the first param takes a server-name. use NULL
|
|
// to force a local binding
|
|
//
|
|
|
|
RpcStatus = RpcStringBindingComposeW(
|
|
NULL, // uuid of lsarpc
|
|
L"ncalrpc", // we want to use LRPC
|
|
NULL, // network address (local machine)
|
|
L"audit", // endpoint name
|
|
L"", // options
|
|
&pszBinding );
|
|
|
|
if ( RpcStatus == RPC_S_OK )
|
|
{
|
|
RpcStatus = RpcBindingFromStringBindingW(
|
|
pszBinding,
|
|
&hBinding
|
|
);
|
|
|
|
RpcStringFreeW( &pszBinding );
|
|
}
|
|
|
|
Status = I_RpcMapWin32Status( RpcStatus );
|
|
|
|
if (!NT_SUCCESS(Status)) {
|
|
|
|
DbgPrint("PAUDIT_AUTHZ_AUDIT_EVENT_OLD_bind: failed 0x%lx\n", Status);
|
|
|
|
}
|
|
|
|
UNREFERENCED_PARAMETER( pAuditEventType );
|
|
|
|
return( hBinding );
|
|
}
|
|
|
|
|
|
VOID
|
|
PAUTHZ_AUDIT_EVENT_TYPE_OLD_unbind (
|
|
IN PAUTHZ_AUDIT_EVENT_TYPE_OLD pAuditEventType, OPTIONAL
|
|
IN handle_t BindingHandle
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to unbind from the LSA server.
|
|
|
|
|
|
Arguments:
|
|
|
|
AuditInfo - ignored
|
|
|
|
BindingHandle - This is the binding handle that is to be closed.
|
|
|
|
Return Value:
|
|
|
|
none.
|
|
|
|
--*/
|
|
{
|
|
RpcpUnbindRpc ( BindingHandle );
|
|
|
|
UNREFERENCED_PARAMETER( pAuditEventType ); // This parameter is not used
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
handle_t
|
|
PSECURITY_SOURCE_NAME_bind (
|
|
IN PSECURITY_SOURCE_NAME pSecuritySource
|
|
)
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to bind to local LSA.
|
|
|
|
Arguments:
|
|
|
|
pSecuritySource -- ignored
|
|
|
|
Return Value:
|
|
|
|
The binding handle is returned to the stub routine.
|
|
If the binding is unsuccessful, a NULL will be returned.
|
|
|
|
--*/
|
|
|
|
{
|
|
handle_t hBinding=NULL;
|
|
NTSTATUS Status;
|
|
PWSTR pszBinding;
|
|
RPC_STATUS RpcStatus;
|
|
|
|
//
|
|
// the first param takes a server-name. use NULL
|
|
// to force a local binding
|
|
//
|
|
|
|
RpcStatus = RpcStringBindingComposeW(
|
|
NULL, // uuid of lsarpc
|
|
L"ncalrpc", // we want to use LRPC
|
|
NULL, // network address (local machine)
|
|
L"securityevent", // endpoint name
|
|
L"", // options
|
|
&pszBinding );
|
|
|
|
if ( RpcStatus == RPC_S_OK )
|
|
{
|
|
RpcStatus = RpcBindingFromStringBindingW(
|
|
pszBinding,
|
|
&hBinding
|
|
);
|
|
|
|
RpcStringFreeW( &pszBinding );
|
|
}
|
|
|
|
Status = I_RpcMapWin32Status( RpcStatus );
|
|
|
|
if (!NT_SUCCESS(Status)) {
|
|
|
|
DbgPrint("PSECURITY_SOURCE_NAME_bind: failed 0x%lx\n", Status);
|
|
|
|
}
|
|
|
|
UNREFERENCED_PARAMETER( pSecuritySource );
|
|
|
|
return( hBinding );
|
|
}
|
|
|
|
|
|
VOID
|
|
PSECURITY_SOURCE_NAME_unbind (
|
|
IN PSECURITY_SOURCE_NAME pSecuritySource OPTIONAL,
|
|
IN handle_t BindingHandle
|
|
)
|
|
|
|
/*++
|
|
|
|
Routine Description:
|
|
|
|
This routine is called from the LSA client stubs when
|
|
it is necessary to unbind from the LSA server.
|
|
|
|
|
|
Arguments:
|
|
|
|
pSecuritySource - ignored
|
|
|
|
BindingHandle - This is the binding handle that is to be closed.
|
|
|
|
Return Value:
|
|
|
|
none.
|
|
|
|
--*/
|
|
{
|
|
RpcpUnbindRpc ( BindingHandle );
|
|
|
|
UNREFERENCED_PARAMETER( pSecuritySource ); // This parameter is not used
|
|
|
|
return;
|
|
|
|
}
|