forked from ocaml-multicore/eio
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
6 changed files
with
72 additions
and
8 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 |
---|---|---|
@@ -0,0 +1,3 @@ | ||
(executable | ||
(name main) | ||
(libraries eio_main)) |
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 |
---|---|---|
@@ -0,0 +1,40 @@ | ||
open Eio.Std | ||
|
||
let ( / ) = Eio.Path.( / ) | ||
|
||
let test_eio dir = | ||
traceln "Using the file-system via the directory resource works:"; | ||
let test_file = dir / "capsicum-test.txt" in | ||
traceln "Writing %a..." Eio.Path.pp test_file; | ||
Eio.Path.save test_file "A test file" ~create:(`Exclusive 0o644); | ||
traceln "Read: %S" (Eio.Path.load test_file); | ||
Eio.Path.unlink test_file | ||
|
||
let test_legacy () = | ||
traceln "Bypassing Eio and accessing other resources should fail in Capsicum mode:"; | ||
let ch = open_in "/etc/passwd" in | ||
let len = in_channel_length ch in | ||
let data = really_input_string ch len in | ||
close_in ch; | ||
traceln "Was able to read /etc/passwd:@.%s" (String.trim data) | ||
|
||
let () = | ||
Eio_main.run @@ fun env -> | ||
(* Parse command-line arguments *) | ||
let path = | ||
match Sys.argv with | ||
| [| _; dir |] -> Eio.Stdenv.fs env / dir | ||
| _ -> failwith "Usage: main.exe DIR" | ||
in | ||
if not (Eio.Path.is_directory path) then Fmt.failwith "%a is not a directory" Eio.Path.pp path; | ||
(* Get access to resources before calling cap_enter: *) | ||
Eio.Path.with_open_dir path @@ fun dir -> | ||
traceln "Opened directory %a" Eio.Path.pp path; | ||
(* Switch to capability mode, if possible: *) | ||
begin match Eio_unix.Cap.enter () with | ||
| Ok () -> traceln "Capsicum mode enabled" | ||
| Error `Not_supported -> traceln "!! CAPSICUM PROTECTION NOT AVAILABLE !!" | ||
end; | ||
(* Run tests: *) | ||
test_eio dir; | ||
test_legacy () |
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,24 +1,27 @@ | ||
#include "primitives.h" | ||
|
||
#define HAVE_CAP_ENTER | ||
|
||
#include <errno.h> | ||
#include <sys/param.h> | ||
|
||
#ifdef __FreeBSD__ | ||
# define HAVE_CAPSICUM | ||
#endif | ||
|
||
#ifdef HAVE_CAP_ENTER | ||
#ifdef HAVE_CAPSICUM | ||
# include <sys/capsicum.h> | ||
#endif | ||
|
||
#include <caml/mlvalues.h> | ||
#include <caml/unixsupport.h> | ||
|
||
CAMLprim value eio_unix_cap_enter(value v_unit) { | ||
#ifdef HAVE_CAP_ENTER | ||
#ifdef HAVE_CAPSICUM | ||
int r = cap_enter(); | ||
if (r == -1 && errno != ENOSYS) | ||
caml_uerror("cap_enter", Nothing); | ||
|
||
return Val_bool(r == 0) | ||
return Val_bool(r == 0); | ||
#else | ||
return Val_bool(0) | ||
return Val_bool(0); | ||
#endif | ||
} |
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,5 @@ | ||
external eio_cap_enter : unit -> bool = "eio_unix_cap_enter" | ||
|
||
let cap_enter () = | ||
let enter () = | ||
if eio_cap_enter () then Ok () | ||
else Error `Not_supported |
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 +1 @@ | ||
val cap_enter : unit -> (unit, [`Not_supported]) result | ||
val enter : unit -> (unit, [`Not_supported]) result |