2008-06-02 17:34:53 +02:00
/*
* Unix SMB / CIFS implementation .
* NetApi LocalGroup Support
* Copyright ( C ) Guenther Deschner 2008
*
* 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 3 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 , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# include "librpc/gen_ndr/libnetapi.h"
# include "lib/netapi/netapi.h"
# include "lib/netapi/netapi_private.h"
# include "lib/netapi/libnetapi.h"
2008-06-03 00:41:36 +02:00
static WERROR libnetapi_samr_lookup_and_open_alias ( TALLOC_CTX * mem_ctx ,
struct rpc_pipe_client * pipe_cli ,
struct policy_handle * domain_handle ,
2008-07-18 16:24:02 +02:00
const char * group_name ,
2008-06-03 00:41:36 +02:00
uint32_t access_rights ,
struct policy_handle * alias_handle )
{
NTSTATUS status ;
WERROR werr ;
2008-07-18 16:24:02 +02:00
struct lsa_String lsa_account_name ;
2008-06-03 00:41:36 +02:00
struct samr_Ids user_rids , name_types ;
2008-07-18 16:24:02 +02:00
init_lsa_String ( & lsa_account_name , group_name ) ;
2008-06-03 00:41:36 +02:00
status = rpccli_samr_LookupNames ( pipe_cli , mem_ctx ,
domain_handle ,
1 ,
2008-07-18 16:24:02 +02:00
& lsa_account_name ,
2008-06-03 00:41:36 +02:00
& user_rids ,
& name_types ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
switch ( name_types . ids [ 0 ] ) {
case SID_NAME_ALIAS :
case SID_NAME_WKN_GRP :
break ;
default :
return WERR_INVALID_DATATYPE ;
}
status = rpccli_samr_OpenAlias ( pipe_cli , mem_ctx ,
domain_handle ,
access_rights ,
user_rids . ids [ 0 ] ,
alias_handle ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
werr = WERR_OK ;
done :
return werr ;
}
2008-06-02 17:34:53 +02:00
/****************************************************************
2008-07-18 15:01:21 +02:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static NTSTATUS libnetapi_samr_open_alias_queryinfo ( TALLOC_CTX * mem_ctx ,
struct rpc_pipe_client * pipe_cli ,
struct policy_handle * handle ,
uint32_t rid ,
uint32_t access_rights ,
enum samr_AliasInfoEnum level ,
union samr_AliasInfo * * alias_info )
{
NTSTATUS status ;
struct policy_handle alias_handle ;
union samr_AliasInfo * _alias_info = NULL ;
ZERO_STRUCT ( alias_handle ) ;
status = rpccli_samr_OpenAlias ( pipe_cli , mem_ctx ,
handle ,
access_rights ,
rid ,
& alias_handle ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto done ;
}
status = rpccli_samr_QueryAliasInfo ( pipe_cli , mem_ctx ,
& alias_handle ,
level ,
& _alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
goto done ;
}
* alias_info = _alias_info ;
done :
if ( is_valid_policy_hnd ( & alias_handle ) ) {
rpccli_samr_Close ( pipe_cli , mem_ctx , & alias_handle ) ;
}
return status ;
}
/****************************************************************
2008-06-02 17:34:53 +02:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupAdd_r ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupAdd * r )
{
2008-06-02 19:02:52 +02:00
struct cli_state * cli = NULL ;
struct rpc_pipe_client * pipe_cli = NULL ;
NTSTATUS status ;
WERROR werr ;
struct lsa_String lsa_account_name ;
struct policy_handle connect_handle , domain_handle , builtin_handle , alias_handle ;
struct dom_sid2 * domain_sid = NULL ;
uint32_t rid ;
2008-06-03 01:37:55 +02:00
struct LOCALGROUP_INFO_0 * info0 = NULL ;
struct LOCALGROUP_INFO_1 * info1 = NULL ;
2008-06-02 19:02:52 +02:00
const char * alias_name = NULL ;
if ( ! r - > in . buf ) {
return WERR_INVALID_PARAM ;
}
switch ( r - > in . level ) {
case 0 :
info0 = ( struct LOCALGROUP_INFO_0 * ) r - > in . buf ;
alias_name = info0 - > lgrpi0_name ;
break ;
case 1 :
info1 = ( struct LOCALGROUP_INFO_1 * ) r - > in . buf ;
alias_name = info1 - > lgrpi1_name ;
break ;
default :
werr = WERR_UNKNOWN_LEVEL ;
goto done ;
}
ZERO_STRUCT ( connect_handle ) ;
ZERO_STRUCT ( builtin_handle ) ;
ZERO_STRUCT ( domain_handle ) ;
ZERO_STRUCT ( alias_handle ) ;
werr = libnetapi_open_ipc_connection ( ctx , r - > in . server_name , & cli ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-07-20 17:59:30 +02:00
werr = libnetapi_open_pipe ( ctx , cli , & ndr_table_samr . syntax_id ,
& pipe_cli ) ;
2008-06-02 19:02:52 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-06-03 00:13:59 +02:00
werr = libnetapi_samr_open_builtin_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& builtin_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 19:02:52 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& builtin_handle ,
2008-07-18 16:24:02 +02:00
alias_name ,
2008-06-03 00:42:00 +02:00
SAMR_ALIAS_ACCESS_LOOKUP_INFO ,
& alias_handle ) ;
2008-06-02 19:02:52 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
}
2008-06-02 19:02:52 +02:00
2008-06-03 00:42:00 +02:00
if ( W_ERROR_IS_OK ( werr ) ) {
werr = WERR_ALIAS_EXISTS ;
goto done ;
}
2008-06-02 23:55:45 +02:00
werr = libnetapi_samr_open_domain ( ctx , pipe_cli ,
SAMR_ACCESS_ENUM_DOMAINS |
SAMR_ACCESS_OPEN_DOMAIN ,
SAMR_DOMAIN_ACCESS_CREATE_ALIAS |
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& domain_handle ,
& domain_sid ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 19:02:52 +02:00
goto done ;
}
2008-07-18 20:10:37 +02:00
init_lsa_String ( & lsa_account_name , alias_name ) ;
2008-06-02 19:02:52 +02:00
status = rpccli_samr_CreateDomAlias ( pipe_cli , ctx ,
& domain_handle ,
& lsa_account_name ,
SEC_STD_DELETE |
SAMR_ALIAS_ACCESS_SET_INFO ,
& alias_handle ,
& rid ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
if ( r - > in . level = = 1 ) {
union samr_AliasInfo alias_info ;
init_lsa_String ( & alias_info . description , info1 - > lgrpi1_comment ) ;
status = rpccli_samr_SetAliasInfo ( pipe_cli , ctx ,
& alias_handle ,
ALIASINFODESCRIPTION ,
& alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
}
werr = WERR_OK ;
done :
if ( ! cli ) {
return werr ;
}
if ( is_valid_policy_hnd ( & alias_handle ) ) {
rpccli_samr_Close ( pipe_cli , ctx , & alias_handle ) ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
libnetapi_samr_close_connect_handle ( ctx , & connect_handle ) ;
2008-06-02 19:02:52 +02:00
}
return werr ;
2008-06-02 17:34:53 +02:00
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupAdd_l ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupAdd * r )
{
2008-06-02 19:02:52 +02:00
return NetLocalGroupAdd_r ( ctx , r ) ;
2008-06-02 17:34:53 +02:00
}
2008-06-02 19:20:25 +02:00
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupDel_r ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupDel * r )
{
2008-06-02 19:44:32 +02:00
struct cli_state * cli = NULL ;
struct rpc_pipe_client * pipe_cli = NULL ;
NTSTATUS status ;
WERROR werr ;
struct policy_handle connect_handle , domain_handle , builtin_handle , alias_handle ;
struct dom_sid2 * domain_sid = NULL ;
if ( ! r - > in . group_name ) {
return WERR_INVALID_PARAM ;
}
ZERO_STRUCT ( connect_handle ) ;
ZERO_STRUCT ( builtin_handle ) ;
ZERO_STRUCT ( domain_handle ) ;
ZERO_STRUCT ( alias_handle ) ;
werr = libnetapi_open_ipc_connection ( ctx , r - > in . server_name , & cli ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-07-20 17:59:30 +02:00
werr = libnetapi_open_pipe ( ctx , cli , & ndr_table_samr . syntax_id ,
& pipe_cli ) ;
2008-06-02 19:44:32 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-06-03 00:13:59 +02:00
werr = libnetapi_samr_open_builtin_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& builtin_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 19:44:32 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& builtin_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SEC_STD_DELETE ,
& alias_handle ) ;
2008-06-02 19:44:32 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
}
2008-06-02 19:44:32 +02:00
2008-06-03 00:42:00 +02:00
if ( W_ERROR_IS_OK ( werr ) ) {
goto delete_alias ;
}
2008-06-02 23:55:45 +02:00
werr = libnetapi_samr_open_domain ( ctx , pipe_cli ,
SAMR_ACCESS_ENUM_DOMAINS |
SAMR_ACCESS_OPEN_DOMAIN ,
SAMR_DOMAIN_ACCESS_CREATE_ALIAS |
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& domain_handle ,
& domain_sid ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 19:44:32 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& domain_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SEC_STD_DELETE ,
& alias_handle ) ;
2008-06-02 19:44:32 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
}
2008-06-03 00:42:00 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 19:44:32 +02:00
goto done ;
}
delete_alias :
status = rpccli_samr_DeleteDomAlias ( pipe_cli , ctx ,
& alias_handle ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
ZERO_STRUCT ( alias_handle ) ;
werr = WERR_OK ;
done :
if ( ! cli ) {
return werr ;
}
if ( is_valid_policy_hnd ( & alias_handle ) ) {
rpccli_samr_Close ( pipe_cli , ctx , & alias_handle ) ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
libnetapi_samr_close_connect_handle ( ctx , & connect_handle ) ;
2008-06-02 19:44:32 +02:00
}
return werr ;
2008-06-02 19:20:25 +02:00
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupDel_l ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupDel * r )
{
2008-06-02 19:44:32 +02:00
return NetLocalGroupDel_r ( ctx , r ) ;
2008-06-02 19:20:25 +02:00
}
2008-06-02 20:20:27 +02:00
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-06-02 22:20:14 +02:00
static WERROR map_alias_info_to_buffer ( TALLOC_CTX * mem_ctx ,
2008-07-18 15:10:43 +02:00
const char * alias_name ,
2008-06-02 22:20:14 +02:00
struct samr_AliasInfoAll * info ,
uint32_t level ,
2008-07-18 15:10:43 +02:00
uint32_t * entries_read ,
2008-06-02 22:20:14 +02:00
uint8_t * * buffer )
{
struct LOCALGROUP_INFO_0 g0 ;
struct LOCALGROUP_INFO_1 g1 ;
struct LOCALGROUP_INFO_1002 g1002 ;
switch ( level ) {
case 0 :
2008-07-18 15:10:43 +02:00
g0 . lgrpi0_name = talloc_strdup ( mem_ctx , alias_name ) ;
W_ERROR_HAVE_NO_MEMORY ( g0 . lgrpi0_name ) ;
2008-06-02 22:20:14 +02:00
2008-07-18 15:10:43 +02:00
ADD_TO_ARRAY ( mem_ctx , struct LOCALGROUP_INFO_0 , g0 ,
( struct LOCALGROUP_INFO_0 * * ) buffer , entries_read ) ;
2008-06-02 22:20:14 +02:00
break ;
case 1 :
2008-07-18 15:10:43 +02:00
g1 . lgrpi1_name = talloc_strdup ( mem_ctx , alias_name ) ;
g1 . lgrpi1_comment = talloc_strdup ( mem_ctx , info - > description . string ) ;
W_ERROR_HAVE_NO_MEMORY ( g1 . lgrpi1_name ) ;
2008-06-02 22:20:14 +02:00
2008-07-18 15:10:43 +02:00
ADD_TO_ARRAY ( mem_ctx , struct LOCALGROUP_INFO_1 , g1 ,
( struct LOCALGROUP_INFO_1 * * ) buffer , entries_read ) ;
2008-06-02 22:20:14 +02:00
break ;
case 1002 :
2008-07-18 15:10:43 +02:00
g1002 . lgrpi1002_comment = talloc_strdup ( mem_ctx , info - > description . string ) ;
2008-06-02 22:20:14 +02:00
2008-07-18 15:10:43 +02:00
ADD_TO_ARRAY ( mem_ctx , struct LOCALGROUP_INFO_1002 , g1002 ,
( struct LOCALGROUP_INFO_1002 * * ) buffer , entries_read ) ;
2008-06-02 22:20:14 +02:00
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
return WERR_OK ;
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-06-02 20:20:27 +02:00
WERROR NetLocalGroupGetInfo_r ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupGetInfo * r )
{
2008-06-02 22:20:14 +02:00
struct cli_state * cli = NULL ;
struct rpc_pipe_client * pipe_cli = NULL ;
NTSTATUS status ;
WERROR werr ;
struct policy_handle connect_handle , domain_handle , builtin_handle , alias_handle ;
struct dom_sid2 * domain_sid = NULL ;
union samr_AliasInfo * alias_info = NULL ;
2008-07-18 15:10:43 +02:00
uint32_t entries_read = 0 ;
2008-06-02 22:20:14 +02:00
if ( ! r - > in . group_name ) {
return WERR_INVALID_PARAM ;
}
switch ( r - > in . level ) {
case 0 :
case 1 :
case 1002 :
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
ZERO_STRUCT ( connect_handle ) ;
ZERO_STRUCT ( builtin_handle ) ;
ZERO_STRUCT ( domain_handle ) ;
ZERO_STRUCT ( alias_handle ) ;
werr = libnetapi_open_ipc_connection ( ctx , r - > in . server_name , & cli ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-07-20 17:59:30 +02:00
werr = libnetapi_open_pipe ( ctx , cli , & ndr_table_samr . syntax_id ,
& pipe_cli ) ;
2008-06-02 22:20:14 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-06-03 00:13:59 +02:00
werr = libnetapi_samr_open_builtin_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& builtin_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 22:20:14 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& builtin_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SAMR_ALIAS_ACCESS_LOOKUP_INFO ,
& alias_handle ) ;
2008-06-02 22:20:14 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
}
2008-06-02 22:20:14 +02:00
2008-06-03 00:42:00 +02:00
if ( W_ERROR_IS_OK ( werr ) ) {
goto query_alias ;
}
2008-06-02 23:55:45 +02:00
werr = libnetapi_samr_open_domain ( ctx , pipe_cli ,
SAMR_ACCESS_ENUM_DOMAINS |
SAMR_ACCESS_OPEN_DOMAIN ,
SAMR_DOMAIN_ACCESS_CREATE_ALIAS |
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& domain_handle ,
& domain_sid ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 22:20:14 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& domain_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SAMR_ALIAS_ACCESS_LOOKUP_INFO ,
& alias_handle ) ;
2008-06-02 22:20:14 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
}
2008-06-03 00:42:00 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 22:20:14 +02:00
goto done ;
}
query_alias :
status = rpccli_samr_QueryAliasInfo ( pipe_cli , ctx ,
& alias_handle ,
ALIASINFOALL ,
& alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
2008-07-18 15:10:43 +02:00
werr = map_alias_info_to_buffer ( ctx ,
r - > in . group_name ,
& alias_info - > all ,
r - > in . level , & entries_read ,
r - > out . buf ) ;
2008-06-02 22:20:14 +02:00
done :
if ( ! cli ) {
return werr ;
}
if ( is_valid_policy_hnd ( & alias_handle ) ) {
rpccli_samr_Close ( pipe_cli , ctx , & alias_handle ) ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
libnetapi_samr_close_connect_handle ( ctx , & connect_handle ) ;
2008-06-02 22:20:14 +02:00
}
return werr ;
2008-06-02 20:20:27 +02:00
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupGetInfo_l ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupGetInfo * r )
{
2008-06-02 22:20:14 +02:00
return NetLocalGroupGetInfo_r ( ctx , r ) ;
2008-06-02 20:20:27 +02:00
}
2008-06-02 22:29:32 +02:00
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-06-02 23:36:25 +02:00
static WERROR map_buffer_to_alias_info ( TALLOC_CTX * mem_ctx ,
uint32_t level ,
uint8_t * buffer ,
enum samr_AliasInfoEnum * alias_level ,
union samr_AliasInfo * * alias_info )
{
struct LOCALGROUP_INFO_0 * info0 ;
struct LOCALGROUP_INFO_1 * info1 ;
struct LOCALGROUP_INFO_1002 * info1002 ;
union samr_AliasInfo * info = NULL ;
info = TALLOC_ZERO_P ( mem_ctx , union samr_AliasInfo ) ;
W_ERROR_HAVE_NO_MEMORY ( info ) ;
switch ( level ) {
case 0 :
info0 = ( struct LOCALGROUP_INFO_0 * ) buffer ;
init_lsa_String ( & info - > name , info0 - > lgrpi0_name ) ;
* alias_level = ALIASINFONAME ;
break ;
case 1 :
info1 = ( struct LOCALGROUP_INFO_1 * ) buffer ;
/* group name will be ignored */
init_lsa_String ( & info - > description , info1 - > lgrpi1_comment ) ;
* alias_level = ALIASINFODESCRIPTION ;
break ;
case 1002 :
info1002 = ( struct LOCALGROUP_INFO_1002 * ) buffer ;
init_lsa_String ( & info - > description , info1002 - > lgrpi1002_comment ) ;
* alias_level = ALIASINFODESCRIPTION ;
break ;
}
* alias_info = info ;
return WERR_OK ;
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-06-02 22:29:32 +02:00
WERROR NetLocalGroupSetInfo_r ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupSetInfo * r )
{
2008-06-02 23:36:25 +02:00
struct cli_state * cli = NULL ;
struct rpc_pipe_client * pipe_cli = NULL ;
NTSTATUS status ;
WERROR werr ;
struct lsa_String lsa_account_name ;
struct policy_handle connect_handle , domain_handle , builtin_handle , alias_handle ;
struct dom_sid2 * domain_sid = NULL ;
2008-06-03 01:37:55 +02:00
enum samr_AliasInfoEnum alias_level = 0 ;
2008-06-02 23:36:25 +02:00
union samr_AliasInfo * alias_info = NULL ;
if ( ! r - > in . group_name ) {
return WERR_INVALID_PARAM ;
}
switch ( r - > in . level ) {
case 0 :
case 1 :
case 1002 :
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
ZERO_STRUCT ( connect_handle ) ;
ZERO_STRUCT ( builtin_handle ) ;
ZERO_STRUCT ( domain_handle ) ;
ZERO_STRUCT ( alias_handle ) ;
werr = libnetapi_open_ipc_connection ( ctx , r - > in . server_name , & cli ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-07-20 17:59:30 +02:00
werr = libnetapi_open_pipe ( ctx , cli , & ndr_table_samr . syntax_id ,
& pipe_cli ) ;
2008-06-02 23:36:25 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-06-03 00:13:59 +02:00
werr = libnetapi_samr_open_builtin_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& builtin_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 23:36:25 +02:00
goto done ;
}
init_lsa_String ( & lsa_account_name , r - > in . group_name ) ;
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& builtin_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SAMR_ALIAS_ACCESS_SET_INFO ,
& alias_handle ) ;
2008-06-02 23:36:25 +02:00
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
}
2008-06-02 23:36:25 +02:00
2008-06-03 00:42:00 +02:00
if ( W_ERROR_IS_OK ( werr ) ) {
goto set_alias ;
}
2008-06-02 23:55:45 +02:00
werr = libnetapi_samr_open_domain ( ctx , pipe_cli ,
SAMR_ACCESS_ENUM_DOMAINS |
SAMR_ACCESS_OPEN_DOMAIN ,
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& domain_handle ,
& domain_sid ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 23:36:25 +02:00
goto done ;
}
2008-06-03 00:42:00 +02:00
werr = libnetapi_samr_lookup_and_open_alias ( ctx , pipe_cli ,
& domain_handle ,
2008-07-18 16:24:02 +02:00
r - > in . group_name ,
2008-06-03 00:42:00 +02:00
SAMR_ALIAS_ACCESS_SET_INFO ,
& alias_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
2008-06-02 23:36:25 +02:00
goto done ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
}
2008-06-02 23:36:25 +02:00
set_alias :
werr = map_buffer_to_alias_info ( ctx , r - > in . level , r - > in . buf ,
& alias_level , & alias_info ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
status = rpccli_samr_SetAliasInfo ( pipe_cli , ctx ,
& alias_handle ,
alias_level ,
alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
werr = WERR_OK ;
done :
if ( ! cli ) {
return werr ;
}
if ( is_valid_policy_hnd ( & alias_handle ) ) {
rpccli_samr_Close ( pipe_cli , ctx , & alias_handle ) ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
libnetapi_samr_close_connect_handle ( ctx , & connect_handle ) ;
2008-06-02 23:36:25 +02:00
}
return werr ;
2008-06-02 22:29:32 +02:00
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupSetInfo_l ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupSetInfo * r )
{
2008-06-02 23:36:25 +02:00
return NetLocalGroupSetInfo_r ( ctx , r ) ;
2008-06-02 22:29:32 +02:00
}
2008-07-18 01:23:26 +02:00
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupEnum_r ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupEnum * r )
{
2008-07-18 15:11:08 +02:00
struct cli_state * cli = NULL ;
struct rpc_pipe_client * pipe_cli = NULL ;
NTSTATUS status ;
WERROR werr ;
struct policy_handle connect_handle , domain_handle , builtin_handle , alias_handle ;
struct dom_sid2 * domain_sid = NULL ;
uint32_t entries_read = 0 ;
union samr_DomainInfo * domain_info = NULL ;
union samr_DomainInfo * builtin_info = NULL ;
struct samr_SamArray * domain_sam_array = NULL ;
struct samr_SamArray * builtin_sam_array = NULL ;
int i ;
if ( ! r - > out . buffer ) {
return WERR_INVALID_PARAM ;
}
switch ( r - > in . level ) {
case 0 :
case 1 :
break ;
default :
return WERR_UNKNOWN_LEVEL ;
}
2008-07-18 20:10:37 +02:00
if ( r - > out . total_entries ) {
* r - > out . total_entries = 0 ;
}
if ( r - > out . entries_read ) {
* r - > out . entries_read = 0 ;
}
2008-07-18 15:11:08 +02:00
ZERO_STRUCT ( connect_handle ) ;
ZERO_STRUCT ( builtin_handle ) ;
ZERO_STRUCT ( domain_handle ) ;
ZERO_STRUCT ( alias_handle ) ;
werr = libnetapi_open_ipc_connection ( ctx , r - > in . server_name , & cli ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
2008-07-20 17:59:30 +02:00
werr = libnetapi_open_pipe ( ctx , cli , & ndr_table_samr . syntax_id ,
& pipe_cli ) ;
2008-07-18 15:11:08 +02:00
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
werr = libnetapi_samr_open_builtin_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_LOOKUP_INFO_2 |
SAMR_DOMAIN_ACCESS_ENUM_ACCOUNTS |
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& builtin_handle ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
werr = libnetapi_samr_open_domain ( ctx , pipe_cli ,
SAMR_ACCESS_OPEN_DOMAIN |
SAMR_ACCESS_ENUM_DOMAINS ,
SAMR_DOMAIN_ACCESS_LOOKUP_INFO_2 |
SAMR_DOMAIN_ACCESS_ENUM_ACCOUNTS |
SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ,
& connect_handle ,
& domain_handle ,
& domain_sid ) ;
if ( ! W_ERROR_IS_OK ( werr ) ) {
goto done ;
}
status = rpccli_samr_QueryDomainInfo ( pipe_cli , ctx ,
& builtin_handle ,
2 ,
& builtin_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
2008-07-18 20:10:37 +02:00
if ( r - > out . total_entries ) {
* r - > out . total_entries + = builtin_info - > info2 . num_aliases ;
}
2008-07-18 15:11:08 +02:00
status = rpccli_samr_QueryDomainInfo ( pipe_cli , ctx ,
& domain_handle ,
2 ,
& domain_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
2008-07-18 20:10:37 +02:00
if ( r - > out . total_entries ) {
* r - > out . total_entries + = domain_info - > info2 . num_aliases ;
}
2008-07-18 15:11:08 +02:00
status = rpccli_samr_EnumDomainAliases ( pipe_cli , ctx ,
& builtin_handle ,
r - > in . resume_handle ,
& builtin_sam_array ,
r - > in . prefmaxlen ,
& entries_read ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
for ( i = 0 ; i < builtin_sam_array - > count ; i + + ) {
union samr_AliasInfo * alias_info = NULL ;
if ( r - > in . level = = 1 ) {
status = libnetapi_samr_open_alias_queryinfo ( ctx , pipe_cli ,
& builtin_handle ,
builtin_sam_array - > entries [ i ] . idx ,
SAMR_ALIAS_ACCESS_LOOKUP_INFO ,
ALIASINFOALL ,
& alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
}
werr = map_alias_info_to_buffer ( ctx ,
builtin_sam_array - > entries [ i ] . name . string ,
alias_info ? & alias_info - > all : NULL ,
r - > in . level ,
r - > out . entries_read ,
r - > out . buffer ) ;
}
status = rpccli_samr_EnumDomainAliases ( pipe_cli , ctx ,
& domain_handle ,
r - > in . resume_handle ,
& domain_sam_array ,
r - > in . prefmaxlen ,
& entries_read ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
for ( i = 0 ; i < domain_sam_array - > count ; i + + ) {
union samr_AliasInfo * alias_info = NULL ;
if ( r - > in . level = = 1 ) {
status = libnetapi_samr_open_alias_queryinfo ( ctx , pipe_cli ,
& domain_handle ,
domain_sam_array - > entries [ i ] . idx ,
SAMR_ALIAS_ACCESS_LOOKUP_INFO ,
ALIASINFOALL ,
& alias_info ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
werr = ntstatus_to_werror ( status ) ;
goto done ;
}
}
werr = map_alias_info_to_buffer ( ctx ,
domain_sam_array - > entries [ i ] . name . string ,
alias_info ? & alias_info - > all : NULL ,
r - > in . level ,
r - > out . entries_read ,
r - > out . buffer ) ;
}
done :
if ( ! cli ) {
return werr ;
}
2008-07-17 22:44:24 +02:00
if ( ctx - > disable_policy_handle_cache ) {
libnetapi_samr_close_domain_handle ( ctx , & domain_handle ) ;
libnetapi_samr_close_builtin_handle ( ctx , & builtin_handle ) ;
libnetapi_samr_close_connect_handle ( ctx , & connect_handle ) ;
}
2008-07-18 15:11:08 +02:00
return werr ;
2008-07-18 01:23:26 +02:00
}
/****************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
WERROR NetLocalGroupEnum_l ( struct libnetapi_ctx * ctx ,
struct NetLocalGroupEnum * r )
{
return WERR_NOT_SUPPORTED ;
}