view src/environ.rs @ 171:e27c5c667a5a

Create full new types for return code and flags, separate end to end. This plumbs the ReturnCode and RawFlags types through the places where we call into or are called from PAM. Also adds Sun documentation to the project.
author Paul Fisher <paul@pfish.zone>
date Fri, 25 Jul 2025 20:52:14 -0400
parents a508a69c068a
children
line wrap: on
line source

//! Traits and stuff for managing the environment of a PAM handle.
//!
//! PAM modules can set environment variables to apply to a user session.
//! This module manages the interface for doing all of that.

use std::ffi::{OsStr, OsString};

/// A key/value map for environment variables, as [`OsString`]s.
///
/// This is a limited subset of what [`HashMap`](std::collections::HashMap)
/// can do. Notably, we do *not* support mutable iteration.
pub trait EnvironMap<'a> {
    /// Gets the environment variable of the given key.
    fn get(&self, key: impl AsRef<OsStr>) -> Option<OsString>;

    /// Iterates over the key/value pairs of the environment.
    fn iter(&self) -> impl Iterator<Item = (OsString, OsString)>;
}

pub trait EnvironMapMut<'a>: EnvironMap<'a> {
    /// Sets the environment variable with the given key,
    /// returning the old one if present.
    fn insert(&mut self, key: impl AsRef<OsStr>, val: impl AsRef<OsStr>) -> Option<OsString>;

    /// Removes the environment variable from the map, returning its old value
    /// if present.
    fn remove(&mut self, key: impl AsRef<OsStr>) -> Option<OsString>;
}