summaryrefslogtreecommitdiff
path: root/source4/libcli/security/privilege.c
diff options
context:
space:
mode:
authorAndrew Tridgell <tridge@samba.org>2004-12-11 12:01:20 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 13:07:19 -0500
commit02a9aa08923e348af2cda9829b64a5f98282164d (patch)
treed08fcad68289d714f1438162ecd944837aac87d9 /source4/libcli/security/privilege.c
parentdca888e51eb97df60a3af6779b88cfa8d0e34996 (diff)
downloadsamba-02a9aa08923e348af2cda9829b64a5f98282164d.tar.gz
samba-02a9aa08923e348af2cda9829b64a5f98282164d.tar.bz2
samba-02a9aa08923e348af2cda9829b64a5f98282164d.zip
r4150: - add fns for manipulating the privilege_mask in a security_token
- add the hooks in access_check that check the privilege bitmasks for SEC_STD_DELETE and SEC_FLAG_SYSTEM_SECURITY (This used to be commit 0fa3764edcabffe8f7d5e40f0097f97d0c4519c4)
Diffstat (limited to 'source4/libcli/security/privilege.c')
-rw-r--r--source4/libcli/security/privilege.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/source4/libcli/security/privilege.c b/source4/libcli/security/privilege.c
index 1962aaa374..10a51c8b42 100644
--- a/source4/libcli/security/privilege.c
+++ b/source4/libcli/security/privilege.c
@@ -82,3 +82,27 @@ int sec_privilege_id(const char *name)
}
return -1;
}
+
+
+/*
+ return True if a security_token has a particular privilege bit set
+*/
+BOOL sec_privilege_check(const struct security_token *token, unsigned int privilege)
+{
+ uint64_t mask = 1;
+ mask <<= (privilege-1);
+ if (token->privilege_mask & mask) {
+ return True;
+ }
+ return False;
+}
+
+/*
+ set a bit in the privilege mask
+*/
+void sec_privilege_set(struct security_token *token, unsigned int privilege)
+{
+ uint64_t mask = 1;
+ mask <<= (privilege-1);
+ token->privilege_mask |= mask;
+}