2005-02-03 18:14:54 +03:00
2003-05-06 17:10:10 +04:00
/*
Unix SMB / CIFS implementation .
SMB parameters and setup
Copyright ( C ) Andrew Tridgell 1992 - 1997
Copyright ( C ) Luke Kenneth Casson Leighton 1996 - 1997
Copyright ( C ) Paul Ashton 1997
2005-01-13 21:20:37 +03:00
Copyright ( C ) Simo Sorce 2003
2005-03-10 21:50:47 +03:00
Copyright ( C ) Gerald ( Jerry ) Carter 2005
2003-05-06 17:10:10 +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
2007-07-09 23:25:36 +04:00
the Free Software Foundation ; either version 3 of the License , or
2003-05-06 17:10:10 +04: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 04:52:41 +04:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2003-05-06 17:10:10 +04:00
*/
# ifndef PRIVILEGES_H
# define PRIVILEGES_H
2005-01-19 19:52:19 +03:00
/* privilege bitmask */
# define SE_PRIV_MASKSIZE 4
typedef struct {
uint32 mask [ SE_PRIV_MASKSIZE ] ;
} SE_PRIV ;
2005-01-13 21:20:37 +03:00
/* common privilege defines */
2003-06-18 19:24:10 +04:00
2005-01-17 18:23:11 +03:00
# define SE_END { { 0x00000000, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_NONE { { 0x00000000, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_ALL_PRIVS { { 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF } }
2003-06-18 19:24:10 +04:00
2005-01-13 21:20:37 +03:00
/*
* We will use our own set of privileges since it makes no sense
* to implement all of the Windows set when only a portion will
2005-01-17 18:23:11 +03:00
* be used . Use 128 - bit mask to give room to grow .
2005-01-13 21:20:37 +03:00
*/
2005-01-17 18:23:11 +03:00
# define SE_NETWORK_LOGON { { 0x00000001, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_INTERACTIVE_LOGON { { 0x00000002, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_BATCH_LOGON { { 0x00000004, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_SERVICE_LOGON { { 0x00000008, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_MACHINE_ACCOUNT { { 0x00000010, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_PRINT_OPERATOR { { 0x00000020, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_ADD_USERS { { 0x00000040, 0x00000000, 0x00000000, 0x00000000 } }
2005-01-17 23:27:29 +03:00
# define SE_DISK_OPERATOR { { 0x00000080, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_REMOTE_SHUTDOWN { { 0x00000100, 0x00000000, 0x00000000, 0x00000000 } }
2005-06-09 19:20:11 +04:00
# define SE_BACKUP { { 0x00000200, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_RESTORE { { 0x00000400, 0x00000000, 0x00000000, 0x00000000 } }
# define SE_TAKE_OWNERSHIP { { 0x00000800, 0x00000000, 0x00000000, 0x00000000 } }
2005-01-13 21:20:37 +03:00
2007-06-14 15:29:35 +04:00
/* defined in lib/privilegs_basic.c */
extern const SE_PRIV se_priv_all ;
2005-01-19 19:52:19 +03:00
2005-02-03 18:14:54 +03:00
extern const SE_PRIV se_priv_none ;
2005-01-19 19:52:19 +03:00
extern const SE_PRIV se_machine_account ;
extern const SE_PRIV se_print_operator ;
extern const SE_PRIV se_add_users ;
extern const SE_PRIV se_disk_operators ;
extern const SE_PRIV se_remote_shutdown ;
2005-06-09 19:20:11 +04:00
extern const SE_PRIV se_restore ;
2005-09-02 16:53:46 +04:00
extern const SE_PRIV se_take_ownership ;
2005-01-19 19:52:19 +03:00
2005-01-13 21:20:37 +03:00
/*
* These are used in Lsa replies ( srv_lsa_nt . c )
*/
2003-06-18 19:24:10 +04:00
# define PR_NONE 0x0000
# define PR_LOG_ON_LOCALLY 0x0001
# define PR_ACCESS_FROM_NETWORK 0x0002
# define PR_LOG_ON_BATCH_JOB 0x0004
# define PR_LOG_ON_SERVICE 0x0010
2005-01-13 21:20:37 +03:00
2005-06-29 20:35:32 +04:00
typedef struct {
2003-05-06 17:10:10 +04:00
uint32 high ;
2005-06-29 20:35:32 +04:00
uint32 low ;
2003-05-06 17:10:10 +04:00
} LUID ;
2005-06-29 20:35:32 +04:00
typedef struct {
2003-05-06 17:10:10 +04:00
LUID luid ;
uint32 attr ;
2005-01-13 21:20:37 +03:00
} LUID_ATTR ;
2003-05-06 17:10:10 +04:00
2005-06-29 20:35:32 +04:00
typedef struct {
2003-10-06 05:38:46 +04:00
TALLOC_CTX * mem_ctx ;
2007-10-19 04:40:25 +04:00
bool ext_ctx ;
2003-05-06 17:10:10 +04:00
uint32 count ;
uint32 control ;
LUID_ATTR * set ;
} PRIVILEGE_SET ;
2005-06-29 20:35:32 +04:00
typedef struct {
2005-01-17 18:23:11 +03:00
SE_PRIV se_priv ;
2005-01-13 21:20:37 +03:00
const char * name ;
2003-06-18 19:24:10 +04:00
const char * description ;
2005-06-29 20:35:32 +04:00
LUID luid ;
2003-06-18 19:24:10 +04:00
} PRIVS ;
# endif /* PRIVILEGES_H */