1 Star 0 Fork 1

yyqng / memcached-memcached-master

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
freebsd_priv.c 1.35 KB
一键复制 编辑 原始数据 按行查看 历史
David Carlier 提交于 2019-07-12 14:26 . drop privileges, FreeBSD.
#include <sys/capsicum.h>
#include <errno.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include "memcached.h"
/*
* dropping privileges is entering in capability mode
* in FreeBSD vocabulary.
*/
void drop_privileges() {
cap_rights_t wd, rd;
if (cap_rights_init(&wd, CAP_WRITE, CAP_READ) == NULL) {
fprintf(stderr, "cap_rights_init write protection failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (cap_rights_init(&rd, CAP_FCNTL, CAP_READ, CAP_EVENT) == NULL) {
fprintf(stderr, "cap_rights_init read protection failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (cap_rights_limit(STDIN_FILENO, &rd) != 0) {
fprintf(stderr, "cap_rights_limit stdin failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (cap_rights_limit(STDOUT_FILENO, &wd) != 0) {
fprintf(stderr, "cap_rights_limit stdout failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (cap_rights_limit(STDERR_FILENO, &wd) != 0) {
fprintf(stderr, "cap_rights_limit stderr failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
if (cap_enter() != 0) {
fprintf(stderr, "cap_enter failed: %s\n", strerror(errno));
exit(EXIT_FAILURE);
}
}
void setup_privilege_violations_handler(void) {
// not needed
}
1
https://gitee.com/yyqng/memcached-memcached-master.git
git@gitee.com:yyqng/memcached-memcached-master.git
yyqng
memcached-memcached-master
memcached-memcached-master
master

搜索帮助