| Crates.io | unveil |
| lib.rs | unveil |
| version | 0.3.2 |
| created_at | 2018-10-20 17:03:20.047259+00 |
| updated_at | 2022-05-22 07:04:52.658978+00 |
| description | Rust binding for OpenBSD's unveil(2) |
| homepage | |
| repository | https://github.com/asmarques/unveil-rs |
| max_upload_size | |
| id | 91675 |
| size | 19,067 |
Rust binding for OpenBSD's unveil(2).
extern crate unveil;
use std::fs::File;
use std::io::prelude::*;
use unveil::unveil;
fn main() {
let path = "public.txt";
let contents = b"Hello world!";
File::create(path).unwrap().write_all(contents).unwrap();
// Restrict filesystem view by only allowing read operations on the specified path
unveil(path, "r")
.or_else(unveil::Error::ignore_platform)
.unwrap();
// Reading from unveiled paths will succeed
let mut file = File::open(path).unwrap();
let mut buffer = Vec::new();
file.read_to_end(&mut buffer).unwrap();
assert_eq!(contents, &buffer[..]);
// Reading from paths which have not been unveiled will fail
assert!(File::open("/etc/passwd").is_err());
// Disable further calls to unveil
unveil("", "")
.or_else(unveil::Error::ignore_platform)
.unwrap();
// All calls to unveil will now fail
assert!(unveil(path, "rw").is_err());
}