summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--bin/systrace/filter.c8
-rw-r--r--bin/systrace/systrace.c8
2 files changed, 13 insertions, 3 deletions
diff --git a/bin/systrace/filter.c b/bin/systrace/filter.c
index 237df9146de..7a005211105 100644
--- a/bin/systrace/filter.c
+++ b/bin/systrace/filter.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: filter.c,v 1.3 2002/06/04 19:15:54 deraadt Exp $ */
+/* $OpenBSD: filter.c,v 1.4 2002/06/05 15:59:52 provos Exp $ */
/*
* Copyright 2002 Niels Provos <provos@citi.umich.edu>
* All rights reserved.
@@ -29,6 +29,7 @@
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
+#include <sys/param.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <sys/tree.h>
@@ -44,6 +45,7 @@
#include "systrace.h"
extern int connected;
+extern char cwd[];
int
filter_match(struct intercept_tlq *tls, struct logic *logic)
@@ -385,7 +387,7 @@ filter_replace(char *buf, size_t buflen, char *match, char *repl)
char *
filter_expand(char *data)
{
- static char expand[1024];
+ static char expand[2*MAXPATHLEN];
char *what;
if (data != NULL)
@@ -398,6 +400,8 @@ filter_expand(char *data)
if (what != NULL)
filter_replace(expand, sizeof(expand), "$USER", what);
+ filter_replace(expand, sizeof(expand), "$CWD", cwd);
+
return (expand);
}
diff --git a/bin/systrace/systrace.c b/bin/systrace/systrace.c
index c7d37833b63..7ec5c124f22 100644
--- a/bin/systrace/systrace.c
+++ b/bin/systrace/systrace.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: systrace.c,v 1.9 2002/06/04 22:45:25 provos Exp $ */
+/* $OpenBSD: systrace.c,v 1.10 2002/06/05 15:59:52 provos Exp $ */
/*
* Copyright 2002 Niels Provos <provos@citi.umich.edu>
* All rights reserved.
@@ -30,6 +30,7 @@
*/
#include <sys/types.h>
+#include <sys/param.h>
#include <sys/wait.h>
#include <sys/tree.h>
#include <sys/socket.h>
@@ -52,6 +53,7 @@ int inherit = 0; /* Inherit policy to childs */
int automatic = 0; /* Do not run interactively */
int userpolicy = 1; /* Permit user defined policies */
char *username = NULL; /* Username in automatic mode */
+char cwd[MAXPATHLEN]; /* Current working directory of process */
short
trans_cb(int fd, pid_t pid, int policynr,
@@ -423,6 +425,10 @@ main(int argc, char **argv)
if (argc == 0)
usage();
+ /* Determine current working directory for filtering */
+ if (getcwd(cwd, sizeof(cwd)) == NULL)
+ err(1, "getcwd");
+
if ((args = malloc((argc + 1) * sizeof(char *))) == NULL)
err(1, "malloc");