sudo-rs 0.2.9

A memory safe implementation of sudo and su.
Documentation
use std::{fs::File, io, os::fd::AsRawFd};

use crate::{
    cutils::cerr,
    system::interface::{GroupId, UserId},
};

pub(crate) trait Chown {
    fn chown(&self, uid: UserId, gid: GroupId) -> io::Result<()>;
}

impl Chown for File {
    fn chown(&self, owner: UserId, group: GroupId) -> io::Result<()> {
        let fd = self.as_raw_fd();

        // SAFETY: `fchown` is passed a proper file descriptor; and even if the user/group id
        // is invalid, it will not cause UB.
        cerr(unsafe { libc::fchown(fd, owner.inner(), group.inner()) }).map(|_| ())
    }
}