26 releases

0.6.13 Nov 23, 2024
0.6.10 Jul 28, 2024
0.6.9 Mar 27, 2024
0.6.7 Nov 1, 2023
0.2.0 Mar 17, 2021

#967 in Unix APIs

Download history 2844/week @ 2024-08-19 1442/week @ 2024-08-26 2862/week @ 2024-09-02 3750/week @ 2024-09-09 5801/week @ 2024-09-16 3092/week @ 2024-09-23 2415/week @ 2024-09-30 2907/week @ 2024-10-07 3804/week @ 2024-10-14 3641/week @ 2024-10-21 2895/week @ 2024-10-28 777/week @ 2024-11-04 4242/week @ 2024-11-11 3557/week @ 2024-11-18 3975/week @ 2024-11-25 6133/week @ 2024-12-02

17,942 downloads per month
Used in 8 crates (via selinux)

MIT license

26KB
379 lines

crates.io docs.rs license

selinux-sys: Unsafe Rust bindings for libselinux

SELinux is a flexible Mandatory Access Control (MAC) for Linux.

This crate exposes neither deprecated nor undocumented SELinux API functions and types.

This crate is Linux-specific. Building it for non-Linux platforms, or for the Linux kernel, results in an empty crate.

Supported environment variables

This crate depends on some environment variables, and variants of those. For each environment variable (e.g., CC), the following are the accepted variants of it:

  • <var>_<target>, e.g., CC_aarch64-unknown-linux-gnu.
  • <var>_<target-with-underscores>, e.g., CC_aarch64_unknown_linux_gnu.
  • TARGET_<var>, e.g., TARGET_CC.
  • <var>, e.g., CC.

The following environment variables (and their variants) affect how this crate is built:

  • SELINUX_STATIC
  • SELINUX_PATH
  • SELINUX_INCLUDE_DIR
  • SELINUX_LIB_DIR
  • SYSROOT
  • CC
  • CFLAGS

Dynamic or static linking

This crate links to libselinux dynamically if possible, except when targeting platforms based on the musl C library.

This behavior can be changed either by setting the environment variable SELINUX_STATIC to 1, or by enabling the crate feature static. If both are defined, then the value of SELINUX_STATIC takes precedence.

Setting SELINUX_STATIC to 0 mandates dynamic linking.

Finding SELinux library and headers

By default, this crate finds SELinux headers and library based on the default target C compiler.

This behavior can be changed by:

  • Either defining the environment variable SELINUX_PATH to the path of a directory containing the sub-directories include and lib where the headers and library are installed.
  • Or by defining one or both of the environment variables SELINUX_INCLUDE_DIR and SELINUX_LIB_DIR to paths to the directories where headers and library are present. If SELINUX_PATH is also defined, then SELINUX_INCLUDE_DIR and SELINUX_LIB_DIR take precedence.

Depending on this crate

This crate provides the following variables to other crates that depend on it:

  • DEP_SELINUX_INCLUDE: Path of the directory where library C header files reside.
  • DEP_SELINUX_LIB: Path of the directory where the library binary resides.

Versioning

This project adheres to Semantic Versioning. The CHANGELOG.md file details notable changes over time.

Dependencies

~0–2.8MB
~48K SLoC