2003-01-15 19:10:57 +03:00
/*
2002-01-30 09:08:46 +03:00
Unix SMB / CIFS implementation .
2001-01-12 01:49:30 +03:00
RPC pipe client
2002-07-15 14:35:28 +04:00
Copyright ( C ) Tim Potter 2000
Copyright ( C ) Rafal Szczesniak 2002
2001-01-12 01:49:30 +03:00
1998-09-26 01:01:52 +04: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
the Free Software Foundation ; either version 2 of the License , or
( at your option ) any later version .
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 .
You should have received a copy of the GNU General Public License
along with this program ; if not , write to the Free Software
Foundation , Inc . , 675 Mass Ave , Cambridge , MA 0213 9 , USA .
*/
# include "includes.h"
2001-10-12 09:56:23 +04:00
# include "rpcclient.h"
2000-12-08 06:34:00 +03:00
2003-01-29 05:24:12 +03:00
2003-01-29 00:09:56 +03:00
/* useful function to allow entering a name instead of a SID and
* looking it up automatically */
2005-09-30 21:13:37 +04:00
static NTSTATUS name_to_sid ( struct rpc_pipe_client * cli ,
2003-01-29 05:24:12 +03:00
TALLOC_CTX * mem_ctx ,
DOM_SID * sid , const char * name )
2003-01-29 00:09:56 +03:00
{
POLICY_HND pol ;
2006-09-08 18:28:06 +04:00
enum lsa_SidType * sid_types ;
2003-01-29 00:09:56 +03:00
NTSTATUS result ;
DOM_SID * sids ;
/* maybe its a raw SID */
if ( strncmp ( name , " S- " , 2 ) = = 0 & &
2003-01-29 05:24:12 +03:00
string_to_sid ( sid , name ) ) {
2003-01-29 00:09:56 +03:00
return NT_STATUS_OK ;
}
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2003-01-29 05:24:12 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
2003-01-29 00:09:56 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-02-04 01:19:41 +03:00
result = rpccli_lsa_lookup_names ( cli , mem_ctx , & pol , 1 , & name , NULL , & sids , & sid_types ) ;
2003-01-29 00:09:56 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2003-01-29 00:09:56 +03:00
* sid = sids [ 0 ] ;
done :
return result ;
}
2006-04-11 19:47:24 +04:00
static void display_query_info_1 ( DOM_QUERY_1 d )
{
d_printf ( " percent_full: \t %d \n " , d . percent_full ) ;
d_printf ( " log_size: \t %d \n " , d . log_size ) ;
2006-09-30 21:32:26 +04:00
d_printf ( " retention_time: \t %lld \n " , ( long long ) d . retention_time ) ;
2006-04-11 19:47:24 +04:00
d_printf ( " shutdown_in_progress: \t %d \n " , d . shutdown_in_progress ) ;
2006-09-30 21:32:26 +04:00
d_printf ( " time_to_shutdown: \t %lld \n " , ( long long ) d . time_to_shutdown ) ;
2006-04-11 19:47:24 +04:00
d_printf ( " next_audit_record: \t %d \n " , d . next_audit_record ) ;
d_printf ( " unknown: \t %d \n " , d . unknown ) ;
}
static void display_query_info_2 ( DOM_QUERY_2 d , TALLOC_CTX * mem_ctx )
{
int i ;
d_printf ( " Auditing enabled: \t %d \n " , d . auditing_enabled ) ;
d_printf ( " Auditing categories: \t %d \n " , d . count1 ) ;
d_printf ( " Auditsettings: \n " ) ;
for ( i = 0 ; i < d . count1 ; i + + ) {
const char * val = audit_policy_str ( mem_ctx , d . auditsettings [ i ] ) ;
const char * policy = audit_description_str ( i ) ;
d_printf ( " %s: \t %s \n " , policy , val ) ;
}
}
static void display_query_info_3 ( DOM_QUERY_3 d )
{
fstring name ;
unistr2_to_ascii ( name , & d . uni_domain_name , d . uni_dom_max_len ) ;
d_printf ( " Domain Name: %s \n " , name ) ;
d_printf ( " Domain Sid: %s \n " , sid_string_static ( & d . dom_sid . sid ) ) ;
}
static void display_query_info_5 ( DOM_QUERY_5 d )
{
fstring name ;
unistr2_to_ascii ( name , & d . uni_domain_name , d . uni_dom_max_len ) ;
d_printf ( " Domain Name: %s \n " , name ) ;
d_printf ( " Domain Sid: %s \n " , sid_string_static ( & d . dom_sid . sid ) ) ;
}
static void display_query_info_10 ( DOM_QUERY_10 d )
{
d_printf ( " Shutdown on full: %d \n " , d . shutdown_on_full ) ;
}
static void display_query_info_11 ( DOM_QUERY_11 d )
{
d_printf ( " Shutdown on full: %d \n " , d . shutdown_on_full ) ;
d_printf ( " Log is full: %d \n " , d . log_is_full ) ;
d_printf ( " Unknown: %d \n " , d . unknown ) ;
}
static void display_query_info_12 ( DOM_QUERY_12 d )
{
fstring dom_name , dns_dom_name , forest_name ;
unistr2_to_ascii ( dom_name , & d . uni_nb_dom_name , d . hdr_nb_dom_name . uni_max_len ) ;
unistr2_to_ascii ( dns_dom_name , & d . uni_dns_dom_name , d . hdr_dns_dom_name . uni_max_len ) ;
unistr2_to_ascii ( forest_name , & d . uni_forest_name , d . hdr_forest_name . uni_max_len ) ;
2003-01-29 05:24:12 +03:00
2006-04-11 19:47:24 +04:00
d_printf ( " Domain NetBios Name: %s \n " , dom_name ) ;
d_printf ( " Domain DNS Name: %s \n " , dns_dom_name ) ;
d_printf ( " Domain Forest Name: %s \n " , forest_name ) ;
d_printf ( " Domain Sid: %s \n " , sid_string_static ( & d . dom_sid . sid ) ) ;
d_printf ( " Domain GUID: %s \n " , smb_uuid_string_static ( d . dom_guid ) ) ;
}
static void display_lsa_query_info ( LSA_INFO_CTR * dom , TALLOC_CTX * mem_ctx )
{
switch ( dom - > info_class ) {
case 1 :
display_query_info_1 ( dom - > info . id1 ) ;
break ;
case 2 :
display_query_info_2 ( dom - > info . id2 , mem_ctx ) ;
break ;
case 3 :
display_query_info_3 ( dom - > info . id3 ) ;
break ;
case 5 :
display_query_info_5 ( dom - > info . id5 ) ;
break ;
case 10 :
display_query_info_10 ( dom - > info . id10 ) ;
break ;
case 11 :
display_query_info_11 ( dom - > info . id11 ) ;
break ;
case 12 :
display_query_info_12 ( dom - > info . id12 ) ;
break ;
default :
printf ( " can't display info level: %d \n " , dom - > info_class ) ;
break ;
}
}
2001-10-12 09:56:23 +04:00
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_query_info_policy ( struct rpc_pipe_client * cli ,
2001-10-12 09:56:23 +04:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-01-12 01:49:30 +03:00
{
POLICY_HND pol ;
2001-09-04 11:13:01 +04:00
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
2006-04-11 19:47:24 +04:00
LSA_INFO_CTR dom ;
2004-01-08 11:19:18 +03:00
2001-01-12 01:49:30 +03:00
uint32 info_class = 3 ;
if ( argc > 2 ) {
printf ( " Usage: %s [info_class] \n " , argv [ 0 ] ) ;
2001-09-04 11:13:01 +04:00
return NT_STATUS_OK ;
2000-12-08 06:34:00 +03:00
}
1999-11-02 01:25:38 +03:00
2001-10-12 09:56:23 +04:00
if ( argc = = 2 )
2001-01-12 01:49:30 +03:00
info_class = atoi ( argv [ 1 ] ) ;
2006-04-11 19:47:24 +04:00
2002-08-17 19:33:49 +04:00
switch ( info_class ) {
case 12 :
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2006-04-11 19:47:24 +04:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
2002-08-17 19:33:49 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-04-11 19:47:24 +04:00
result = rpccli_lsa_query_info_policy2_new ( cli , mem_ctx , & pol ,
info_class , & dom ) ;
2002-08-17 19:33:49 +04:00
break ;
default :
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2006-04-11 19:47:24 +04:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
1998-09-26 01:01:52 +04:00
2002-08-17 19:33:49 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-04-11 19:47:24 +04:00
result = rpccli_lsa_query_info_policy_new ( cli , mem_ctx , & pol ,
info_class , & dom ) ;
2002-08-17 19:33:49 +04:00
}
2001-10-12 09:56:23 +04:00
2001-01-12 20:53:47 +03:00
2006-04-11 19:47:24 +04:00
display_lsa_query_info ( & dom , mem_ctx ) ;
2005-09-30 21:13:37 +04:00
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-09-30 21:13:37 +04:00
2001-10-12 09:56:23 +04:00
done :
2001-01-12 01:49:30 +03:00
return result ;
}
1998-09-26 01:01:52 +04:00
2001-01-12 01:49:30 +03:00
/* Resolve a list of names to a list of sids */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_lookup_names ( struct rpc_pipe_client * cli ,
2001-10-12 09:56:23 +04:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-01-12 01:49:30 +03:00
{
POLICY_HND pol ;
2001-09-04 11:13:01 +04:00
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
2001-01-12 01:49:30 +03:00
DOM_SID * sids ;
2006-09-08 18:28:06 +04:00
enum lsa_SidType * types ;
2002-04-15 09:02:22 +04:00
int i ;
1998-09-26 01:01:52 +04:00
2001-01-12 01:49:30 +03:00
if ( argc = = 1 ) {
printf ( " Usage: %s [name1 [name2 [...]]] \n " , argv [ 0 ] ) ;
2001-09-04 11:13:01 +04:00
return NT_STATUS_OK ;
2000-12-08 06:34:00 +03:00
}
1998-09-26 01:01:52 +04:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2001-09-04 11:13:01 +04:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
1998-09-26 01:01:52 +04:00
2001-10-12 09:56:23 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
1998-09-26 01:01:52 +04:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_lookup_names ( cli , mem_ctx , & pol , argc - 1 ,
2006-02-04 01:19:41 +03:00
( const char * * ) ( argv + 1 ) , NULL , & sids , & types ) ;
2001-10-12 09:56:23 +04:00
2002-07-15 14:35:28 +04:00
if ( ! NT_STATUS_IS_OK ( result ) & & NT_STATUS_V ( result ) ! =
NT_STATUS_V ( STATUS_SOME_UNMAPPED ) )
2001-01-12 01:49:30 +03:00
goto done ;
2000-12-08 06:34:00 +03:00
2002-07-15 14:35:28 +04:00
result = NT_STATUS_OK ;
2001-01-12 01:49:30 +03:00
/* Print results */
2000-12-08 06:34:00 +03:00
2002-04-15 09:02:22 +04:00
for ( i = 0 ; i < ( argc - 1 ) ; i + + ) {
2001-01-12 01:49:30 +03:00
fstring sid_str ;
sid_to_string ( sid_str , & sids [ i ] ) ;
2002-07-15 14:35:28 +04:00
printf ( " %s %s (%s: %d) \n " , argv [ i + 1 ] , sid_str ,
sid_type_lookup ( types [ i ] ) , types [ i ] ) ;
1998-09-26 01:01:52 +04:00
}
2000-12-08 06:34:00 +03:00
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-03-10 21:50:47 +03:00
2001-01-12 01:49:30 +03:00
done :
2000-12-08 06:34:00 +03:00
return result ;
1998-09-30 23:09:57 +04:00
}
2001-01-12 01:49:30 +03:00
/* Resolve a list of SIDs to a list of names */
2000-12-08 06:34:00 +03:00
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_lookup_sids ( struct rpc_pipe_client * cli , TALLOC_CTX * mem_ctx ,
2003-02-26 02:51:56 +03:00
int argc , const char * * argv )
1998-11-25 22:57:04 +03:00
{
2001-01-12 01:49:30 +03:00
POLICY_HND pol ;
2001-09-04 11:13:01 +04:00
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
2000-12-08 06:34:00 +03:00
DOM_SID * sids ;
2002-01-20 04:24:59 +03:00
char * * domains ;
2000-12-08 06:34:00 +03:00
char * * names ;
2006-09-08 18:28:06 +04:00
enum lsa_SidType * types ;
2002-04-15 09:02:22 +04:00
int i ;
1998-09-30 23:09:57 +04:00
2000-12-08 06:34:00 +03:00
if ( argc = = 1 ) {
2001-01-12 01:49:30 +03:00
printf ( " Usage: %s [sid1 [sid2 [...]]] \n " , argv [ 0 ] ) ;
2001-09-04 11:13:01 +04:00
return NT_STATUS_OK ;
2000-12-08 06:34:00 +03:00
}
1998-09-30 23:09:57 +04:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2001-09-04 11:13:01 +04:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
1998-11-11 17:23:55 +03:00
2001-10-12 09:56:23 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
1998-09-30 23:09:57 +04:00
2001-01-12 01:49:30 +03:00
/* Convert arguments to sids */
1999-12-13 16:27:58 +03:00
2005-02-28 14:11:55 +03:00
sids = TALLOC_ARRAY ( mem_ctx , DOM_SID , argc - 1 ) ;
1998-09-30 23:09:57 +04:00
2001-01-12 01:49:30 +03:00
if ( ! sids ) {
2001-10-12 09:56:23 +04:00
printf ( " could not allocate memory for %d sids \n " , argc - 1 ) ;
2001-01-12 01:49:30 +03:00
goto done ;
2000-12-08 06:34:00 +03:00
}
1998-09-30 23:09:57 +04:00
2005-02-28 14:11:55 +03:00
for ( i = 0 ; i < argc - 1 ; i + + )
if ( ! string_to_sid ( & sids [ i ] , argv [ i + 1 ] ) ) {
2003-02-18 10:05:02 +03:00
result = NT_STATUS_INVALID_SID ;
goto done ;
}
1999-12-13 16:27:58 +03:00
2001-01-12 01:49:30 +03:00
/* Lookup the SIDs */
1998-09-30 23:09:57 +04:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_lookup_sids ( cli , mem_ctx , & pol , argc - 1 , sids ,
2002-04-15 09:02:22 +04:00
& domains , & names , & types ) ;
2001-10-12 09:56:23 +04:00
2002-07-15 14:35:28 +04:00
if ( ! NT_STATUS_IS_OK ( result ) & & NT_STATUS_V ( result ) ! =
NT_STATUS_V ( STATUS_SOME_UNMAPPED ) )
2001-01-12 01:49:30 +03:00
goto done ;
2000-12-08 06:34:00 +03:00
2002-07-15 14:35:28 +04:00
result = NT_STATUS_OK ;
2001-01-12 01:49:30 +03:00
/* Print results */
2005-03-10 21:50:47 +03:00
for ( i = 0 ; i < ( argc - 1 ) ; i + + ) {
2001-01-12 01:49:30 +03:00
fstring sid_str ;
2000-12-08 06:34:00 +03:00
2001-01-12 01:49:30 +03:00
sid_to_string ( sid_str , & sids [ i ] ) ;
2002-07-15 14:35:28 +04:00
printf ( " %s %s \\ %s (%d) \n " , sid_str ,
2002-01-20 04:24:59 +03:00
domains [ i ] ? domains [ i ] : " *unknown* " ,
names [ i ] ? names [ i ] : " *unknown* " , types [ i ] ) ;
1998-09-26 01:01:52 +04:00
}
2000-12-08 06:34:00 +03:00
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-03-10 21:50:47 +03:00
2001-01-12 01:49:30 +03:00
done :
2000-12-08 06:34:00 +03:00
return result ;
1999-03-18 08:16:59 +03:00
}
2001-01-12 01:49:30 +03:00
/* Enumerate list of trusted domains */
2000-12-08 06:34:00 +03:00
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_enum_trust_dom ( struct rpc_pipe_client * cli ,
2001-10-12 09:56:23 +04:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-01-12 01:49:30 +03:00
{
POLICY_HND pol ;
2001-09-04 11:13:01 +04:00
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
2001-01-12 01:49:30 +03:00
DOM_SID * domain_sids ;
char * * domain_names ;
2002-07-15 14:35:28 +04:00
/* defaults, but may be changed using params */
2001-03-23 23:41:22 +03:00
uint32 enum_ctx = 0 ;
2002-07-15 14:35:28 +04:00
uint32 num_domains = 0 ;
2001-03-23 23:41:22 +03:00
int i ;
2001-01-12 01:49:30 +03:00
2002-08-17 19:33:49 +04:00
if ( argc > 2 ) {
printf ( " Usage: %s [enum context (0)] \n " , argv [ 0 ] ) ;
2001-09-04 11:13:01 +04:00
return NT_STATUS_OK ;
2001-01-12 01:49:30 +03:00
}
2000-12-08 06:34:00 +03:00
2002-08-17 19:33:49 +04:00
if ( argc = = 2 & & argv [ 1 ] ) {
2002-07-15 14:35:28 +04:00
enum_ctx = atoi ( argv [ 2 ] ) ;
}
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2002-07-15 14:35:28 +04:00
POLICY_VIEW_LOCAL_INFORMATION ,
2001-09-04 11:13:01 +04:00
& pol ) ;
2000-12-08 06:34:00 +03:00
2001-10-12 09:56:23 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2001-01-12 01:49:30 +03:00
2005-01-22 20:12:19 +03:00
result = STATUS_MORE_ENTRIES ;
while ( NT_STATUS_EQUAL ( result , STATUS_MORE_ENTRIES ) ) {
2001-01-12 01:49:30 +03:00
2005-01-22 20:12:19 +03:00
/* Lookup list of trusted domains */
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_enum_trust_dom ( cli , mem_ctx , & pol , & enum_ctx ,
2005-01-22 20:12:19 +03:00
& num_domains ,
& domain_names , & domain_sids ) ;
if ( ! NT_STATUS_IS_OK ( result ) & &
! NT_STATUS_EQUAL ( result , NT_STATUS_NO_MORE_ENTRIES ) & &
! NT_STATUS_EQUAL ( result , STATUS_MORE_ENTRIES ) )
goto done ;
/* Print results: list of names and sids returned in this
* response . */
for ( i = 0 ; i < num_domains ; i + + ) {
fstring sid_str ;
sid_to_string ( sid_str , & domain_sids [ i ] ) ;
printf ( " %s %s \n " , domain_names [ i ] ? domain_names [ i ] :
" *unknown* " , sid_str ) ;
}
2001-01-12 01:49:30 +03:00
}
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-01-12 01:49:30 +03:00
done :
return result ;
2000-12-08 06:34:00 +03:00
}
2001-01-12 01:49:30 +03:00
2001-11-22 19:12:43 +03:00
/* Enumerates privileges */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_enum_privilege ( struct rpc_pipe_client * cli ,
2003-02-26 02:51:56 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
2001-11-22 19:12:43 +03:00
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint32 enum_context = 0 ;
uint32 pref_max_length = 0x1000 ;
uint32 count = 0 ;
char * * privs_name ;
uint32 * privs_high ;
uint32 * privs_low ;
int i ;
2001-11-23 02:50:16 +03:00
if ( argc > 3 ) {
printf ( " Usage: %s [enum context] [max length] \n " , argv [ 0 ] ) ;
2001-11-22 19:12:43 +03:00
return NT_STATUS_OK ;
}
2001-11-23 02:50:16 +03:00
if ( argc > = 2 )
enum_context = atoi ( argv [ 1 ] ) ;
if ( argc = = 3 )
pref_max_length = atoi ( argv [ 2 ] ) ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2001-11-22 19:12:43 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_enum_privilege ( cli , mem_ctx , & pol , & enum_context , pref_max_length ,
2001-11-22 19:12:43 +03:00
& count , & privs_name , & privs_high , & privs_low ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
2001-11-23 02:50:16 +03:00
printf ( " found %d privileges \n \n " , count ) ;
2001-11-22 19:12:43 +03:00
for ( i = 0 ; i < count ; i + + ) {
printf ( " %s \t \t %d:%d (0x%x:0x%x) \n " , privs_name [ i ] ? privs_name [ i ] : " *unknown* " ,
privs_high [ i ] , privs_low [ i ] , privs_high [ i ] , privs_low [ i ] ) ;
}
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-11-22 19:12:43 +03:00
done :
return result ;
}
2001-11-22 19:54:48 +03:00
/* Get privilege name */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_get_dispname ( struct rpc_pipe_client * cli ,
2001-11-22 19:54:48 +03:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-11-22 19:54:48 +03:00
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint16 lang_id = 0 ;
uint16 lang_id_sys = 0 ;
uint16 lang_id_desc ;
fstring description ;
if ( argc ! = 2 ) {
printf ( " Usage: %s privilege name \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2001-11-22 19:54:48 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_get_dispname ( cli , mem_ctx , & pol , argv [ 1 ] , lang_id , lang_id_sys , description , & lang_id_desc ) ;
2001-11-22 19:54:48 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
printf ( " %s -> %s (language: 0x%x) \n " , argv [ 1 ] , description , lang_id_desc ) ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-11-22 19:54:48 +03:00
done :
return result ;
}
2001-11-23 02:50:16 +03:00
/* Enumerate the LSA SIDS */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_enum_sids ( struct rpc_pipe_client * cli ,
2003-02-26 02:51:56 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
2001-11-23 02:50:16 +03:00
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint32 enum_context = 0 ;
uint32 pref_max_length = 0x1000 ;
DOM_SID * sids ;
uint32 count = 0 ;
int i ;
if ( argc > 3 ) {
printf ( " Usage: %s [enum context] [max length] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
if ( argc > = 2 )
enum_context = atoi ( argv [ 1 ] ) ;
if ( argc = = 3 )
pref_max_length = atoi ( argv [ 2 ] ) ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy ( cli , mem_ctx , True ,
2001-11-23 02:50:16 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_enum_sids ( cli , mem_ctx , & pol , & enum_context , pref_max_length ,
2001-11-23 02:50:16 +03:00
& count , & sids ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
printf ( " found %d SIDs \n \n " , count ) ;
for ( i = 0 ; i < count ; i + + ) {
fstring sid_str ;
sid_to_string ( sid_str , & sids [ i ] ) ;
printf ( " %s \n " , sid_str ) ;
}
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-11-23 02:50:16 +03:00
done :
return result ;
}
2005-01-14 22:26:13 +03:00
/* Create a new account */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_create_account ( struct rpc_pipe_client * cli ,
2005-01-14 22:26:13 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND dom_pol ;
POLICY_HND user_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint32 des_access = 0x000f000f ;
DOM_SID sid ;
if ( argc ! = 2 ) {
printf ( " Usage: %s SID \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
result = name_to_sid ( cli , mem_ctx , & sid , argv [ 1 ] ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2005-01-14 22:26:13 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& dom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_create_account ( cli , mem_ctx , & dom_pol , & sid , des_access , & user_pol ) ;
2005-01-14 22:26:13 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
printf ( " Account for SID %s successfully created \n \n " , argv [ 1 ] ) ;
result = NT_STATUS_OK ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & dom_pol ) ;
2005-01-14 22:26:13 +03:00
done :
return result ;
}
2001-11-24 03:13:41 +03:00
/* Enumerate the privileges of an SID */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_enum_privsaccounts ( struct rpc_pipe_client * cli ,
2001-11-24 03:13:41 +03:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-11-24 03:13:41 +03:00
{
POLICY_HND dom_pol ;
POLICY_HND user_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
2003-01-15 20:22:48 +03:00
uint32 access_desired = 0x000f000f ;
2003-01-15 21:57:41 +03:00
2001-11-24 03:13:41 +03:00
DOM_SID sid ;
uint32 count = 0 ;
LUID_ATTR * set ;
int i ;
if ( argc ! = 2 ) {
printf ( " Usage: %s SID \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
2003-01-29 05:24:12 +03:00
result = name_to_sid ( cli , mem_ctx , & sid , argv [ 1 ] ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2001-11-24 03:13:41 +03:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2001-11-24 03:13:41 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& dom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_account ( cli , mem_ctx , & dom_pol , & sid , access_desired , & user_pol ) ;
2001-11-24 03:13:41 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_enum_privsaccount ( cli , mem_ctx , & user_pol , & count , & set ) ;
2001-11-24 03:13:41 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
printf ( " found %d privileges for SID %s \n \n " , count , argv [ 1 ] ) ;
printf ( " high \t low \t attribute \n " ) ;
for ( i = 0 ; i < count ; i + + ) {
printf ( " %u \t %u \t %u \n " , set [ i ] . luid . high , set [ i ] . luid . low , set [ i ] . attr ) ;
}
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & dom_pol ) ;
2001-11-24 03:13:41 +03:00
done :
return result ;
}
2003-01-15 20:22:48 +03:00
/* Enumerate the privileges of an SID via LsaEnumerateAccountRights */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_enum_acct_rights ( struct rpc_pipe_client * cli ,
2003-01-15 20:22:48 +03:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2003-01-15 20:22:48 +03:00
{
POLICY_HND dom_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
DOM_SID sid ;
uint32 count ;
char * * rights ;
int i ;
if ( argc ! = 2 ) {
printf ( " Usage: %s SID \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
2003-01-29 05:24:12 +03:00
result = name_to_sid ( cli , mem_ctx , & sid , argv [ 1 ] ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2003-01-15 20:22:48 +03:00
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2003-01-15 20:22:48 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& dom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_enum_account_rights ( cli , mem_ctx , & dom_pol , & sid , & count , & rights ) ;
2003-01-15 20:22:48 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2003-01-29 05:24:12 +03:00
printf ( " found %d privileges for SID %s \n " , count , sid_string_static ( & sid ) ) ;
2003-01-15 20:22:48 +03:00
for ( i = 0 ; i < count ; i + + ) {
printf ( " \t %s \n " , rights [ i ] ) ;
}
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & dom_pol ) ;
2003-01-15 20:22:48 +03:00
done :
return result ;
}
2003-01-29 00:09:56 +03:00
/* add some privileges to a SID via LsaAddAccountRights */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_add_acct_rights ( struct rpc_pipe_client * cli ,
2003-01-29 00:09:56 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND dom_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
DOM_SID sid ;
if ( argc < 3 ) {
printf ( " Usage: %s SID [rights...] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
result = name_to_sid ( cli , mem_ctx , & sid , argv [ 1 ] ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2003-01-29 00:09:56 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& dom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_add_account_rights ( cli , mem_ctx , & dom_pol , sid ,
2003-01-29 00:09:56 +03:00
argc - 2 , argv + 2 ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & dom_pol ) ;
2003-01-29 00:09:56 +03:00
done :
return result ;
}
2003-01-29 05:24:12 +03:00
/* remove some privileges to a SID via LsaRemoveAccountRights */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_remove_acct_rights ( struct rpc_pipe_client * cli ,
2003-01-29 05:24:12 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND dom_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
DOM_SID sid ;
if ( argc < 3 ) {
printf ( " Usage: %s SID [rights...] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
result = name_to_sid ( cli , mem_ctx , & sid , argv [ 1 ] ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2003-01-29 05:24:12 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& dom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_remove_account_rights ( cli , mem_ctx , & dom_pol , sid ,
2003-01-29 05:24:12 +03:00
False , argc - 2 , argv + 2 ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & dom_pol ) ;
2005-09-30 21:13:37 +04:00
2003-01-29 05:24:12 +03:00
done :
return result ;
}
2001-11-24 03:13:41 +03:00
/* Get a privilege value given its name */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_lookup_priv_value ( struct rpc_pipe_client * cli ,
2003-02-26 02:51:56 +03:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
2001-11-24 03:13:41 +03:00
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
LUID luid ;
if ( argc ! = 2 ) {
printf ( " Usage: %s name \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2001-11-24 03:13:41 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_lookup_priv_value ( cli , mem_ctx , & pol , argv [ 1 ] , & luid ) ;
2001-11-24 03:13:41 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
2002-07-15 14:35:28 +04:00
2001-11-24 03:13:41 +03:00
printf ( " %u:%u (0x%x:0x%x) \n " , luid . high , luid . low , luid . high , luid . low ) ;
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-11-24 03:13:41 +03:00
done :
return result ;
}
2001-12-11 05:17:26 +03:00
/* Query LSA security object */
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_query_secobj ( struct rpc_pipe_client * cli ,
2001-12-11 05:17:26 +03:00
TALLOC_CTX * mem_ctx , int argc ,
2003-02-26 02:51:56 +03:00
const char * * argv )
2001-12-11 05:17:26 +03:00
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
SEC_DESC_BUF * sdb ;
2006-03-10 16:01:08 +03:00
uint32 sec_info = DACL_SECURITY_INFORMATION ;
2001-12-11 05:17:26 +03:00
2006-03-10 16:01:08 +03:00
if ( argc < 1 | | argc > 2 ) {
printf ( " Usage: %s [sec_info] \n " , argv [ 0 ] ) ;
2001-12-11 05:17:26 +03:00
return NT_STATUS_OK ;
}
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True ,
2001-12-11 05:17:26 +03:00
SEC_RIGHTS_MAXIMUM_ALLOWED ,
& pol ) ;
2006-03-10 16:01:08 +03:00
if ( argc = = 2 )
sscanf ( argv [ 1 ] , " %x " , & sec_info ) ;
2001-12-11 05:17:26 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_query_secobj ( cli , mem_ctx , & pol , sec_info , & sdb ) ;
2001-12-11 05:17:26 +03:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
/* Print results */
2006-09-21 02:23:12 +04:00
display_sec_desc ( sdb - > sd ) ;
2001-12-11 05:17:26 +03:00
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2001-12-11 05:17:26 +03:00
done :
return result ;
}
2005-06-08 17:59:03 +04:00
static void display_trust_dom_info_1 ( TRUSTED_DOMAIN_INFO_NAME * n )
{
printf ( " NetBIOS Name: \t %s \n " , unistr2_static ( & n - > netbios_name . unistring ) ) ;
}
static void display_trust_dom_info_3 ( TRUSTED_DOMAIN_INFO_POSIX_OFFSET * p )
{
2005-11-22 17:38:49 +03:00
printf ( " Posix Offset: \t %08x (%d) \n " , p - > posix_offset , p - > posix_offset ) ;
2005-06-08 17:59:03 +04:00
}
static void display_trust_dom_info_4 ( TRUSTED_DOMAIN_INFO_PASSWORD * p , const char * password )
{
char * pwd , * pwd_old ;
DATA_BLOB data = data_blob ( NULL , p - > password . length ) ;
DATA_BLOB data_old = data_blob ( NULL , p - > old_password . length ) ;
memcpy ( data . data , p - > password . data , p - > password . length ) ;
memcpy ( data_old . data , p - > old_password . data , p - > old_password . length ) ;
pwd = decrypt_trustdom_secret ( password , & data ) ;
pwd_old = decrypt_trustdom_secret ( password , & data_old ) ;
2005-06-13 18:39:40 +04:00
d_printf ( " Password: \t %s \n " , pwd ) ;
d_printf ( " Old Password: \t %s \n " , pwd_old ) ;
2005-06-08 17:59:03 +04:00
SAFE_FREE ( pwd ) ;
SAFE_FREE ( pwd_old ) ;
data_blob_free ( & data ) ;
data_blob_free ( & data_old ) ;
}
2005-11-22 17:38:49 +03:00
static void display_trust_dom_info_6 ( TRUSTED_DOMAIN_INFO_EX * i )
{
printf ( " Domain Name: \t \t %s \n " , unistr2_static ( & i - > domain_name . unistring ) ) ;
printf ( " NetBIOS Name: \t \t %s \n " , unistr2_static ( & i - > netbios_name . unistring ) ) ;
printf ( " SID: \t \t \t %s \n " , sid_string_static ( & i - > sid . sid ) ) ;
printf ( " Trust Direction: \t 0x%08x \n " , i - > trust_direction ) ;
printf ( " Trust Type: \t \t 0x%08x \n " , i - > trust_type ) ;
printf ( " Trust Attributes: \t 0x%08x \n " , i - > trust_attributes ) ;
}
2005-06-08 17:59:03 +04:00
static void display_trust_dom_info ( LSA_TRUSTED_DOMAIN_INFO * info , uint32 info_class , const char * pass )
{
switch ( info_class ) {
case 1 :
display_trust_dom_info_1 ( & info - > name ) ;
break ;
case 3 :
display_trust_dom_info_3 ( & info - > posix_offset ) ;
break ;
case 4 :
display_trust_dom_info_4 ( & info - > password , pass ) ;
break ;
2005-11-22 17:38:49 +03:00
case 6 :
display_trust_dom_info_6 ( & info - > info_ex ) ;
break ;
2005-06-08 17:59:03 +04:00
default :
printf ( " unsupported info-class: %d \n " , info_class ) ;
break ;
}
}
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_query_trustdominfobysid ( struct rpc_pipe_client * cli ,
2005-06-08 17:59:03 +04:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
DOM_SID dom_sid ;
uint32 access_mask = SEC_RIGHTS_MAXIMUM_ALLOWED ;
LSA_TRUSTED_DOMAIN_INFO * info ;
uint32 info_class = 1 ;
if ( argc > 3 | | argc < 2 ) {
printf ( " Usage: %s [sid] [info_class] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
if ( ! string_to_sid ( & dom_sid , argv [ 1 ] ) )
return NT_STATUS_NO_MEMORY ;
if ( argc = = 3 )
info_class = atoi ( argv [ 2 ] ) ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True , access_mask , & pol ) ;
2005-06-08 17:59:03 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_query_trusted_domain_info_by_sid ( cli , mem_ctx , & pol ,
2005-06-08 17:59:03 +04:00
info_class , & dom_sid , & info ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
display_trust_dom_info ( info , info_class , cli - > pwd . password ) ;
done :
if ( & pol )
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-06-08 17:59:03 +04:00
return result ;
}
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_query_trustdominfobyname ( struct rpc_pipe_client * cli ,
2005-06-08 17:59:03 +04:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint32 access_mask = SEC_RIGHTS_MAXIMUM_ALLOWED ;
LSA_TRUSTED_DOMAIN_INFO * info ;
uint32 info_class = 1 ;
if ( argc > 3 | | argc < 2 ) {
printf ( " Usage: %s [name] [info_class] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
if ( argc = = 3 )
info_class = atoi ( argv [ 2 ] ) ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True , access_mask , & pol ) ;
2005-06-08 17:59:03 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_query_trusted_domain_info_by_name ( cli , mem_ctx , & pol ,
2005-06-08 17:59:03 +04:00
info_class , argv [ 1 ] , & info ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
display_trust_dom_info ( info , info_class , cli - > pwd . password ) ;
done :
if ( & pol )
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-06-08 17:59:03 +04:00
return result ;
}
2005-09-30 21:13:37 +04:00
static NTSTATUS cmd_lsa_query_trustdominfo ( struct rpc_pipe_client * cli ,
2005-06-08 17:59:03 +04:00
TALLOC_CTX * mem_ctx , int argc ,
const char * * argv )
{
POLICY_HND pol , trustdom_pol ;
NTSTATUS result = NT_STATUS_UNSUCCESSFUL ;
uint32 access_mask = SEC_RIGHTS_MAXIMUM_ALLOWED ;
LSA_TRUSTED_DOMAIN_INFO * info ;
DOM_SID dom_sid ;
uint32 info_class = 1 ;
if ( argc > 3 | | argc < 2 ) {
printf ( " Usage: %s [sid] [info_class] \n " , argv [ 0 ] ) ;
return NT_STATUS_OK ;
}
if ( ! string_to_sid ( & dom_sid , argv [ 1 ] ) )
return NT_STATUS_NO_MEMORY ;
if ( argc = = 3 )
info_class = atoi ( argv [ 2 ] ) ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_policy2 ( cli , mem_ctx , True , access_mask , & pol ) ;
2005-06-08 17:59:03 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_open_trusted_domain ( cli , mem_ctx , & pol ,
2005-06-08 17:59:03 +04:00
& dom_sid , access_mask , & trustdom_pol ) ;
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
2005-09-30 21:13:37 +04:00
result = rpccli_lsa_query_trusted_domain_info ( cli , mem_ctx , & trustdom_pol ,
2005-11-22 17:32:29 +03:00
info_class , & info ) ;
2005-06-08 17:59:03 +04:00
if ( ! NT_STATUS_IS_OK ( result ) )
goto done ;
display_trust_dom_info ( info , info_class , cli - > pwd . password ) ;
done :
if ( & pol )
2006-09-21 02:49:02 +04:00
rpccli_lsa_Close ( cli , mem_ctx , & pol ) ;
2005-06-08 17:59:03 +04:00
return result ;
}
2002-10-04 08:10:23 +04:00
2001-01-12 01:49:30 +03:00
/* List of commands exported by this module */
struct cmd_set lsarpc_commands [ ] = {
2001-07-20 08:38:58 +04:00
{ " LSARPC " } ,
2005-09-30 21:13:37 +04:00
{ " lsaquery " , RPC_RTYPE_NTSTATUS , cmd_lsa_query_info_policy , NULL , PI_LSARPC , NULL , " Query info policy " , " " } ,
{ " lookupsids " , RPC_RTYPE_NTSTATUS , cmd_lsa_lookup_sids , NULL , PI_LSARPC , NULL , " Convert SIDs to names " , " " } ,
{ " lookupnames " , RPC_RTYPE_NTSTATUS , cmd_lsa_lookup_names , NULL , PI_LSARPC , NULL , " Convert names to SIDs " , " " } ,
{ " enumtrust " , RPC_RTYPE_NTSTATUS , cmd_lsa_enum_trust_dom , NULL , PI_LSARPC , NULL , " Enumerate trusted domains " , " Usage: [preferred max number] [enum context (0)] " } ,
{ " enumprivs " , RPC_RTYPE_NTSTATUS , cmd_lsa_enum_privilege , NULL , PI_LSARPC , NULL , " Enumerate privileges " , " " } ,
{ " getdispname " , RPC_RTYPE_NTSTATUS , cmd_lsa_get_dispname , NULL , PI_LSARPC , NULL , " Get the privilege name " , " " } ,
{ " lsaenumsid " , RPC_RTYPE_NTSTATUS , cmd_lsa_enum_sids , NULL , PI_LSARPC , NULL , " Enumerate the LSA SIDS " , " " } ,
{ " lsacreateaccount " , RPC_RTYPE_NTSTATUS , cmd_lsa_create_account , NULL , PI_LSARPC , NULL , " Create a new lsa account " , " " } ,
{ " lsaenumprivsaccount " , RPC_RTYPE_NTSTATUS , cmd_lsa_enum_privsaccounts , NULL , PI_LSARPC , NULL , " Enumerate the privileges of an SID " , " " } ,
{ " lsaenumacctrights " , RPC_RTYPE_NTSTATUS , cmd_lsa_enum_acct_rights , NULL , PI_LSARPC , NULL , " Enumerate the rights of an SID " , " " } ,
2005-01-15 05:20:30 +03:00
#if 0
{ " lsaaddpriv " , RPC_RTYPE_NTSTATUS , cmd_lsa_add_priv , NULL , PI_LSARPC , " Assign a privilege to a SID " , " " } ,
{ " lsadelpriv " , RPC_RTYPE_NTSTATUS , cmd_lsa_del_priv , NULL , PI_LSARPC , " Revoke a privilege from a SID " , " " } ,
# endif
2005-09-30 21:13:37 +04:00
{ " lsaaddacctrights " , RPC_RTYPE_NTSTATUS , cmd_lsa_add_acct_rights , NULL , PI_LSARPC , NULL , " Add rights to an account " , " " } ,
{ " lsaremoveacctrights " , RPC_RTYPE_NTSTATUS , cmd_lsa_remove_acct_rights , NULL , PI_LSARPC , NULL , " Remove rights from an account " , " " } ,
{ " lsalookupprivvalue " , RPC_RTYPE_NTSTATUS , cmd_lsa_lookup_priv_value , NULL , PI_LSARPC , NULL , " Get a privilege value given its name " , " " } ,
{ " lsaquerysecobj " , RPC_RTYPE_NTSTATUS , cmd_lsa_query_secobj , NULL , PI_LSARPC , NULL , " Query LSA security object " , " " } ,
{ " lsaquerytrustdominfo " , RPC_RTYPE_NTSTATUS , cmd_lsa_query_trustdominfo , NULL , PI_LSARPC , NULL , " Query LSA trusted domains info (given a SID) " , " " } ,
{ " lsaquerytrustdominfobyname " , RPC_RTYPE_NTSTATUS , cmd_lsa_query_trustdominfobyname , NULL , PI_LSARPC , NULL , " Query LSA trusted domains info (given a name), only works for Windows > 2k " , " " } ,
{ " lsaquerytrustdominfobysid " , RPC_RTYPE_NTSTATUS , cmd_lsa_query_trustdominfobysid , NULL , PI_LSARPC , NULL , " Query LSA trusted domains info (given a SID) " , " " } ,
2001-07-20 08:38:58 +04:00
{ NULL }
2001-01-12 01:49:30 +03:00
} ;
2005-01-15 05:20:30 +03:00