forked from freebsd/freebsd-src
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
The idea behinds mocks is that we don't need to ifdef a lot of code in tools itself but those defines are hidden in the casper library. Right now the mocks are implemented as define/inlines functions. There was a very long discussion how this should be implemented. This approach has some advantages like we don't need to link to any additional libraries. Unfortunately there are also some disadvantages for example it is easy to get library out of sync between two versions of functions or that we need extra define to compile program with casper support. This isn't an ideal solution but it's good enough for now and should simplify capsicumizing programs. This also doesn't close us any other ways to do those mocks and this should evolve in time. Discussed with: pjd, emaste, ed, rwatson, bapt, cem, bdrewery Differential Revision: https://reviews.freebsd.org/D8753
- Loading branch information
Showing
22 changed files
with
283 additions
and
9 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,9 @@ | ||
# $FreeBSD$ | ||
|
||
.include <src.opts.mk> | ||
|
||
.if ${MK_CASPER} != "no" | ||
CFLAGS+=-DWITH_CASPER | ||
.endif | ||
|
||
.include "../Makefile.inc" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
/*- | ||
* Copyright (c) 2012-2013 The FreeBSD Foundation | ||
* Copyright (c) 2015 Mariusz Zaborski <[email protected]> | ||
* Copyright (c) 2015-2017 Mariusz Zaborski <[email protected]> | ||
* All rights reserved. | ||
* | ||
* This software was developed by Pawel Jakub Dawidek under sponsorship from | ||
|
@@ -33,7 +33,15 @@ | |
#ifndef _LIBCASPER_H_ | ||
#define _LIBCASPER_H_ | ||
|
||
#ifdef HAVE_CASPER | ||
#define WITH_CASPER | ||
#endif | ||
|
||
#include <sys/types.h> | ||
#include <sys/nv.h> | ||
|
||
#include <stdlib.h> | ||
#include <unistd.h> | ||
|
||
#ifndef _NVLIST_T_DECLARED | ||
#define _NVLIST_T_DECLARED | ||
|
@@ -44,72 +52,191 @@ typedef struct nvlist nvlist_t; | |
|
||
#ifndef _CAP_CHANNEL_T_DECLARED | ||
#define _CAP_CHANNEL_T_DECLARED | ||
#ifdef WITH_CASPER | ||
struct cap_channel; | ||
|
||
typedef struct cap_channel cap_channel_t; | ||
#endif | ||
#else | ||
struct cap_channel { | ||
int cch_fd; | ||
}; | ||
typedef struct cap_channel cap_channel_t; | ||
#endif /* ! WITH_CASPER */ | ||
#endif /* ! _CAP_CHANNEL_T_DECLARED */ | ||
|
||
/* | ||
* The functions opens unrestricted communication channel to Casper. | ||
*/ | ||
#ifdef WITH_CASPER | ||
cap_channel_t *cap_init(void); | ||
#else | ||
static inline cap_channel_t * | ||
cap_init(void) | ||
{ | ||
cap_channel_t *chan; | ||
|
||
chan = malloc(sizeof(*chan)); | ||
if (chan != NULL) { | ||
chan->cch_fd = -1; | ||
} | ||
return (chan); | ||
} | ||
#endif | ||
|
||
/* | ||
* The functions to communicate with service. | ||
*/ | ||
#ifdef WITH_CASPER | ||
cap_channel_t *cap_service_open(const cap_channel_t *chan, const char *name); | ||
int cap_service_limit(const cap_channel_t *chan, | ||
const char * const *names, size_t nnames); | ||
#else | ||
#define cap_service_open(chan, name) (cap_init()) | ||
#define cap_service_limit(chan, names, nnames) (0) | ||
#endif | ||
|
||
/* | ||
* The function creates cap_channel_t based on the given socket. | ||
*/ | ||
#ifdef WITH_CASPER | ||
cap_channel_t *cap_wrap(int sock); | ||
#else | ||
static inline cap_channel_t * | ||
cap_wrap(int sock) | ||
{ | ||
cap_channel_t *chan; | ||
|
||
chan = cap_init(); | ||
if (chan != NULL) { | ||
chan->cch_fd = sock; | ||
} | ||
return (chan); | ||
} | ||
#endif | ||
|
||
/* | ||
* The function returns communication socket and frees cap_channel_t. | ||
*/ | ||
#ifdef WITH_CASPER | ||
int cap_unwrap(cap_channel_t *chan); | ||
#else | ||
#define cap_unwrap(chan) (chan->cch_fd) | ||
#endif | ||
|
||
/* | ||
* The function clones the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
cap_channel_t *cap_clone(const cap_channel_t *chan); | ||
#else | ||
static inline cap_channel_t * | ||
cap_clone(const cap_channel_t *chan) | ||
{ | ||
cap_channel_t *newchan; | ||
|
||
newchan = cap_init(); | ||
if (newchan == NULL) { | ||
return (NULL); | ||
} | ||
|
||
if (chan->cch_fd == -1) { | ||
newchan->cch_fd = -1; | ||
} else { | ||
newchan->cch_fd = dup(chan->cch_fd); | ||
if (newchan->cch_fd < 0) { | ||
free(newchan); | ||
newchan = NULL; | ||
} | ||
} | ||
|
||
return (newchan); | ||
} | ||
#endif | ||
|
||
/* | ||
* The function closes the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
void cap_close(cap_channel_t *chan); | ||
#else | ||
static inline void | ||
cap_close(cap_channel_t *chan) | ||
{ | ||
|
||
if (chan->cch_fd >= 0) { | ||
close(chan->cch_fd); | ||
} | ||
free(chan); | ||
} | ||
#endif | ||
|
||
/* | ||
* The function returns socket descriptor associated with the given | ||
* cap_channel_t for use with select(2)/kqueue(2)/etc. | ||
*/ | ||
#ifdef WITH_CASPER | ||
int cap_sock(const cap_channel_t *chan); | ||
#else | ||
#define cap_sock(chan) (chan->cch_fd) | ||
#endif | ||
|
||
/* | ||
* The function limits the given capability. | ||
* It always destroys 'limits' on return. | ||
*/ | ||
#ifdef WITH_CASPER | ||
int cap_limit_set(const cap_channel_t *chan, nvlist_t *limits); | ||
#else | ||
#define cap_limit_set(chan, limits) (0) | ||
#endif | ||
|
||
/* | ||
* The function returns current limits of the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
int cap_limit_get(const cap_channel_t *chan, nvlist_t **limitsp); | ||
#else | ||
static inline int | ||
cap_limit_get(const cap_channel_t *chan __unused, nvlist_t **limitsp) | ||
{ | ||
|
||
*limitsp = nvlist_create(0); | ||
return (0); | ||
} | ||
#endif | ||
|
||
/* | ||
* Function sends nvlist over the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
int cap_send_nvlist(const cap_channel_t *chan, const nvlist_t *nvl); | ||
#else | ||
#define cap_send_nvlist(chan, nvl) (0) | ||
#endif | ||
|
||
/* | ||
* Function receives nvlist over the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
nvlist_t *cap_recv_nvlist(const cap_channel_t *chan, int flags); | ||
#else | ||
#define cap_recv_nvlist(chan, flags) (0) | ||
#endif | ||
|
||
/* | ||
* Function sends the given nvlist, destroys it and receives new nvlist in | ||
* response over the given capability. | ||
*/ | ||
#ifdef WITH_CASPER | ||
nvlist_t *cap_xfer_nvlist(const cap_channel_t *chan, nvlist_t *nvl, int flags); | ||
#else | ||
static inline nvlist_t * | ||
cap_xfer_nvlist(const cap_channel_t *chan __unused, nvlist_t *nvl, int flags) | ||
{ | ||
|
||
nvlist_destroy(nvl); | ||
return (nvlist_create(flags)); | ||
} | ||
#endif | ||
|
||
#endif /* !_LIBCASPER_H_ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,7 @@ | ||
# $FreeBSD$ | ||
|
||
.include <src.opts.mk> | ||
|
||
SUBDIR= cap_dns | ||
SUBDIR+= cap_grp | ||
SUBDIR+= cap_pwd | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.