2007-09-19 12:45:35 +00:00
/*
2002-01-30 06:08:46 +00:00
Unix SMB / CIFS implementation .
2000-12-13 12:52:21 +00:00
RPC pipe client
2001-05-07 01:55:08 +00:00
Copyright ( C ) Tim Potter 2000 - 2001 ,
2000-12-13 12:52:21 +00:00
Copyright ( C ) Andrew Tridgell 1992 - 1997 , 2000 ,
2002-05-17 13:49:01 +00:00
Copyright ( C ) Rafal Szczesniak 2002
2005-09-30 17:13:37 +00:00
Copyright ( C ) Jeremy Allison 2005.
2007-09-20 09:15:26 +00:00
Copyright ( C ) Michael Adam 2007.
2008-02-27 19:38:48 +01:00
Copyright ( C ) Guenther Deschner 2008.
2007-09-19 12:45:35 +00:00
2000-12-13 12:52:21 +00:00
This program is free software ; you can redistribute it and / or modify
it under the terms of the GNU General Public License as published by
2007-07-09 19:25:36 +00:00
the Free Software Foundation ; either version 3 of the License , or
2000-12-13 12:52:21 +00:00
( at your option ) any later version .
2007-09-19 12:45:35 +00:00
2000-12-13 12:52:21 +00:00
This program is distributed in the hope that it will be useful ,
but WITHOUT ANY WARRANTY ; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
GNU General Public License for more details .
2007-09-19 12:45:35 +00:00
2000-12-13 12:52:21 +00:00
You should have received a copy of the GNU General Public License
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2000-12-13 12:52:21 +00:00
*/
# include "includes.h"
2009-11-26 18:21:28 +01:00
# include "../librpc/gen_ndr/cli_lsa.h"
2010-05-18 18:26:16 +02:00
# include "rpc_client/cli_lsarpc.h"
2000-12-13 12:52:21 +00:00
2002-01-06 03:48:41 +00:00
/** @defgroup lsa LSA - Local Security Architecture
2001-11-23 05:50:05 +00:00
* @ ingroup rpc_client
2001-11-15 06:03:22 +00:00
*
* @ {
* */
/**
* @ file cli_lsarpc . c
*
* RPC client routines for the LSA RPC pipe . LSA means " local
* security authority " , which is half of a password database.
* */
2001-11-23 05:50:05 +00:00
/** Open a LSA policy handle
*
* @ param cli Handle on an initialised SMB connection */
2000-12-13 12:52:21 +00:00
2005-06-08 22:10:34 +00:00
NTSTATUS rpccli_lsa_open_policy ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
2007-10-18 17:40:25 -07:00
bool sec_qos , uint32 des_access ,
2009-03-18 22:49:41 +01:00
struct policy_handle * pol )
2000-12-13 12:52:21 +00:00
{
2008-02-11 17:50:18 +01:00
struct lsa_ObjectAttribute attr ;
struct lsa_QosInfo qos ;
uint16_t system_name = ' \\ ' ;
2000-12-13 12:52:21 +00:00
2008-12-08 18:03:01 +01:00
ZERO_STRUCT ( attr ) ;
attr . len = 0x18 ;
2000-12-13 12:52:21 +00:00
if ( sec_qos ) {
2008-12-08 18:03:01 +01:00
qos . len = 0xc ;
qos . impersonation_level = 2 ;
qos . context_mode = 1 ;
qos . effective_only = 0 ;
attr . sec_qos = & qos ;
2000-12-13 12:52:21 +00:00
}
2008-02-11 17:50:18 +01:00
return rpccli_lsa_OpenPolicy ( cli , mem_ctx ,
& system_name ,
& attr ,
des_access ,
pol ) ;
2000-12-13 12:52:21 +00:00
}
2002-02-20 22:34:35 +00:00
/** Open a LSA policy handle
*
2007-09-19 12:45:35 +00:00
* @ param cli Handle on an initialised SMB connection
2002-02-20 22:34:35 +00:00
*/
2001-08-21 03:05:27 +00:00
2005-06-08 22:10:34 +00:00
NTSTATUS rpccli_lsa_open_policy2 ( struct rpc_pipe_client * cli ,
2007-10-18 17:40:25 -07:00
TALLOC_CTX * mem_ctx , bool sec_qos ,
2009-03-18 22:49:41 +01:00
uint32 des_access , struct policy_handle * pol )
2001-08-21 03:05:27 +00:00
{
2008-02-11 17:50:18 +01:00
struct lsa_ObjectAttribute attr ;
struct lsa_QosInfo qos ;
2001-08-21 03:05:27 +00:00
2008-12-08 18:03:01 +01:00
ZERO_STRUCT ( attr ) ;
attr . len = 0x18 ;
2001-08-21 03:05:27 +00:00
if ( sec_qos ) {
2008-12-08 18:03:01 +01:00
qos . len = 0xc ;
qos . impersonation_level = 2 ;
qos . context_mode = 1 ;
qos . effective_only = 0 ;
attr . sec_qos = & qos ;
2001-08-21 03:05:27 +00:00
}
2008-02-11 17:50:18 +01:00
return rpccli_lsa_OpenPolicy2 ( cli , mem_ctx ,
2008-04-19 23:03:16 +02:00
cli - > srv_name_slash ,
2008-02-11 17:50:18 +01:00
& attr ,
des_access ,
pol ) ;
2001-08-21 03:05:27 +00:00
}
2007-05-22 11:30:35 +00:00
/* Lookup a list of sids
*
2007-05-22 13:40:01 +00:00
* internal version withOUT memory allocation of the target arrays .
* this assumes suffciently sized arrays to store domains , names and types . */
2007-05-22 11:30:35 +00:00
static NTSTATUS rpccli_lsa_lookup_sids_noalloc ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
2009-03-18 22:49:41 +01:00
struct policy_handle * pol ,
2007-05-22 11:30:35 +00:00
int num_sids ,
2010-05-21 11:25:01 +10:00
const struct dom_sid * sids ,
2007-05-22 11:30:35 +00:00
char * * domains ,
char * * names ,
2009-09-13 00:28:49 +02:00
enum lsa_SidType * types ,
bool use_lookupsids3 )
2007-05-22 11:30:35 +00:00
{
NTSTATUS result = NT_STATUS_OK ;
2007-05-22 13:40:01 +00:00
TALLOC_CTX * tmp_ctx = NULL ;
2007-05-22 11:30:35 +00:00
int i ;
2008-02-18 10:03:19 +01:00
struct lsa_SidArray sid_array ;
struct lsa_RefDomainList * ref_domains = NULL ;
struct lsa_TransNameArray lsa_names ;
uint32_t count = 0 ;
uint16_t level = 1 ;
ZERO_STRUCT ( lsa_names ) ;
2007-05-22 11:30:35 +00:00
2007-05-22 13:40:01 +00:00
tmp_ctx = talloc_new ( mem_ctx ) ;
if ( ! tmp_ctx ) {
DEBUG ( 0 , ( " rpccli_lsa_lookup_sids_noalloc: out of memory! \n " ) ) ;
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
2008-02-18 10:03:19 +01:00
sid_array . num_sids = num_sids ;
sid_array . sids = TALLOC_ARRAY ( mem_ctx , struct lsa_SidPtr , num_sids ) ;
if ( ! sid_array . sids ) {
return NT_STATUS_NO_MEMORY ;
}
2007-05-22 11:30:35 +00:00
2008-02-18 10:03:19 +01:00
for ( i = 0 ; i < num_sids ; i + + ) {
sid_array . sids [ i ] . sid = sid_dup_talloc ( mem_ctx , & sids [ i ] ) ;
if ( ! sid_array . sids [ i ] . sid ) {
return NT_STATUS_NO_MEMORY ;
}
}
2007-05-22 11:30:35 +00:00
2009-09-13 00:28:49 +02:00
if ( use_lookupsids3 ) {
struct lsa_TransNameArray2 lsa_names2 ;
uint32_t n ;
2009-09-17 09:42:49 +02:00
ZERO_STRUCT ( lsa_names2 ) ;
2009-09-13 00:28:49 +02:00
result = rpccli_lsa_LookupSids3 ( cli , mem_ctx ,
& sid_array ,
& ref_domains ,
& lsa_names2 ,
level ,
& count ,
0 ,
0 ) ;
if ( ! NT_STATUS_IS_ERR ( result ) ) {
lsa_names . count = lsa_names2 . count ;
lsa_names . names = talloc_array ( mem_ctx , struct lsa_TranslatedName , lsa_names . count ) ;
if ( ! lsa_names . names ) {
return NT_STATUS_NO_MEMORY ;
}
for ( n = 0 ; n < lsa_names . count ; n + + ) {
lsa_names . names [ n ] . sid_type = lsa_names2 . names [ n ] . sid_type ;
lsa_names . names [ n ] . name = lsa_names2 . names [ n ] . name ;
lsa_names . names [ n ] . sid_index = lsa_names2 . names [ n ] . sid_index ;
}
}
} else {
result = rpccli_lsa_LookupSids ( cli , mem_ctx ,
pol ,
& sid_array ,
& ref_domains ,
& lsa_names ,
level ,
& count ) ;
}
2007-05-22 11:30:35 +00:00
2007-09-19 12:05:47 +00:00
DEBUG ( 10 , ( " LSA_LOOKUPSIDS returned '%s', mapped count = %d' \n " ,
2008-02-18 10:03:19 +01:00
nt_errstr ( result ) , count ) ) ;
2007-09-19 12:05:47 +00:00
2008-02-18 10:03:19 +01:00
if ( ! NT_STATUS_IS_OK ( result ) & &
! NT_STATUS_EQUAL ( result , NT_STATUS_NONE_MAPPED ) & &
! NT_STATUS_EQUAL ( result , STATUS_SOME_UNMAPPED ) )
2007-05-22 11:30:35 +00:00
{
/* An actual error occured */
goto done ;
}
/* Return output parameters */
2008-02-18 10:03:19 +01:00
if ( NT_STATUS_EQUAL ( result , NT_STATUS_NONE_MAPPED ) | |
( count = = 0 ) )
2007-09-19 12:03:02 +00:00
{
2007-08-29 14:34:15 +00:00
for ( i = 0 ; i < num_sids ; i + + ) {
( names ) [ i ] = NULL ;
( domains ) [ i ] = NULL ;
( types ) [ i ] = SID_NAME_UNKNOWN ;
}
2007-05-22 11:30:35 +00:00
result = NT_STATUS_NONE_MAPPED ;
goto done ;
}
for ( i = 0 ; i < num_sids ; i + + ) {
2008-02-18 10:03:19 +01:00
const char * name , * dom_name ;
uint32_t dom_idx = lsa_names . names [ i ] . sid_index ;
2007-05-22 11:30:35 +00:00
/* Translate optimised name through domain index array */
if ( dom_idx ! = 0xffffffff ) {
2008-02-18 10:03:19 +01:00
dom_name = ref_domains - > domains [ dom_idx ] . name . string ;
name = lsa_names . names [ i ] . name . string ;
2007-05-22 11:30:35 +00:00
2008-04-03 00:23:50 +02:00
if ( name ) {
2010-06-11 11:48:37 +02:00
( names ) [ i ] = talloc_strdup ( names , name ) ;
2008-04-03 00:23:50 +02:00
if ( ( names ) [ i ] = = NULL ) {
DEBUG ( 0 , ( " cli_lsa_lookup_sids_noalloc(): out of memory \n " ) ) ;
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
} else {
( names ) [ i ] = NULL ;
}
2010-06-11 11:48:37 +02:00
domains [ i ] = talloc_strdup ( domains ,
dom_name ? dom_name : " " ) ;
2008-02-18 10:03:19 +01:00
( types ) [ i ] = lsa_names . names [ i ] . sid_type ;
2008-04-03 00:23:50 +02:00
if ( ( ( domains ) [ i ] = = NULL ) ) {
2007-06-09 00:13:07 +00:00
DEBUG ( 0 , ( " cli_lsa_lookup_sids_noalloc(): out of memory \n " ) ) ;
2007-05-22 11:30:35 +00:00
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
} else {
2007-05-22 21:17:31 +00:00
( names ) [ i ] = NULL ;
( domains ) [ i ] = NULL ;
2007-05-22 11:30:35 +00:00
( types ) [ i ] = SID_NAME_UNKNOWN ;
}
}
2007-05-22 13:40:01 +00:00
done :
TALLOC_FREE ( tmp_ctx ) ;
2007-05-22 11:30:35 +00:00
return result ;
}
2007-09-19 12:45:35 +00:00
/* Lookup a list of sids
2007-05-22 11:30:35 +00:00
*
* do it the right way : there is a limit ( of 20480 for w2k3 ) entries
* returned by this call . when the sids list contains more entries ,
* empty lists are returned . This version of lsa_lookup_sids passes
* the list of sids in hunks of LOOKUP_SIDS_HUNK_SIZE to the lsa call . */
/* This constant defines the limit of how many sids to look up
* in one call ( maximum ) . the limit from the server side is
* at 20480 for win2k3 , but we keep it at a save 1000 for now . */
# define LOOKUP_SIDS_HUNK_SIZE 1000
2009-09-13 00:28:49 +02:00
static NTSTATUS rpccli_lsa_lookup_sids_generic ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol ,
int num_sids ,
2010-05-21 11:25:01 +10:00
const struct dom_sid * sids ,
2009-09-13 00:28:49 +02:00
char * * * pdomains ,
char * * * pnames ,
enum lsa_SidType * * ptypes ,
bool use_lookupsids3 )
2007-05-22 11:30:35 +00:00
{
NTSTATUS result = NT_STATUS_OK ;
int sids_left = 0 ;
int sids_processed = 0 ;
2010-05-21 11:25:01 +10:00
const struct dom_sid * hunk_sids = sids ;
2008-03-05 16:20:34 +01:00
char * * hunk_domains ;
char * * hunk_names ;
enum lsa_SidType * hunk_types ;
char * * domains = NULL ;
char * * names = NULL ;
enum lsa_SidType * types = NULL ;
2007-05-22 11:30:35 +00:00
if ( num_sids ) {
2008-03-05 16:20:34 +01:00
if ( ! ( domains = TALLOC_ARRAY ( mem_ctx , char * , num_sids ) ) ) {
2007-09-19 22:11:09 +00:00
DEBUG ( 0 , ( " rpccli_lsa_lookup_sids(): out of memory \n " ) ) ;
2007-05-22 11:30:35 +00:00
result = NT_STATUS_NO_MEMORY ;
2007-09-19 11:01:44 +00:00
goto fail ;
2007-05-22 11:30:35 +00:00
}
2008-03-05 16:20:34 +01:00
if ( ! ( names = TALLOC_ARRAY ( mem_ctx , char * , num_sids ) ) ) {
2007-09-19 22:11:09 +00:00
DEBUG ( 0 , ( " rpccli_lsa_lookup_sids(): out of memory \n " ) ) ;
2007-05-22 11:30:35 +00:00
result = NT_STATUS_NO_MEMORY ;
2007-09-19 11:01:44 +00:00
goto fail ;
2007-05-22 11:30:35 +00:00
}
2008-03-05 16:20:34 +01:00
if ( ! ( types = TALLOC_ARRAY ( mem_ctx , enum lsa_SidType , num_sids ) ) ) {
2007-09-19 22:11:09 +00:00
DEBUG ( 0 , ( " rpccli_lsa_lookup_sids(): out of memory \n " ) ) ;
2007-05-22 11:30:35 +00:00
result = NT_STATUS_NO_MEMORY ;
2007-09-19 11:01:44 +00:00
goto fail ;
2007-05-22 11:30:35 +00:00
}
}
2007-09-19 12:45:35 +00:00
2007-05-22 11:30:35 +00:00
sids_left = num_sids ;
2008-03-05 16:20:34 +01:00
hunk_domains = domains ;
hunk_names = names ;
hunk_types = types ;
2007-05-22 11:30:35 +00:00
while ( sids_left > 0 ) {
int hunk_num_sids ;
NTSTATUS hunk_result = NT_STATUS_OK ;
2007-09-19 12:45:35 +00:00
hunk_num_sids = ( ( sids_left > LOOKUP_SIDS_HUNK_SIZE )
? LOOKUP_SIDS_HUNK_SIZE
2007-05-22 11:30:35 +00:00
: sids_left ) ;
2007-09-19 22:11:09 +00:00
DEBUG ( 10 , ( " rpccli_lsa_lookup_sids: processing items "
2007-09-19 12:45:35 +00:00
" %d -- %d of %d. \n " ,
sids_processed ,
2007-05-22 11:30:35 +00:00
sids_processed + hunk_num_sids - 1 ,
num_sids ) ) ;
2007-05-22 13:40:01 +00:00
hunk_result = rpccli_lsa_lookup_sids_noalloc ( cli ,
mem_ctx ,
2007-05-22 11:30:35 +00:00
pol ,
2007-09-19 12:45:35 +00:00
hunk_num_sids ,
2007-05-22 11:30:35 +00:00
hunk_sids ,
hunk_domains ,
hunk_names ,
2009-09-13 00:28:49 +02:00
hunk_types ,
use_lookupsids3 ) ;
2007-05-22 11:30:35 +00:00
if ( ! NT_STATUS_IS_OK ( hunk_result ) & &
! NT_STATUS_EQUAL ( hunk_result , STATUS_SOME_UNMAPPED ) & &
2007-09-19 12:45:35 +00:00
! NT_STATUS_EQUAL ( hunk_result , NT_STATUS_NONE_MAPPED ) )
2007-05-22 11:30:35 +00:00
{
/* An actual error occured */
2007-09-19 11:01:44 +00:00
result = hunk_result ;
goto fail ;
2007-05-22 11:30:35 +00:00
}
/* adapt overall result */
2007-09-19 12:45:35 +00:00
if ( ( NT_STATUS_IS_OK ( result ) & &
! NT_STATUS_IS_OK ( hunk_result ) )
2007-05-22 11:30:35 +00:00
| |
( NT_STATUS_EQUAL ( result , NT_STATUS_NONE_MAPPED ) & &
! NT_STATUS_EQUAL ( hunk_result , NT_STATUS_NONE_MAPPED ) ) )
{
result = STATUS_SOME_UNMAPPED ;
}
sids_left - = hunk_num_sids ;
sids_processed + = hunk_num_sids ; /* only used in DEBUG */
hunk_sids + = hunk_num_sids ;
hunk_domains + = hunk_num_sids ;
hunk_names + = hunk_num_sids ;
hunk_types + = hunk_num_sids ;
}
2008-03-05 16:20:34 +01:00
* pdomains = domains ;
* pnames = names ;
* ptypes = types ;
2007-09-19 11:01:44 +00:00
return result ;
fail :
2008-03-05 16:20:34 +01:00
TALLOC_FREE ( domains ) ;
TALLOC_FREE ( names ) ;
TALLOC_FREE ( types ) ;
2007-05-22 11:30:35 +00:00
return result ;
}
2009-09-13 00:28:49 +02:00
NTSTATUS rpccli_lsa_lookup_sids ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol ,
int num_sids ,
2010-05-21 11:25:01 +10:00
const struct dom_sid * sids ,
2009-09-13 00:28:49 +02:00
char * * * pdomains ,
char * * * pnames ,
enum lsa_SidType * * ptypes )
{
return rpccli_lsa_lookup_sids_generic ( cli , mem_ctx , pol , num_sids , sids ,
pdomains , pnames , ptypes , false ) ;
}
NTSTATUS rpccli_lsa_lookup_sids3 ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol ,
int num_sids ,
2010-05-21 11:25:01 +10:00
const struct dom_sid * sids ,
2009-09-13 00:28:49 +02:00
char * * * pdomains ,
char * * * pnames ,
enum lsa_SidType * * ptypes )
{
return rpccli_lsa_lookup_sids_generic ( cli , mem_ctx , pol , num_sids , sids ,
pdomains , pnames , ptypes , true ) ;
}
2001-11-15 06:03:22 +00:00
/** Lookup a list of names */
2000-12-13 12:52:21 +00:00
2009-09-11 19:35:14 +02:00
static NTSTATUS rpccli_lsa_lookup_names_generic ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol , int num_names ,
const char * * names ,
const char * * * dom_names ,
int level ,
2010-05-21 11:25:01 +10:00
struct dom_sid * * sids ,
2009-09-11 19:35:14 +02:00
enum lsa_SidType * * types ,
bool use_lookupnames4 )
2000-12-13 12:52:21 +00:00
{
2001-08-27 21:32:54 +00:00
NTSTATUS result ;
2000-12-13 12:52:21 +00:00
int i ;
2008-02-18 04:30:57 +01:00
struct lsa_String * lsa_names = NULL ;
struct lsa_RefDomainList * domains = NULL ;
struct lsa_TransSidArray sid_array ;
2009-09-11 19:35:14 +02:00
struct lsa_TransSidArray3 sid_array3 ;
2008-02-18 04:30:57 +01:00
uint32_t count = 0 ;
2007-09-19 12:45:35 +00:00
2008-02-18 04:30:57 +01:00
ZERO_STRUCT ( sid_array ) ;
2009-09-11 19:35:14 +02:00
ZERO_STRUCT ( sid_array3 ) ;
2000-12-13 12:52:21 +00:00
2008-02-18 04:30:57 +01:00
lsa_names = TALLOC_ARRAY ( mem_ctx , struct lsa_String , num_names ) ;
if ( ! lsa_names ) {
return NT_STATUS_NO_MEMORY ;
}
2005-09-30 17:13:37 +00:00
2008-02-18 04:30:57 +01:00
for ( i = 0 ; i < num_names ; i + + ) {
init_lsa_String ( & lsa_names [ i ] , names [ i ] ) ;
}
2000-12-13 12:52:21 +00:00
2009-09-11 19:35:14 +02:00
if ( use_lookupnames4 ) {
result = rpccli_lsa_LookupNames4 ( cli , mem_ctx ,
num_names ,
lsa_names ,
& domains ,
& sid_array3 ,
level ,
& count ,
0 ,
0 ) ;
} else {
result = rpccli_lsa_LookupNames ( cli , mem_ctx ,
pol ,
num_names ,
lsa_names ,
& domains ,
& sid_array ,
level ,
& count ) ;
}
2000-12-13 12:52:21 +00:00
2002-04-14 11:21:25 +00:00
if ( ! NT_STATUS_IS_OK ( result ) & & NT_STATUS_V ( result ) ! =
NT_STATUS_V ( STATUS_SOME_UNMAPPED ) ) {
2000-12-13 12:52:21 +00:00
/* An actual error occured */
goto done ;
}
/* Return output parameters */
2008-02-18 04:30:57 +01:00
if ( count = = 0 ) {
2001-11-22 08:31:50 +00:00
result = NT_STATUS_NONE_MAPPED ;
goto done ;
}
2007-04-30 02:39:34 +00:00
if ( num_names ) {
2010-05-21 11:25:01 +10:00
if ( ! ( ( * sids = TALLOC_ARRAY ( mem_ctx , struct dom_sid , num_names ) ) ) ) {
2007-04-30 02:39:34 +00:00
DEBUG ( 0 , ( " cli_lsa_lookup_sids(): out of memory \n " ) ) ;
result = NT_STATUS_NO_MEMORY ;
goto done ;
}
2000-12-13 12:52:21 +00:00
2007-10-25 18:29:49 -07:00
if ( ! ( ( * types = TALLOC_ARRAY ( mem_ctx , enum lsa_SidType , num_names ) ) ) ) {
2006-02-03 22:19:41 +00:00
DEBUG ( 0 , ( " cli_lsa_lookup_sids(): out of memory \n " ) ) ;
result = NT_STATUS_NO_MEMORY ;
goto done ;
}
2007-04-30 02:39:34 +00:00
if ( dom_names ! = NULL ) {
* dom_names = TALLOC_ARRAY ( mem_ctx , const char * , num_names ) ;
if ( * dom_names = = NULL ) {
DEBUG ( 0 , ( " cli_lsa_lookup_sids(): out of memory \n " ) ) ;
result = NT_STATUS_NO_MEMORY ;
goto done ;
}
}
} else {
* sids = NULL ;
* types = NULL ;
if ( dom_names ! = NULL ) {
* dom_names = NULL ;
}
2006-02-03 22:19:41 +00:00
}
2002-04-14 11:21:25 +00:00
for ( i = 0 ; i < num_names ; i + + ) {
2009-09-11 19:35:14 +02:00
uint32_t dom_idx ;
2010-05-21 11:25:01 +10:00
struct dom_sid * sid = & ( * sids ) [ i ] ;
2000-12-13 12:52:21 +00:00
2009-09-11 19:35:14 +02:00
if ( use_lookupnames4 ) {
dom_idx = sid_array3 . sids [ i ] . sid_index ;
( * types ) [ i ] = sid_array3 . sids [ i ] . sid_type ;
} else {
dom_idx = sid_array . sids [ i ] . sid_index ;
( * types ) [ i ] = sid_array . sids [ i ] . sid_type ;
}
2000-12-13 12:52:21 +00:00
/* Translate optimised sid through domain index array */
2006-02-03 22:19:41 +00:00
if ( dom_idx = = 0xffffffff ) {
/* Nothing to do, this is unknown */
ZERO_STRUCTP ( sid ) ;
( * types ) [ i ] = SID_NAME_UNKNOWN ;
continue ;
}
2000-12-13 12:52:21 +00:00
2009-09-11 19:35:14 +02:00
if ( use_lookupnames4 ) {
sid_copy ( sid , sid_array3 . sids [ i ] . sid ) ;
} else {
sid_copy ( sid , domains - > domains [ dom_idx ] . sid ) ;
2000-12-13 12:52:21 +00:00
2009-09-11 19:35:14 +02:00
if ( sid_array . sids [ i ] . rid ! = 0xffffffff ) {
sid_append_rid ( sid , sid_array . sids [ i ] . rid ) ;
}
2006-02-03 22:19:41 +00:00
}
2000-12-13 12:52:21 +00:00
2006-02-03 22:19:41 +00:00
if ( dom_names = = NULL ) {
continue ;
2000-12-13 12:52:21 +00:00
}
2006-02-03 22:19:41 +00:00
2008-02-18 04:30:57 +01:00
( * dom_names ) [ i ] = domains - > domains [ dom_idx ] . name . string ;
2000-12-13 12:52:21 +00:00
}
done :
2000-12-15 01:02:11 +00:00
2000-12-13 12:52:21 +00:00
return result ;
2002-08-12 13:40:59 +00:00
}
2009-09-11 19:35:14 +02:00
NTSTATUS rpccli_lsa_lookup_names ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol , int num_names ,
const char * * names ,
const char * * * dom_names ,
int level ,
2010-05-21 11:25:01 +10:00
struct dom_sid * * sids ,
2009-09-11 19:35:14 +02:00
enum lsa_SidType * * types )
{
return rpccli_lsa_lookup_names_generic ( cli , mem_ctx , pol , num_names ,
names , dom_names , level , sids ,
types , false ) ;
}
NTSTATUS rpccli_lsa_lookup_names4 ( struct rpc_pipe_client * cli ,
TALLOC_CTX * mem_ctx ,
struct policy_handle * pol , int num_names ,
const char * * names ,
const char * * * dom_names ,
int level ,
2010-05-21 11:25:01 +10:00
struct dom_sid * * sids ,
2009-09-11 19:35:14 +02:00
enum lsa_SidType * * types )
{
return rpccli_lsa_lookup_names_generic ( cli , mem_ctx , pol , num_names ,
names , dom_names , level , sids ,
types , true ) ;
}