From 118aeac6e0e4a10b2728fd13920a2c6c3808a6ff Mon Sep 17 00:00:00 2001 From: rabite Date: Wed, 20 Mar 2019 15:49:41 +0100 Subject: faster read permission checking --- src/files.rs | 34 +++++++++++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) (limited to 'src/files.rs') diff --git a/src/files.rs b/src/files.rs index 53f167a..2ea4512 100644 --- a/src/files.rs +++ b/src/files.rs @@ -9,7 +9,10 @@ use std::ffi::{OsStr, OsString}; use lscolors::LsColors; use mime_detective; -use users; +use users::{get_current_username, + get_current_groupname, + get_user_by_uid, + get_group_by_gid}; use chrono::TimeZone; use failure::Error; use notify::DebouncedEvent; @@ -553,6 +556,35 @@ impl File { Ok(()) } + pub fn is_readable(&self) -> HResult { + let meta = self.meta()?; + let current_user = get_current_username()?.to_string_lossy().to_string(); + let current_group = get_current_groupname()?.to_string_lossy().to_string(); + let file_user = get_user_by_uid(meta.uid())? + .name() + .to_string_lossy() + .to_string(); + let file_group = get_group_by_gid(meta.gid())? + .name() + .to_string_lossy() + .to_string(); + let perms = meta.mode(); + + let user_readable = perms & 0o400; + let group_readable = perms & 0o040; + let other_readable = perms & 0o004; + + if current_user == file_user && user_readable > 0 { + Ok(true) + } else if current_group == file_group && group_readable > 0 { + Ok(true) + } else if other_readable > 0 { + Ok(true) + } else { + Ok(false) + } + } + pub fn pretty_print_permissions(&self) -> HResult { let perms: usize = format!("{:o}", self.meta()?.mode()).parse().unwrap(); let perms: usize = perms % 800; -- cgit v1.2.3