2003-10-06 01:24:48 +00:00
/*
Unix SMB / CIFS implementation .
Privileges handling functions
2005-02-17 22:46:41 +00:00
Copyright ( C ) Jean François Micouleau 1998 - 2001
2003-10-06 01:24:48 +00:00
Copyright ( C ) Simo Sorce 2002 - 2003
2005-03-10 18:50:47 +00:00
Copyright ( C ) Gerald ( Jerry ) Carter 2005
2007-06-14 11:29:35 +00:00
Copyright ( C ) Michael Adam 2007
2003-10-06 01:24:48 +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
2003-10-06 01:24:48 +00:00
( 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
2007-07-10 00:52:41 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2003-10-06 01:24:48 +00:00
*/
2005-01-13 18:20:37 +00:00
2003-10-06 01:24:48 +00:00
# include "includes.h"
2005-01-13 18:20:37 +00:00
# define PRIVPREFIX "PRIV_"
2003-10-06 01:24:48 +00:00
2005-03-22 15:39:24 +00:00
typedef struct {
2005-10-18 03:24:00 +00:00
size_t count ;
2005-03-22 15:39:24 +00:00
DOM_SID * list ;
} SID_LIST ;
typedef struct {
2007-09-08 20:30:51 +00:00
TALLOC_CTX * mem_ctx ;
2005-01-17 15:23:11 +00:00
SE_PRIV privilege ;
2005-01-13 18:20:37 +00:00
SID_LIST sids ;
} PRIV_SID_LIST ;
2003-10-06 01:24:48 +00:00
2003-12-04 04:31:29 +00:00
2007-10-18 17:40:25 -07:00
static bool get_privileges ( const DOM_SID * sid , SE_PRIV * mask )
2005-01-13 18:20:37 +00:00
{
2008-03-28 12:09:56 +01:00
struct db_context * db = get_account_pol_db ( ) ;
2007-12-15 22:00:39 +01:00
fstring tmp , keystr ;
2007-03-27 09:59:32 +00:00
TDB_DATA data ;
2005-01-17 20:27:29 +00:00
/* Fail if the admin has not enable privileges */
if ( ! lp_enable_privileges ( ) ) {
return False ;
}
2005-01-13 18:20:37 +00:00
2008-03-28 12:09:56 +01:00
if ( db = = NULL )
2005-01-15 02:20:30 +00:00
return False ;
2003-12-04 04:31:29 +00:00
2005-01-17 15:23:11 +00:00
/* PRIV_<SID> (NULL terminated) as the key */
2007-12-15 22:47:30 +01:00
fstr_sprintf ( keystr , " %s%s " , PRIVPREFIX , sid_to_fstring ( tmp , sid ) ) ;
2003-10-06 01:24:48 +00:00
2008-03-28 12:09:56 +01:00
data = dbwrap_fetch_bystring ( db , talloc_tos ( ) , keystr ) ;
2005-01-17 15:23:11 +00:00
if ( ! data . dptr ) {
2007-12-15 21:11:36 +01:00
DEBUG ( 3 , ( " get_privileges: No privileges assigned to SID "
" [%s] \n " , sid_string_dbg ( sid ) ) ) ;
2005-01-15 02:20:30 +00:00
return False ;
2005-01-13 18:20:37 +00:00
}
2003-10-06 01:24:48 +00:00
2005-01-17 15:23:11 +00:00
SMB_ASSERT ( data . dsize = = sizeof ( SE_PRIV ) ) ;
se_priv_copy ( mask , ( SE_PRIV * ) data . dptr ) ;
2008-03-28 12:09:56 +01:00
TALLOC_FREE ( data . dptr ) ;
2005-02-21 11:21:11 +00:00
2005-01-15 02:20:30 +00:00
return True ;
2003-10-06 01:24:48 +00:00
}
2005-01-13 18:20:37 +00:00
/***************************************************************************
Store the privilege mask ( set ) for a given SID
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2003-10-06 01:24:48 +00:00
2007-10-18 17:40:25 -07:00
static bool set_privileges ( const DOM_SID * sid , SE_PRIV * mask )
2005-01-13 18:20:37 +00:00
{
2008-03-28 12:09:56 +01:00
struct db_context * db = get_account_pol_db ( ) ;
2007-12-15 22:00:39 +01:00
fstring tmp , keystr ;
2007-03-27 09:59:32 +00:00
TDB_DATA data ;
2005-01-13 18:20:37 +00:00
2005-01-25 23:32:19 +00:00
if ( ! lp_enable_privileges ( ) )
return False ;
2008-03-28 12:09:56 +01:00
if ( db = = NULL )
2005-01-13 18:20:37 +00:00
return False ;
2003-10-06 01:24:48 +00:00
2005-09-23 15:23:16 +00:00
if ( ! sid | | ( sid - > num_auths = = 0 ) ) {
DEBUG ( 0 , ( " set_privileges: Refusing to store empty SID! \n " ) ) ;
return False ;
}
2005-01-17 15:23:11 +00:00
/* PRIV_<SID> (NULL terminated) as the key */
2007-12-15 22:47:30 +01:00
fstr_sprintf ( keystr , " %s%s " , PRIVPREFIX , sid_to_fstring ( tmp , sid ) ) ;
2005-01-17 15:23:11 +00:00
/* no packing. static size structure, just write it out */
2007-03-29 09:35:51 +00:00
data . dptr = ( uint8 * ) mask ;
2005-01-17 15:23:11 +00:00
data . dsize = sizeof ( SE_PRIV ) ;
2003-10-06 01:24:48 +00:00
2008-03-28 12:09:56 +01:00
return NT_STATUS_IS_OK ( dbwrap_store_bystring ( db , keystr , data ,
TDB_REPLACE ) ) ;
2003-10-06 01:24:48 +00:00
}
2005-01-13 18:20:37 +00:00
/*********************************************************************
2007-08-14 20:11:47 +00:00
get a list of all privileges for all sids in the list
2005-01-13 18:20:37 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool get_privileges_for_sids ( SE_PRIV * privileges , DOM_SID * slist , int scount )
2003-10-06 01:24:48 +00:00
{
2005-01-17 15:23:11 +00:00
SE_PRIV mask ;
2005-01-13 18:20:37 +00:00
int i ;
2007-10-18 17:40:25 -07:00
bool found = False ;
2005-01-17 15:23:11 +00:00
se_priv_copy ( privileges , & se_priv_none ) ;
2005-01-13 18:20:37 +00:00
for ( i = 0 ; i < scount ; i + + ) {
/* don't add unless we actually have a privilege assigned */
2003-10-06 01:24:48 +00:00
2005-01-17 15:23:11 +00:00
if ( ! get_privileges ( & slist [ i ] , & mask ) )
2005-01-13 18:20:37 +00:00
continue ;
2005-01-15 02:20:30 +00:00
2007-12-15 21:11:36 +01:00
DEBUG ( 5 , ( " get_privileges_for_sids: sid = %s \n Privilege "
" set: \n " , sid_string_dbg ( & slist [ i ] ) ) ) ;
2005-01-17 15:23:11 +00:00
dump_se_priv ( DBGC_ALL , 5 , & mask ) ;
2005-01-13 18:20:37 +00:00
2005-01-17 15:23:11 +00:00
se_priv_add ( privileges , & mask ) ;
found = True ;
2005-01-13 18:20:37 +00:00
}
2005-01-17 15:23:11 +00:00
return found ;
2003-10-06 01:24:48 +00:00
}
2005-01-13 18:20:37 +00:00
/*********************************************************************
2008-03-28 12:09:56 +01:00
traversal functions for privilege_enumerate_accounts
2005-01-13 18:20:37 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2008-03-28 12:09:56 +01:00
static int priv_traverse_fn ( struct db_record * rec , void * state )
2003-10-06 01:24:48 +00:00
{
2006-07-31 04:30:55 +00:00
PRIV_SID_LIST * priv = ( PRIV_SID_LIST * ) state ;
2005-01-13 18:20:37 +00:00
int prefixlen = strlen ( PRIVPREFIX ) ;
DOM_SID sid ;
fstring sid_string ;
2005-01-17 15:23:11 +00:00
/* easy check first */
2008-03-28 12:09:56 +01:00
if ( rec - > value . dsize ! = sizeof ( SE_PRIV ) )
2005-01-17 15:23:11 +00:00
return 0 ;
2003-10-06 01:24:48 +00:00
2005-01-13 18:20:37 +00:00
/* check we have a PRIV_+SID entry */
2003-10-06 01:24:48 +00:00
2008-03-28 12:09:56 +01:00
if ( strncmp ( ( char * ) rec - > key . dptr , PRIVPREFIX , prefixlen ) ! = 0 )
2005-01-13 18:20:37 +00:00
return 0 ;
/* check to see if we are looking for a particular privilege */
2003-10-06 01:24:48 +00:00
2005-01-17 15:23:11 +00:00
if ( ! se_priv_equal ( & priv - > privilege , & se_priv_none ) ) {
SE_PRIV mask ;
2008-03-28 12:09:56 +01:00
se_priv_copy ( & mask , ( SE_PRIV * ) rec - > value . dptr ) ;
2005-01-13 18:20:37 +00:00
/* if the SID does not have the specified privilege
then just return */
2005-01-17 15:23:11 +00:00
if ( ! is_privilege_assigned ( & mask , & priv - > privilege ) )
2005-01-13 18:20:37 +00:00
return 0 ;
}
2008-03-28 12:09:56 +01:00
fstrcpy ( sid_string , ( char * ) & ( rec - > key . dptr [ strlen ( PRIVPREFIX ) ] ) ) ;
2003-10-06 01:24:48 +00:00
2005-09-23 15:23:16 +00:00
/* this is a last ditch safety check to preventing returning
and invalid SID ( i ' ve somehow run into this on development branches ) */
if ( strcmp ( " S-0-0 " , sid_string ) = = 0 )
return 0 ;
2005-01-13 18:20:37 +00:00
if ( ! string_to_sid ( & sid , sid_string ) ) {
DEBUG ( 0 , ( " travsersal_fn_enum__acct: Could not convert SID [%s] \n " ,
sid_string ) ) ;
return 0 ;
2003-10-06 01:24:48 +00:00
}
2008-01-09 00:11:31 +01:00
if ( ! NT_STATUS_IS_OK ( add_sid_to_array ( priv - > mem_ctx , & sid ,
& priv - > sids . list ,
& priv - > sids . count ) ) )
{
2006-12-09 02:58:18 +00:00
return 0 ;
}
2005-01-13 18:20:37 +00:00
return 0 ;
2003-10-06 01:24:48 +00:00
}
2005-01-13 18:20:37 +00:00
/*********************************************************************
Retreive list of privileged SIDs ( for _lsa_enumerate_accounts ( )
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS privilege_enumerate_accounts ( DOM_SID * * sids , int * num_sids )
2003-10-06 01:24:48 +00:00
{
2008-03-28 12:09:56 +01:00
struct db_context * db = get_account_pol_db ( ) ;
2005-01-13 18:20:37 +00:00
PRIV_SID_LIST priv ;
2008-03-28 12:09:56 +01:00
if ( db = = NULL ) {
2006-06-20 01:32:50 +00:00
return NT_STATUS_ACCESS_DENIED ;
}
2005-01-13 18:20:37 +00:00
ZERO_STRUCT ( priv ) ;
2005-01-17 15:23:11 +00:00
se_priv_copy ( & priv . privilege , & se_priv_none ) ;
2003-10-06 01:24:48 +00:00
2008-03-28 12:09:56 +01:00
db - > traverse_read ( db , priv_traverse_fn , & priv ) ;
2003-10-06 01:24:48 +00:00
2005-01-13 18:20:37 +00:00
/* give the memory away; caller will free */
* sids = priv . sids . list ;
* num_sids = priv . sids . count ;
2003-10-06 01:24:48 +00:00
2005-01-13 18:20:37 +00:00
return NT_STATUS_OK ;
}
2007-09-08 20:30:51 +00:00
/*********************************************************************
Retrieve list of SIDs granted a particular privilege
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS privilege_enum_sids ( const SE_PRIV * mask , TALLOC_CTX * mem_ctx ,
DOM_SID * * sids , int * num_sids )
{
2008-03-28 12:09:56 +01:00
struct db_context * db = get_account_pol_db ( ) ;
2007-09-08 20:30:51 +00:00
PRIV_SID_LIST priv ;
2008-03-28 12:09:56 +01:00
if ( db = = NULL ) {
2007-09-08 20:30:51 +00:00
return NT_STATUS_ACCESS_DENIED ;
}
ZERO_STRUCT ( priv ) ;
se_priv_copy ( & priv . privilege , mask ) ;
priv . mem_ctx = mem_ctx ;
2008-03-28 12:09:56 +01:00
db - > traverse_read ( db , priv_traverse_fn , & priv ) ;
2007-09-08 20:30:51 +00:00
/* give the memory away; caller will free */
* sids = priv . sids . list ;
* num_sids = priv . sids . count ;
return NT_STATUS_OK ;
}
2005-01-13 18:20:37 +00:00
/***************************************************************************
Add privilege to sid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool grant_privilege ( const DOM_SID * sid , const SE_PRIV * priv_mask )
2005-01-13 18:20:37 +00:00
{
2005-01-17 15:23:11 +00:00
SE_PRIV old_mask , new_mask ;
2003-10-06 01:24:48 +00:00
2005-07-04 13:19:05 +00:00
ZERO_STRUCT ( old_mask ) ;
ZERO_STRUCT ( new_mask ) ;
2005-01-15 02:20:30 +00:00
if ( get_privileges ( sid , & old_mask ) )
2005-01-17 15:23:11 +00:00
se_priv_copy ( & new_mask , & old_mask ) ;
2005-01-15 02:20:30 +00:00
else
2005-01-17 15:23:11 +00:00
se_priv_copy ( & new_mask , & se_priv_none ) ;
se_priv_add ( & new_mask , priv_mask ) ;
2005-01-13 18:20:37 +00:00
2007-12-15 21:11:36 +01:00
DEBUG ( 10 , ( " grant_privilege: %s \n " , sid_string_dbg ( sid ) ) ) ;
2005-01-17 15:23:11 +00:00
DEBUGADD ( 10 , ( " original privilege mask: \n " ) ) ;
dump_se_priv ( DBGC_ALL , 10 , & old_mask ) ;
2003-10-06 01:24:48 +00:00
2005-01-17 15:23:11 +00:00
DEBUGADD ( 10 , ( " new privilege mask: \n " ) ) ;
dump_se_priv ( DBGC_ALL , 10 , & new_mask ) ;
return set_privileges ( sid , & new_mask ) ;
2005-01-13 18:20:37 +00:00
}
2005-01-15 02:20:30 +00:00
/*********************************************************************
Add a privilege based on its name
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool grant_privilege_by_name ( DOM_SID * sid , const char * name )
2005-01-15 02:20:30 +00:00
{
2007-06-14 11:29:35 +00:00
SE_PRIV mask ;
2005-01-15 02:20:30 +00:00
2007-06-14 11:29:35 +00:00
if ( ! se_priv_from_name ( name , & mask ) ) {
DEBUG ( 3 , ( " grant_privilege_by_name: "
" No Such Privilege Found (%s) \n " , name ) ) ;
return False ;
}
2005-01-15 02:20:30 +00:00
2007-06-14 11:29:35 +00:00
return grant_privilege ( sid , & mask ) ;
2005-01-15 02:20:30 +00:00
}
2005-01-13 18:20:37 +00:00
/***************************************************************************
Remove privilege from sid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool revoke_privilege ( const DOM_SID * sid , const SE_PRIV * priv_mask )
2005-01-13 18:20:37 +00:00
{
2005-01-17 15:23:11 +00:00
SE_PRIV mask ;
2005-01-13 18:20:37 +00:00
2005-01-17 15:23:11 +00:00
/* if the user has no privileges, then we can't revoke any */
if ( ! get_privileges ( sid , & mask ) )
return True ;
2007-12-15 21:11:36 +01:00
DEBUG ( 10 , ( " revoke_privilege: %s \n " , sid_string_dbg ( sid ) ) ) ;
2005-01-13 18:20:37 +00:00
2005-01-17 15:23:11 +00:00
DEBUGADD ( 10 , ( " original privilege mask: \n " ) ) ;
dump_se_priv ( DBGC_ALL , 10 , & mask ) ;
2005-01-13 18:20:37 +00:00
2005-01-17 15:23:11 +00:00
se_priv_remove ( & mask , priv_mask ) ;
2005-01-13 18:20:37 +00:00
2005-01-17 15:23:11 +00:00
DEBUGADD ( 10 , ( " new privilege mask: \n " ) ) ;
dump_se_priv ( DBGC_ALL , 10 , & mask ) ;
return set_privileges ( sid , & mask ) ;
}
/*********************************************************************
Revoke all privileges
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool revoke_all_privileges ( DOM_SID * sid )
2005-01-17 15:23:11 +00:00
{
return revoke_privilege ( sid , & se_priv_all ) ;
2005-01-13 18:20:37 +00:00
}
2005-01-15 02:20:30 +00:00
/*********************************************************************
Add a privilege based on its name
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool revoke_privilege_by_name ( DOM_SID * sid , const char * name )
2005-01-15 02:20:30 +00:00
{
2007-06-14 11:29:35 +00:00
SE_PRIV mask ;
2005-01-15 02:20:30 +00:00
2007-06-14 11:29:35 +00:00
if ( ! se_priv_from_name ( name , & mask ) ) {
DEBUG ( 3 , ( " revoke_privilege_by_name: "
" No Such Privilege Found (%s) \n " , name ) ) ;
return False ;
}
2005-01-15 02:20:30 +00:00
2007-06-14 11:29:35 +00:00
return revoke_privilege ( sid , & mask ) ;
2005-01-15 02:20:30 +00:00
}
2005-01-13 18:20:37 +00:00
/***************************************************************************
Retrieve the SIDs assigned to a given privilege
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS privilege_create_account ( const DOM_SID * sid )
{
2005-01-17 15:23:11 +00:00
return ( grant_privilege ( sid , & se_priv_none ) ? NT_STATUS_OK : NT_STATUS_UNSUCCESSFUL ) ;
2005-01-13 18:20:37 +00:00
}
/****************************************************************************
initialise a privilege list and set the talloc context
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-06-09 15:20:11 +00:00
2005-01-13 18:20:37 +00:00
NTSTATUS privilege_set_init ( PRIVILEGE_SET * priv_set )
{
2005-01-14 08:14:22 +00:00
TALLOC_CTX * mem_ctx ;
2005-01-13 18:20:37 +00:00
ZERO_STRUCTP ( priv_set ) ;
2005-01-14 08:14:22 +00:00
mem_ctx = talloc_init ( " privilege set " ) ;
2005-01-17 20:27:29 +00:00
if ( ! mem_ctx ) {
DEBUG ( 0 , ( " privilege_set_init: failed to initialize talloc ctx! \n " ) ) ;
return NT_STATUS_NO_MEMORY ;
}
2005-01-13 18:20:37 +00:00
priv_set - > mem_ctx = mem_ctx ;
2005-01-17 20:27:29 +00:00
return NT_STATUS_OK ;
2003-10-06 01:24:48 +00:00
}
/****************************************************************************
2005-01-13 18:20:37 +00:00
initialise a privilege list and with someone else ' s talloc context
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS privilege_set_init_by_ctx ( TALLOC_CTX * mem_ctx , PRIVILEGE_SET * priv_set )
{
ZERO_STRUCTP ( priv_set ) ;
priv_set - > mem_ctx = mem_ctx ;
priv_set - > ext_ctx = True ;
return NT_STATUS_OK ;
}
/****************************************************************************
Free all memory used by a PRIVILEGE_SET
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void privilege_set_free ( PRIVILEGE_SET * priv_set )
{
if ( ! priv_set )
return ;
if ( ! ( priv_set - > ext_ctx ) )
talloc_destroy ( priv_set - > mem_ctx ) ;
ZERO_STRUCTP ( priv_set ) ;
}
/****************************************************************************
duplicate alloc luid_attr
2003-10-06 01:24:48 +00:00
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2005-01-13 18:20:37 +00:00
NTSTATUS dup_luid_attr ( TALLOC_CTX * mem_ctx , LUID_ATTR * * new_la , LUID_ATTR * old_la , int count )
2003-10-06 01:24:48 +00:00
{
int i ;
2005-01-13 18:20:37 +00:00
if ( ! old_la )
2003-10-06 01:24:48 +00:00
return NT_STATUS_OK ;
2007-04-30 02:39:34 +00:00
if ( count ) {
* new_la = TALLOC_ARRAY ( mem_ctx , LUID_ATTR , count ) ;
if ( ! * new_la ) {
DEBUG ( 0 , ( " dup_luid_attr: failed to alloc new LUID_ATTR array [%d] \n " , count ) ) ;
return NT_STATUS_NO_MEMORY ;
}
} else {
* new_la = NULL ;
2005-01-17 20:27:29 +00:00
}
2003-10-06 01:24:48 +00:00
2005-01-13 18:20:37 +00:00
for ( i = 0 ; i < count ; i + + ) {
( * new_la ) [ i ] . luid . high = old_la [ i ] . luid . high ;
( * new_la ) [ i ] . luid . low = old_la [ i ] . luid . low ;
( * new_la ) [ i ] . attr = old_la [ i ] . attr ;
2003-10-06 01:24:48 +00:00
}
2005-01-17 20:27:29 +00:00
return NT_STATUS_OK ;
2005-01-13 18:20:37 +00:00
}
2005-01-18 18:29:28 +00:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool is_privileged_sid ( const DOM_SID * sid )
2005-01-18 18:29:28 +00:00
{
SE_PRIV mask ;
return get_privileges ( sid , & mask ) ;
}
2006-03-15 05:50:52 +00:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2007-10-18 17:40:25 -07:00
bool grant_all_privileges ( const DOM_SID * sid )
2006-03-15 05:50:52 +00:00
{
SE_PRIV mask ;
2007-06-14 11:29:35 +00:00
if ( ! se_priv_put_all_privileges ( & mask ) ) {
return False ;
2006-03-15 05:50:52 +00:00
}
2007-06-14 11:29:35 +00:00
2006-03-15 05:50:52 +00:00
return grant_privilege ( sid , & mask ) ;
}