Support OpenBSD 6.0 pledge() syscall for sandboxing.

This commit is contained in:
John Hood
2016-09-18 01:32:24 -04:00
parent 5619dd47bb
commit 1077db41b6
3 changed files with 21 additions and 0 deletions
+1
View File
@@ -249,6 +249,7 @@ AC_CHECK_FUNCS(m4_normalize([
pselect
getaddrinfo
getnameinfo
pledge
]))
AC_SEARCH_LIBS([clock_gettime], [rt], [AC_DEFINE([HAVE_CLOCK_GETTIME], [1], [Define if clock_gettime is available.])])
+10
View File
@@ -33,6 +33,7 @@
#include "config.h"
#include "version.h"
#include <err.h>
#include <errno.h>
#include <locale.h>
#include <string.h>
@@ -563,6 +564,15 @@ static int run_server( const char *desired_ip, const char *desired_port,
} else {
/* parent */
/* Drop unnecessary privileges */
#ifdef HAVE_PLEDGE
/* OpenBSD pledge() syscall */
if ( pledge( "stdio inet ioctl tty", NULL )) {
perror( "pledge() failed" );
exit( 1 );
}
#endif
#ifdef HAVE_UTEMPTER
/* make utmp entry */
utempter_add_record( master, utmp_entry );
+10
View File
@@ -32,6 +32,7 @@
#include "config.h"
#include <err.h>
#include <errno.h>
#include <locale.h>
#include <string.h>
@@ -407,6 +408,15 @@ bool STMClient::main( void )
/* initialize signal handling and structures */
main_init();
/* Drop unnecessary privileges */
#ifdef HAVE_PLEDGE
/* OpenBSD pledge() syscall */
if ( pledge( "stdio inet ioctl tty", NULL )) {
perror( "pledge() failed" );
exit( 1 );
}
#endif
/* prepare to poll for events */
Select &sel = Select::get_instance();