Crates.io | wil |
lib.rs | wil |
version | 0.0.6 |
source | src |
created_at | 2020-05-20 08:24:30.449945 |
updated_at | 2020-05-21 21:12:01.703014 |
description | This crates is a demonstrator of what a Windows Implementation Library in Rust could look like |
homepage | |
repository | https://github.com/jeanga/wil-rs |
max_upload_size | |
id | 243724 |
size | 15,221 |
Windows Implementation Library for Rust
This crate does not provide raw FFI bindings to Windows API (the winapi crate is what you are looking for). This crate does demonstrate what a Windows Implementation Library could look like in Rust ("à la" https://github.com/microsoft/wil in C++).
The winapi crate is doing a great job in providing the bindings for Windows APIs. What winapi does not provide is a safety wrapper arroung those APIs (with error handling, resource management, ...).
This "wil" crate aims to present what could be a safe wrapper for Windows API.
If this crate is massively missing that something you need. Feel free to create an issue, open a pull request.
Cargo.toml:
[target.'cfg(windows)'.dependencies]
wil = "0.0.3"
winapi = "0.3.8"
main.rs:
use wil::token::Token;
use wil::errorhandling::WinAPIError;
use winapi::um::winnt::{TokenImpersonation, TokenPrimary};
use winapi::um::winnt::{TOKEN_DUPLICATE, TOKEN_QUERY, TOKEN_QUERY_SOURCE};
fn main() -> Result<(), WinAPIError> {
let token =
Token::from_current_process(TOKEN_DUPLICATE | TOKEN_QUERY | TOKEN_QUERY_SOURCE)?;
let token = if token.token_type()? == TokenPrimary {
token.duplicate(TokenImpersonation)?
} else {
token
};
if !token.is_admin()? {
if token.can_elevate()? {
println!("user is not an admin but can elevate to one");
} else {
println!("user is not an admin");
}
}
else {
println!("user is an admin");
}
Ok(())
}