mirror of
				https://git.proxmox.com/git/proxmox
				synced 2025-11-04 15:05:21 +00:00 
			
		
		
		
	proxmox-sys: improve dev docs
And move WorkerTaskContext to top level. Signed-off-by: Dietmar Maurer <dietmar@proxmox.com>
This commit is contained in:
		
							parent
							
								
									e011964f81
								
							
						
					
					
						commit
						0806020ebf
					
				@ -1,3 +1,5 @@
 | 
			
		||||
//! Helpers to run a [Command] and check status code
 | 
			
		||||
 | 
			
		||||
use std::process::{Output, Command};
 | 
			
		||||
 | 
			
		||||
use anyhow::{bail, format_err, Error};
 | 
			
		||||
 | 
			
		||||
@ -1,3 +1,5 @@
 | 
			
		||||
//! Rust bindings for libcrypt
 | 
			
		||||
 | 
			
		||||
use std::ffi::CStr;
 | 
			
		||||
 | 
			
		||||
use anyhow::{bail, Error};
 | 
			
		||||
@ -18,6 +20,7 @@ struct crypt_data {
 | 
			
		||||
    internal: [libc::c_char; CRYPT_DATA_INTERNAL_SIZE],
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Encrypt a pasword - see man crypt(3)
 | 
			
		||||
pub fn crypt(password: &[u8], salt: &[u8]) -> Result<String, Error> {
 | 
			
		||||
    #[link(name = "crypt")]
 | 
			
		||||
    extern "C" {
 | 
			
		||||
@ -51,6 +54,7 @@ pub fn crypt(password: &[u8], salt: &[u8]) -> Result<String, Error> {
 | 
			
		||||
    Ok(String::from(res.to_str()?))
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Encrypt a pasword using sha256 hashing method
 | 
			
		||||
pub fn encrypt_pw(password: &str) -> Result<String, Error> {
 | 
			
		||||
 | 
			
		||||
    let salt = crate::linux::random_data(8)?;
 | 
			
		||||
@ -59,6 +63,7 @@ pub fn encrypt_pw(password: &str) -> Result<String, Error> {
 | 
			
		||||
    crypt(password.as_bytes(), salt.as_bytes())
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Verify if an encrypted password matches
 | 
			
		||||
pub fn verify_crypt_pw(password: &str, enc_password: &str) -> Result<(), Error> {
 | 
			
		||||
    let verify = crypt(password.as_bytes(), enc_password.as_bytes())?;
 | 
			
		||||
    if verify != enc_password {
 | 
			
		||||
 | 
			
		||||
@ -16,6 +16,7 @@ nix::ioctl_write_ptr!(fs_ioc_fssetxattr, b'X', 32, FSXAttr);
 | 
			
		||||
 | 
			
		||||
#[repr(C)]
 | 
			
		||||
#[derive(Debug)]
 | 
			
		||||
/// Rust bindings for struct fsxattr (fsgetxattr, fssetxattr)
 | 
			
		||||
pub struct FSXAttr {
 | 
			
		||||
    pub fsx_xflags: u32,
 | 
			
		||||
    pub fsx_extsize: u32,
 | 
			
		||||
 | 
			
		||||
@ -39,7 +39,7 @@ pub fn fchown(fd: RawFd, owner: Option<Uid>, group: Option<Gid>) -> Result<(), E
 | 
			
		||||
    Ok(())
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// FIXME: Consider using derive-builder!
 | 
			
		||||
/// Define permissions, owner and group when creating files/dirs
 | 
			
		||||
#[derive(Clone, Default)]
 | 
			
		||||
pub struct CreateOptions {
 | 
			
		||||
    perm: Option<stat::Mode>,
 | 
			
		||||
 | 
			
		||||
@ -8,4 +8,6 @@ pub mod logrotate;
 | 
			
		||||
pub mod macros;
 | 
			
		||||
pub mod mmap;
 | 
			
		||||
pub mod process_locker;
 | 
			
		||||
pub mod worker_task_context;
 | 
			
		||||
 | 
			
		||||
mod worker_task_context;
 | 
			
		||||
pub use worker_task_context::*;
 | 
			
		||||
 | 
			
		||||
@ -1,3 +1,5 @@
 | 
			
		||||
//! Log rotation helper
 | 
			
		||||
 | 
			
		||||
use std::path::{Path, PathBuf};
 | 
			
		||||
use std::fs::{File, rename};
 | 
			
		||||
use std::os::unix::io::{FromRawFd, IntoRawFd};
 | 
			
		||||
 | 
			
		||||
@ -56,6 +56,7 @@ impl<T: WorkerTaskContext + ?Sized> WorkerTaskContext for std::sync::Arc<T> {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Log an error to a [WorkerTaskContext]
 | 
			
		||||
#[macro_export]
 | 
			
		||||
macro_rules! task_error {
 | 
			
		||||
    ($task:expr, $($fmt:tt)+) => {{
 | 
			
		||||
@ -63,6 +64,7 @@ macro_rules! task_error {
 | 
			
		||||
    }};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Log a warning to a [WorkerTaskContext]
 | 
			
		||||
#[macro_export]
 | 
			
		||||
macro_rules! task_warn {
 | 
			
		||||
    ($task:expr, $($fmt:tt)+) => {{
 | 
			
		||||
@ -70,6 +72,7 @@ macro_rules! task_warn {
 | 
			
		||||
    }};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Log a message to a [WorkerTaskContext]
 | 
			
		||||
#[macro_export]
 | 
			
		||||
macro_rules! task_log {
 | 
			
		||||
    ($task:expr, $($fmt:tt)+) => {{
 | 
			
		||||
@ -77,6 +80,7 @@ macro_rules! task_log {
 | 
			
		||||
    }};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Log a debug message to a [WorkerTaskContext]
 | 
			
		||||
#[macro_export]
 | 
			
		||||
macro_rules! task_debug {
 | 
			
		||||
    ($task:expr, $($fmt:tt)+) => {{
 | 
			
		||||
@ -84,6 +88,7 @@ macro_rules! task_debug {
 | 
			
		||||
    }};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/// Log a trace message to a [WorkerTaskContext]
 | 
			
		||||
#[macro_export]
 | 
			
		||||
macro_rules! task_trace {
 | 
			
		||||
    ($task:expr, $($fmt:tt)+) => {{
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user