summaryrefslogtreecommitdiffstats
path: root/src/daemon/caps.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/daemon/caps.c')
-rw-r--r--src/daemon/caps.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/daemon/caps.c b/src/daemon/caps.c
index dc74bc7d..957824d9 100644
--- a/src/daemon/caps.c
+++ b/src/daemon/caps.c
@@ -27,6 +27,7 @@
#include <unistd.h>
#include <errno.h>
#include <string.h>
+#include <sys/types.h>
#ifdef HAVE_SYS_CAPABILITY_H
#include <sys/capability.h>
@@ -80,6 +81,10 @@ int pa_limit_caps(void) {
cap_t caps;
cap_value_t nice_cap = CAP_SYS_NICE;
+ /* Only drop caps when called SUID */
+ if (getuid() != 0)
+ return 0;
+
caps = cap_init();
assert(caps);
@@ -106,6 +111,10 @@ int pa_drop_caps(void) {
cap_t caps;
int r = -1;
+ /* Only drop caps when called SUID */
+ if (getuid() != 0)
+ return 0;
+
caps = cap_init();
assert(caps);