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
Copyright ( C ) Gerald ( Jerry ) Carter 2004
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
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 .
*/
# 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-01-13 21:20:37 +03:00
2005-01-19 19:52:19 +03:00
/* defined in lib/privilegs.c */
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-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
# ifndef _BOOL
typedef int BOOL ;
# define _BOOL /* So we don't typedef BOOL again in vfs.h */
# endif
2003-05-06 17:10:10 +04:00
typedef struct LUID
{
uint32 low ;
uint32 high ;
} LUID ;
typedef struct LUID_ATTR
{
LUID luid ;
uint32 attr ;
2005-01-13 21:20:37 +03:00
} LUID_ATTR ;
2003-05-06 17:10:10 +04:00
typedef struct privilege_set
{
2003-10-06 05:38:46 +04:00
TALLOC_CTX * mem_ctx ;
BOOL ext_ctx ;
2003-05-06 17:10:10 +04:00
uint32 count ;
uint32 control ;
LUID_ATTR * set ;
} PRIVILEGE_SET ;
2003-06-18 19:24:10 +04:00
typedef struct _PRIVS {
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 ;
} PRIVS ;
# endif /* PRIVILEGES_H */