pub mod error;
pub mod policy;
pub mod profile;
pub mod result;
pub mod sandbox;
pub(crate) mod arch;
pub(crate) mod sys;
pub mod landlock;
pub mod seccomp;
pub(crate) mod resource;
pub(crate) mod network;
pub mod context;
pub(crate) mod vdso;
pub(crate) mod random;
pub(crate) mod time;
pub(crate) mod cow;
pub(crate) mod checkpoint;
pub(crate) mod sibling_freeze;
pub mod netlink;
pub(crate) mod procfs;
pub(crate) mod port_remap;
pub mod pipeline;
pub mod policy_fn;
pub mod image;
pub mod fork;
pub(crate) mod chroot;
pub mod dry_run;
pub(crate) mod http_acl;
pub use error::SandlockError;
pub use checkpoint::Checkpoint;
pub use policy::{Policy, PolicyBuilder};
pub use result::{RunResult, ExitStatus};
pub use sandbox::Sandbox;
pub use pipeline::{Stage, Pipeline, Gather};
pub use dry_run::{Change, ChangeKind, DryRunResult};
pub fn landlock_abi_version() -> Result<u32, error::ConfinementError> {
landlock::abi_version()
}
pub const MIN_LANDLOCK_ABI: u32 = landlock::MIN_ABI;
pub fn confine_current_process(policy: &Policy) -> Result<(), SandlockError> {
if unsafe { libc::prctl(libc::PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0) } != 0 {
return Err(SandlockError::Sandbox(
error::SandboxError::Confinement(
error::ConfinementError::Landlock(format!(
"prctl(PR_SET_NO_NEW_PRIVS): {}",
std::io::Error::last_os_error()
))
)
));
}
let mut stripped = policy.clone();
stripped.net_bind.clear();
stripped.net_connect.clear();
landlock::confine(&stripped)
}