users 0.11.0

Library for accessing Unix users and groups
Documentation
extern crate users;
use users::{Users, Groups, UsersCache};
use users::os::unix::{UserExt, GroupExt};
//use users::os::bsd::UserExt as BSDUserExt;

extern crate env_logger;


fn main() {
    env_logger::init();

	let cache = UsersCache::new();

	let current_uid = cache.get_current_uid();
	println!("Your UID is {}", current_uid);

	let you = cache.get_user_by_uid(current_uid).expect("No entry for current user!");
	println!("Your username is {}", you.name().to_string_lossy());
	println!("Your shell is {}", you.shell().display());
	println!("Your home directory is {}", you.home_dir().display());

    // The two fields below are only available on BSD systems.
    // Linux systems don’t have the fields in their `passwd` structs!
    //println!("Your password change timestamp is {}", you.password_change_time());
    //println!("Your password expiry timestamp is {}", you.password_expire_time());

	let primary_group = cache.get_group_by_gid(you.primary_group_id()).expect("No entry for your primary group!");
	println!("Your primary group has ID {} and name {}", primary_group.gid(), primary_group.name().to_string_lossy());

	if primary_group.members().is_empty() {
		println!("There are no other members of that group.");
	}
	else {
		for username in primary_group.members() {
			println!("User {} is also a member of that group.", username.to_string_lossy());
		}
	}
}