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
2009-05-16 01:21:08 +02:00
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 .
2009-05-16 01:21:08 +02:00
2003-10-06 01:24:48 +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 .
2009-05-16 01:21:08 +02:00
2003-10-06 01:24:48 +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/>.
2003-10-06 01:24:48 +00:00
*/
2009-05-16 01:21:08 +02:00
2003-10-06 01:24:48 +00:00
# include "includes.h"
2011-03-25 11:56:52 +01:00
# include "lib/privileges.h"
2011-07-07 17:42:08 +02:00
# include "dbwrap/dbwrap.h"
2010-09-04 09:23:12 +10:00
# include "libcli/security/privileges_private.h"
2010-10-12 15:27:50 +11:00
# include "../libcli/security/security.h"
2011-03-22 16:50:02 +01:00
# include "passdb.h"
2003-10-06 01:24:48 +00:00
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 {
2010-08-26 20:54:13 +10:00
uint32_t count ;
2010-05-21 11:25:01 +10:00
struct dom_sid * list ;
2005-03-22 15:39:24 +00:00
} SID_LIST ;
typedef struct {
2007-09-08 20:30:51 +00:00
TALLOC_CTX * mem_ctx ;
2010-08-26 08:49:28 +10:00
uint64_t privilege ;
2005-01-13 18:20:37 +00:00
SID_LIST sids ;
} PRIV_SID_LIST ;
2003-10-06 01:24:48 +00:00
2010-09-03 16:33:41 +10:00
/*
interpret an old style SE_PRIV structure
*/
static uint64_t map_old_SE_PRIV ( unsigned char * dptr )
{
uint32_t * old_masks = ( uint32_t * ) dptr ;
/*
* the old privileges code only ever used up to 0x800 , except
* for a special case of ' SE_ALL_PRIVS ' which was 0xFFFFFFFF
*/
if ( old_masks [ 0 ] = = 0xFFFFFFFF ) {
/* they set all privileges */
return SE_ALL_PRIVS ;
}
/* the old code used the machine byte order, but we don't know
* the byte order of the machine that wrote it . However we can
* tell what byte order it was by taking advantage of the fact
* that it only ever use up to 0x800
*/
if ( dptr [ 0 ] | | dptr [ 1 ] ) {
/* it was little endian */
return IVAL ( dptr , 0 ) ;
}
/* it was either zero or big-endian */
return RIVAL ( dptr , 0 ) ;
}
2003-12-04 04:31:29 +00:00
2010-08-26 08:49:28 +10:00
static bool get_privileges ( const struct dom_sid * sid , uint64_t * 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 ;
2011-08-24 13:08:13 +02:00
NTSTATUS status ;
2005-01-17 20:27:29 +00:00
/* Fail if the admin has not enable privileges */
2009-05-16 01:21:08 +02:00
2005-01-17 20:27:29 +00:00
if ( ! lp_enable_privileges ( ) ) {
return False ;
}
2009-05-16 01:21:08 +02: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 */
2009-05-16 01:21:08 +02:00
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
2011-08-24 13:08:13 +02:00
status = dbwrap_fetch_bystring ( db , talloc_tos ( ) , keystr , & data ) ;
2009-05-16 01:21:08 +02:00
2011-08-24 13:08:13 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-03-08 17:47:36 +01:00
DEBUG ( 4 , ( " get_privileges: No privileges assigned to SID "
2007-12-15 21:11:36 +01:00
" [%s] \n " , sid_string_dbg ( sid ) ) ) ;
2005-01-15 02:20:30 +00:00
return False ;
2005-01-13 18:20:37 +00:00
}
2009-05-16 01:21:08 +02:00
2010-08-26 10:35:45 +10:00
if ( data . dsize = = 4 * 4 ) {
2010-09-03 16:33:41 +10:00
/* it's an old style SE_PRIV structure. */
* mask = map_old_SE_PRIV ( data . dptr ) ;
} else {
if ( data . dsize ! = sizeof ( uint64_t ) ) {
DEBUG ( 3 , ( " get_privileges: Invalid privileges record assigned to SID "
" [%s] \n " , sid_string_dbg ( sid ) ) ) ;
return False ;
}
2010-08-26 10:35:45 +10:00
2010-09-03 16:33:41 +10:00
* mask = BVAL ( data . dptr , 0 ) ;
2010-08-26 10:35:45 +10:00
}
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
2010-09-03 20:30:16 +10:00
static bool set_privileges ( const struct dom_sid * sid , uint64_t 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 ( ) ;
2010-08-26 10:35:45 +10:00
uint8_t privbuf [ 8 ] ;
2007-12-15 22:00:39 +01:00
fstring tmp , keystr ;
2007-03-27 09:59:32 +00:00
TDB_DATA data ;
2009-05-16 01:21:08 +02: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 */
2009-05-16 01:21:08 +02:00
2007-12-15 22:47:30 +01:00
fstr_sprintf ( keystr , " %s%s " , PRIVPREFIX , sid_to_fstring ( tmp , sid ) ) ;
2009-05-16 01:21:08 +02:00
2010-08-26 10:35:45 +10:00
/* This writes the 64 bit bitmask out in little endian format */
2010-09-03 20:30:16 +10:00
SBVAL ( privbuf , 0 , mask ) ;
2009-05-16 01:21:08 +02:00
2010-09-03 16:33:41 +10:00
data . dptr = privbuf ;
data . dsize = sizeof ( privbuf ) ;
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
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-08-26 08:49:28 +10:00
bool get_privileges_for_sids ( uint64_t * privileges , struct dom_sid * slist , int scount )
2003-10-06 01:24:48 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t 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
2010-08-30 13:14:40 +10:00
* privileges = 0 ;
2009-05-16 01:21:08 +02:00
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 "
2010-08-27 10:04:05 +10:00
" set: 0x%llx \n " , sid_string_dbg ( & slist [ i ] ) ,
( unsigned long long ) mask ) ) ;
2009-05-16 01:21:08 +02:00
2010-08-30 13:14:40 +10:00
* privileges | = mask ;
2005-01-17 15:23:11 +00:00
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
}
2010-08-30 15:38:18 +10:00
NTSTATUS get_privileges_for_sid_as_set ( TALLOC_CTX * mem_ctx , PRIVILEGE_SET * * privileges , struct dom_sid * sid )
{
uint64_t mask ;
if ( ! get_privileges ( sid , & mask ) ) {
return NT_STATUS_OBJECT_NAME_NOT_FOUND ;
}
* privileges = talloc_zero ( mem_ctx , PRIVILEGE_SET ) ;
if ( ! * privileges ) {
return NT_STATUS_NO_MEMORY ;
}
if ( ! se_priv_to_privilege_set ( * privileges , mask ) ) {
return NT_STATUS_NO_MEMORY ;
}
return NT_STATUS_OK ;
}
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 ) ;
2010-05-21 11:25:01 +10:00
struct dom_sid sid ;
2005-01-13 18:20:37 +00:00
fstring sid_string ;
2011-08-17 11:24:09 +02:00
TDB_DATA key ;
key = dbwrap_record_get_key ( rec ) ;
2009-05-16 01:21:08 +02:00
2005-01-13 18:20:37 +00:00
/* check we have a PRIV_+SID entry */
2003-10-06 01:24:48 +00:00
2011-08-17 11:24:09 +02:00
if ( strncmp ( ( char * ) key . dptr , PRIVPREFIX , prefixlen ) ! = 0 )
2005-01-13 18:20:37 +00:00
return 0 ;
2009-05-16 01:21:08 +02:00
2005-01-13 18:20:37 +00:00
/* check to see if we are looking for a particular privilege */
2003-10-06 01:24:48 +00:00
2011-08-17 11:24:09 +02:00
fstrcpy ( sid_string , ( char * ) & ( key . dptr [ strlen ( PRIVPREFIX ) ] ) ) ;
2010-08-30 13:24:43 +10:00
if ( priv - > privilege ! = 0 ) {
2010-08-26 08:49:28 +10:00
uint64_t mask ;
2011-08-17 11:24:09 +02:00
TDB_DATA value ;
value = dbwrap_record_get_value ( rec ) ;
2009-05-16 01:21:08 +02:00
2011-08-17 11:24:09 +02:00
if ( value . dsize = = 4 * 4 ) {
mask = map_old_SE_PRIV ( value . dptr ) ;
2010-09-03 16:33:41 +10:00
} else {
2011-08-17 11:24:09 +02:00
if ( value . dsize ! = sizeof ( uint64_t ) ) {
2010-09-03 16:33:41 +10:00
DEBUG ( 3 , ( " get_privileges: Invalid privileges record assigned to SID "
" [%s] \n " , sid_string ) ) ;
return 0 ;
}
2011-08-17 11:24:09 +02:00
mask = BVAL ( value . dptr , 0 ) ;
2010-08-30 13:24:43 +10:00
}
2009-05-16 01:21:08 +02:00
/* if the SID does not have the specified privilege
2005-01-13 18:20:37 +00:00
then just return */
2009-05-16 01:21:08 +02:00
2010-08-30 13:24:43 +10:00
if ( ( mask & priv - > privilege ) = = 0 ) {
2005-01-13 18:20:37 +00:00
return 0 ;
2010-08-30 13:24:43 +10:00
}
2005-01-13 18:20:37 +00:00
}
2009-05-16 01:21:08 +02: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 ;
}
2009-05-16 01:21:08 +02:00
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 ( )
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-21 11:25:01 +10:00
NTSTATUS privilege_enumerate_accounts ( struct 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 ;
2011-08-17 11:24:09 +02:00
NTSTATUS status ;
2009-05-16 01:21:08 +02:00
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
2011-08-17 11:24:09 +02:00
status = dbwrap_traverse_read ( db , priv_traverse_fn , & priv , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
2003-10-06 01:24:48 +00:00
2005-01-13 18:20:37 +00:00
/* give the memory away; caller will free */
2009-05-16 01:21:08 +02:00
2005-01-13 18:20:37 +00:00
* 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
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-08-30 14:17:02 +10:00
NTSTATUS privilege_enum_sids ( enum sec_privilege privilege , TALLOC_CTX * mem_ctx ,
2010-05-21 11:25:01 +10:00
struct dom_sid * * sids , int * num_sids )
2007-09-08 20:30:51 +00:00
{
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 ;
2011-08-17 11:24:09 +02:00
NTSTATUS status ;
2007-09-08 20:30:51 +00:00
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 ) ;
2010-08-30 14:17:02 +10:00
priv . privilege = sec_privilege_mask ( privilege ) ;
2007-09-08 20:30:51 +00:00
priv . mem_ctx = mem_ctx ;
2011-08-17 11:24:09 +02:00
status = dbwrap_traverse_read ( db , priv_traverse_fn , & priv , NULL ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
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
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-08-30 15:27:40 +10:00
static bool grant_privilege_bitmap ( const struct dom_sid * sid , const uint64_t priv_mask )
2005-01-13 18:20:37 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t old_mask , new_mask ;
2009-05-16 01:21:08 +02: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 ) )
2010-08-30 12:59:38 +10:00
new_mask = old_mask ;
2005-01-15 02:20:30 +00:00
else
2010-08-30 12:59:38 +10:00
new_mask = 0 ;
2005-01-17 15:23:11 +00:00
2010-08-30 12:59:38 +10:00
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 ) ) ) ;
2009-05-16 01:21:08 +02:00
2010-08-27 10:04:05 +10:00
DEBUGADD ( 10 , ( " original privilege mask: 0x%llx \n " , ( unsigned long long ) new_mask ) ) ;
2009-05-16 01:21:08 +02:00
2010-08-27 10:04:05 +10:00
DEBUGADD ( 10 , ( " new privilege mask: 0x%llx \n " , ( unsigned long long ) new_mask ) ) ;
2009-05-16 01:21:08 +02:00
2010-09-03 20:30:16 +10:00
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
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-09-03 20:30:50 +10:00
bool grant_privilege_by_name ( const struct dom_sid * sid , const char * name )
2005-01-15 02:20:30 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t 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
2010-08-30 15:27:40 +10:00
return grant_privilege_bitmap ( sid , mask ) ;
}
/***************************************************************************
Grant a privilege set ( list of LUID values ) from a sid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
bool grant_privilege_set ( const struct dom_sid * sid , struct lsa_PrivilegeSet * set )
{
uint64_t privilege_mask ;
if ( ! privilege_set_to_se_priv ( & privilege_mask , set ) ) {
return false ;
}
return grant_privilege_bitmap ( sid , privilege_mask ) ;
2005-01-15 02:20:30 +00:00
}
2005-01-13 18:20:37 +00:00
/***************************************************************************
Remove privilege from sid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-08-30 15:27:40 +10:00
static bool revoke_privilege_bitmap ( const struct dom_sid * sid , const uint64_t priv_mask )
2005-01-13 18:20:37 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t mask ;
2009-05-16 01:21:08 +02:00
2005-01-17 15:23:11 +00:00
/* if the user has no privileges, then we can't revoke any */
2009-05-16 01:21:08 +02:00
2005-01-17 15:23:11 +00:00
if ( ! get_privileges ( sid , & mask ) )
return True ;
2009-05-16 01:21:08 +02:00
2007-12-15 21:11:36 +01:00
DEBUG ( 10 , ( " revoke_privilege: %s \n " , sid_string_dbg ( sid ) ) ) ;
2009-05-16 01:21:08 +02:00
2010-08-27 10:04:05 +10:00
DEBUGADD ( 10 , ( " original privilege mask: 0x%llx \n " , ( unsigned long long ) mask ) ) ;
2005-01-13 18:20:37 +00:00
2010-08-30 12:44:08 +10:00
mask & = ~ priv_mask ;
2009-05-16 01:21:08 +02:00
2010-08-27 10:04:05 +10:00
DEBUGADD ( 10 , ( " new privilege mask: 0x%llx \n " , ( unsigned long long ) mask ) ) ;
2009-05-16 01:21:08 +02:00
2010-09-03 20:30:16 +10:00
return set_privileges ( sid , mask ) ;
2005-01-17 15:23:11 +00:00
}
2010-08-30 15:27:40 +10:00
/***************************************************************************
Remove a privilege set ( list of LUID values ) from a sid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
bool revoke_privilege_set ( const struct dom_sid * sid , struct lsa_PrivilegeSet * set )
{
uint64_t privilege_mask ;
if ( ! privilege_set_to_se_priv ( & privilege_mask , set ) ) {
return false ;
}
return revoke_privilege_bitmap ( sid , privilege_mask ) ;
}
2005-01-17 15:23:11 +00:00
/*********************************************************************
Revoke all privileges
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-09-03 20:30:50 +10:00
bool revoke_all_privileges ( const struct dom_sid * sid )
2005-01-17 15:23:11 +00:00
{
2010-08-30 15:27:40 +10:00
return revoke_privilege_bitmap ( sid , SE_ALL_PRIVS ) ;
2005-01-13 18:20:37 +00:00
}
2005-01-15 02:20:30 +00:00
/*********************************************************************
Add a privilege based on its name
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-09-03 20:30:50 +10:00
bool revoke_privilege_by_name ( const struct dom_sid * sid , const char * name )
2005-01-15 02:20:30 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t 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
2010-08-30 15:27:40 +10:00
return revoke_privilege_bitmap ( 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
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-21 11:25:01 +10:00
NTSTATUS privilege_create_account ( const struct dom_sid * sid )
2005-01-13 18:20:37 +00:00
{
2010-08-30 15:27:40 +10:00
return ( grant_privilege_bitmap ( sid , 0 ) ? NT_STATUS_OK : NT_STATUS_UNSUCCESSFUL ) ;
2005-01-13 18:20:37 +00:00
}
2009-05-16 01:22:28 +02:00
/***************************************************************************
Delete a privileged account
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS privilege_delete_account ( const struct dom_sid * sid )
{
struct db_context * db = get_account_pol_db ( ) ;
fstring tmp , keystr ;
if ( ! lp_enable_privileges ( ) ) {
return NT_STATUS_OK ;
}
if ( ! db ) {
return NT_STATUS_INVALID_HANDLE ;
}
if ( ! sid | | ( sid - > num_auths = = 0 ) ) {
return NT_STATUS_INVALID_SID ;
}
/* PRIV_<SID> (NULL terminated) as the key */
fstr_sprintf ( keystr , " %s%s " , PRIVPREFIX , sid_to_fstring ( tmp , sid ) ) ;
return dbwrap_delete_bystring ( db , keystr ) ;
}
2005-01-18 18:29:28 +00:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-21 11:25:01 +10:00
bool is_privileged_sid ( const struct dom_sid * sid )
2005-01-18 18:29:28 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t mask ;
2009-05-16 01:21:08 +02:00
2005-01-18 18:29:28 +00:00
return get_privileges ( sid , & mask ) ;
}
2006-03-15 05:50:52 +00:00
/*******************************************************************
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2010-05-21 11:25:01 +10:00
bool grant_all_privileges ( const struct dom_sid * sid )
2006-03-15 05:50:52 +00:00
{
2010-08-26 08:49:28 +10:00
uint64_t mask ;
2006-03-15 05:50:52 +00:00
2010-09-04 09:16:23 +10:00
se_priv_put_all_privileges ( & mask ) ;
2009-05-16 01:21:08 +02:00
2010-08-30 15:27:40 +10:00
return grant_privilege_bitmap ( sid , mask ) ;
2006-03-15 05:50:52 +00:00
}