diff options
author | rwatson <rwatson@FreeBSD.org> | 2002-11-01 20:46:53 +0000 |
---|---|---|
committer | rwatson <rwatson@FreeBSD.org> | 2002-11-01 20:46:53 +0000 |
commit | 61ffc1b9bb50dc9c580972208b4348cee6d2ad63 (patch) | |
tree | 2efddbff8b3c159870d2afbb85c9b4a531dcf1fe /sys/security/mac/mac_pipe.c | |
parent | 78a117472a62ba8826a9d70ed969f873f8d41715 (diff) | |
download | FreeBSD-src-61ffc1b9bb50dc9c580972208b4348cee6d2ad63.zip FreeBSD-src-61ffc1b9bb50dc9c580972208b4348cee6d2ad63.tar.gz |
Add MAC checks for various kenv() operations: dump, get, set, unset,
permitting MAC policies to limit access to the kernel environment.
Obtained from: TrustedBSD Project
Sponsored by: DARPA, Network Associates Laboratories
Diffstat (limited to 'sys/security/mac/mac_pipe.c')
-rw-r--r-- | sys/security/mac/mac_pipe.c | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/sys/security/mac/mac_pipe.c b/sys/security/mac/mac_pipe.c index 4882c0f..f4cfa8a 100644 --- a/sys/security/mac/mac_pipe.c +++ b/sys/security/mac/mac_pipe.c @@ -2170,6 +2170,58 @@ mac_check_ifnet_transmit(struct ifnet *ifnet, struct mbuf *mbuf) } int +mac_check_kenv_dump(struct ucred *cred) +{ + int error; + + if (!mac_enforce_system) + return (0); + + MAC_CHECK(check_kenv_dump, cred); + + return (error); +} + +int +mac_check_kenv_get(struct ucred *cred, char *name) +{ + int error; + + if (!mac_enforce_system) + return (0); + + MAC_CHECK(check_kenv_get, cred, name); + + return (error); +} + +int +mac_check_kenv_set(struct ucred *cred, char *name, char *value) +{ + int error; + + if (!mac_enforce_system) + return (0); + + MAC_CHECK(check_kenv_set, cred, name, value); + + return (error); +} + +int +mac_check_kenv_unset(struct ucred *cred, char *name) +{ + int error; + + if (!mac_enforce_system) + return (0); + + MAC_CHECK(check_kenv_unset, cred, name); + + return (error); +} + +int mac_check_mount_stat(struct ucred *cred, struct mount *mount) { int error; |