1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
use crate::{GroupOpt, GroupPosix};
impl GroupOpt {
pub fn debug(&self) -> bool {
match self {
GroupOpt::List(copt) => copt.debug,
GroupOpt::Get(gcopt) => gcopt.copt.debug,
GroupOpt::Create(gcopt) => gcopt.copt.debug,
GroupOpt::Delete(gcopt) => gcopt.copt.debug,
GroupOpt::ListMembers(gcopt) => gcopt.copt.debug,
GroupOpt::AddMembers(gcopt) => gcopt.copt.debug,
GroupOpt::RemoveMembers(gcopt) => gcopt.copt.debug,
GroupOpt::SetMembers(gcopt) => gcopt.copt.debug,
GroupOpt::PurgeMembers(gcopt) => gcopt.copt.debug,
GroupOpt::Posix(gpopt) => match gpopt {
GroupPosix::Show(gcopt) => gcopt.copt.debug,
GroupPosix::Set(gcopt) => gcopt.copt.debug,
},
}
}
pub fn exec(&self) {
match self {
GroupOpt::List(copt) => {
let client = copt.to_client();
match client.idm_group_list() {
Ok(r) => r.iter().for_each(|ent| info!("{}", ent)),
Err(e) => error!("Error -> {:?}", e),
}
}
GroupOpt::Get(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_get(gcopt.name.as_str()) {
Ok(Some(e)) => info!("{}", e),
Ok(None) => info!("No matching group '{}'", gcopt.name.as_str()),
Err(e) => error!("Error -> {:?}", e),
}
}
GroupOpt::Create(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_create(gcopt.name.as_str()) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!("Successfully created group '{}'", gcopt.name.as_str()),
}
}
GroupOpt::Delete(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_delete(gcopt.name.as_str()) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!("Successfully deleted group {}", gcopt.name.as_str()),
}
}
GroupOpt::PurgeMembers(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_purge_members(gcopt.name.as_str()) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!(
"Successfully purged members of group {}",
gcopt.name.as_str()
),
}
}
GroupOpt::ListMembers(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_get_members(gcopt.name.as_str()) {
Ok(Some(groups)) => groups.iter().for_each(|m| info!("{:?}", m)),
Ok(None) => info!("No members in group {}", gcopt.name.as_str()),
Err(e) => error!("Error -> {:?}", e),
}
}
GroupOpt::AddMembers(gcopt) => {
let client = gcopt.copt.to_client();
let new_members: Vec<&str> = gcopt.members.iter().map(String::as_str).collect();
match client.idm_group_add_members(gcopt.name.as_str(), &new_members) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!("Successfully added members to {}", gcopt.name.as_str()),
}
}
GroupOpt::RemoveMembers(gcopt) => {
let client = gcopt.copt.to_client();
let remove_members: Vec<&str> = gcopt.members.iter().map(String::as_str).collect();
match client.idm_group_remove_members(gcopt.name.as_str(), &remove_members) {
Err(e) => error!("Failed to remove members -> {:?}", e),
Ok(_) => info!("Successfully removed members from {}", gcopt.name.as_str()),
}
}
GroupOpt::SetMembers(gcopt) => {
let client = gcopt.copt.to_client();
let new_members: Vec<&str> = gcopt.members.iter().map(String::as_str).collect();
match client.idm_group_set_members(gcopt.name.as_str(), &new_members) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!("Successfully set members for group {}", gcopt.name.as_str()),
}
}
GroupOpt::Posix(gpopt) => match gpopt {
GroupPosix::Show(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_unix_token_get(gcopt.name.as_str()) {
Ok(token) => info!("{}", token),
Err(e) => error!("Error -> {:?}", e),
}
}
GroupPosix::Set(gcopt) => {
let client = gcopt.copt.to_client();
match client.idm_group_unix_extend(gcopt.name.as_str(), gcopt.gidnumber) {
Err(e) => error!("Error -> {:?}", e),
Ok(_) => info!(
"Success adding POSIX configuration for group {}",
gcopt.name.as_str()
),
}
}
},
}
}
}