view src/environ.rs @ 148:4b3a5095f68c

Move libpam-sys helpers into their own library. - Renames libpam-sys-helpers to libpam-sys-consts. - Moves libpam-sys-helpers::helpers into libpam-sys-helpers, which moves them completely out of libpam-sys's dependency chain. - Moves the aliases from libpam-sys into libpam-sys::aliases.
author Paul Fisher <paul@pfish.zone>
date Mon, 07 Jul 2025 12:11:43 -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>;
}