Documentation ¶
Index ¶
- Constants
- Variables
- func CanonicalizeContext(val string) (string, error)
- func Chcon(fpath string, label string, recurse bool) error
- func ClearLabels()
- func ContainerLabels() (processLabel string, fileLabel string)
- func CopyLevel(src, dest string) (string, error)
- func CurrentLabel() (string, error)
- func DefaultEnforceMode() int
- func DisableSecOpt() []string
- func DupSecOpt(src string) ([]string, error)
- func EnforceMode() int
- func ExecLabel() (string, error)
- func FSCreateLabel() (string, error)
- func FileLabel(fpath string) (string, error)
- func GetEnabled() bool
- func KeyLabel() (string, error)
- func PidLabel(pid int) (string, error)
- func ROFileLabel() string
- func ReleaseLabel(label string)
- func ReserveLabel(label string)
- func SecurityCheckContext(val string) error
- func SetDisabled()
- func SetEnforceMode(mode int) error
- func SetExecLabel(label string) error
- func SetFSCreateLabel(label string) error
- func SetFileLabel(fpath string, label string) error
- func SetKeyLabel(label string) error
- func SetSocketLabel(label string) error
- func SocketLabel() (string, error)
- type Context
Constants ¶
const ( // Enforcing constant indicate SELinux is in enforcing mode Enforcing = 1 // Permissive constant to indicate SELinux is in permissive mode Permissive = 0 // Disabled constant to indicate SELinux is disabled Disabled = -1 )
Variables ¶
var ( // ErrMCSAlreadyExists is returned when trying to allocate a duplicate MCS. ErrMCSAlreadyExists = errors.New("MCS label already exists") // ErrEmptyPath is returned when an empty path has been specified. ErrEmptyPath = errors.New("empty path") )
Functions ¶
func CanonicalizeContext ¶
CanonicalizeContext takes a context string and writes it to the kernel the function then returns the context that the kernel will use. This function can be used to see if two contexts are equivalent
func Chcon ¶
Chcon changes the `fpath` file object to the SELinux label `label`. If `fpath` is a directory and `recurse“ is true, Chcon will walk the directory tree setting the label.
func ContainerLabels ¶
ContainerLabels returns an allocated processLabel and fileLabel to be used for container labeling by the calling process.
func CopyLevel ¶
CopyLevel returns a label with the MLS/MCS level from src label replaced on the dest label.
func CurrentLabel ¶
CurrentLabel returns the SELinux label of the current process thread, or an error.
func DefaultEnforceMode ¶
func DefaultEnforceMode() int
DefaultEnforceMode returns the systems default SELinux mode Enforcing, Permissive or Disabled. Note this is is just the default at boot time. EnforceMode tells you the systems current mode.
func DisableSecOpt ¶
func DisableSecOpt() []string
DisableSecOpt returns a security opt that can be used to disable SELinux labeling support for future container processes.
func DupSecOpt ¶
DupSecOpt takes an SELinux process label and returns security options that can be used to set the SELinux Type and Level for future container processes.
func EnforceMode ¶
func EnforceMode() int
EnforceMode returns the current SELinux mode Enforcing, Permissive, Disabled
func ExecLabel ¶
ExecLabel returns the SELinux label that the kernel will use for any programs that are executed by the current process thread, or an error.
func FSCreateLabel ¶
FSCreateLabel returns the default label the kernel which the kernel is using for file system objects created by this task. "" indicates default.
func ROFileLabel ¶
func ROFileLabel() string
ROFileLabel returns the specified SELinux readonly file label
func ReleaseLabel ¶
func ReleaseLabel(label string)
ReleaseLabel will unreserve the MLS/MCS Level field of the specified label. Allowing it to be used by another process.
func ReserveLabel ¶
func ReserveLabel(label string)
ReserveLabel reserves the MLS/MCS level component of the specified label
func SecurityCheckContext ¶
SecurityCheckContext validates that the SELinux label is understood by the kernel
func SetEnforceMode ¶
SetEnforceMode sets the current SELinux mode Enforcing, Permissive. Disabled is not valid, since this needs to be set at boot time.
func SetExecLabel ¶
SetExecLabel sets the SELinux label that the kernel will use for any programs that are executed by the current process thread, or an error.
func SetFSCreateLabel ¶
SetFSCreateLabel tells kernel the label to create all file system objects created by this task. Setting label="" to return to default.
func SetFileLabel ¶
SetFileLabel sets the SELinux label for this path or returns an error.
func SetKeyLabel ¶ added in v1.2.1
SetKeyLabel takes a process label and tells the kernel to assign the label to the next kernel keyring that gets created
func SetSocketLabel ¶
SetSocketLabel sets the SELinux label that the kernel will use for any programs that are executed by the current process thread, or an error.
func SocketLabel ¶
SocketLabel retrieves the current socket label setting
Types ¶
type Context ¶
Context is a representation of the SELinux label broken into 4 parts
func NewContext ¶
NewContext creates a new Context struct from the specified label