manager: add user permissions command
useful for debugging complex ACL setups. Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com>
This commit is contained in:
parent
2156dec5a9
commit
4615325f9e
|
@ -1,12 +1,14 @@
|
||||||
use anyhow::Error;
|
use anyhow::Error;
|
||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
|
|
||||||
|
use std::collections::HashMap;
|
||||||
|
|
||||||
use proxmox::api::{api, cli::*, RpcEnvironment, ApiHandler};
|
use proxmox::api::{api, cli::*, RpcEnvironment, ApiHandler};
|
||||||
|
|
||||||
use proxmox_backup::config;
|
use proxmox_backup::config;
|
||||||
use proxmox_backup::tools;
|
use proxmox_backup::tools;
|
||||||
use proxmox_backup::api2;
|
use proxmox_backup::api2;
|
||||||
use proxmox_backup::api2::types::Userid;
|
use proxmox_backup::api2::types::{ACL_PATH_SCHEMA, Authid, Userid};
|
||||||
|
|
||||||
#[api(
|
#[api(
|
||||||
input: {
|
input: {
|
||||||
|
@ -91,6 +93,64 @@ fn list_tokens(param: Value, rpcenv: &mut dyn RpcEnvironment) -> Result<Value, E
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#[api(
|
||||||
|
input: {
|
||||||
|
properties: {
|
||||||
|
"output-format": {
|
||||||
|
schema: OUTPUT_FORMAT,
|
||||||
|
optional: true,
|
||||||
|
},
|
||||||
|
auth_id: {
|
||||||
|
type: Authid,
|
||||||
|
},
|
||||||
|
path: {
|
||||||
|
schema: ACL_PATH_SCHEMA,
|
||||||
|
optional: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)]
|
||||||
|
/// List permissions of user/token.
|
||||||
|
fn list_permissions(param: Value, rpcenv: &mut dyn RpcEnvironment) -> Result<Value, Error> {
|
||||||
|
|
||||||
|
let output_format = get_output_format(¶m);
|
||||||
|
|
||||||
|
let info = &api2::access::API_METHOD_LIST_PERMISSIONS;
|
||||||
|
let mut data = match info.handler {
|
||||||
|
ApiHandler::Sync(handler) => (handler)(param, info, rpcenv)?,
|
||||||
|
_ => unreachable!(),
|
||||||
|
};
|
||||||
|
|
||||||
|
if output_format == "text" {
|
||||||
|
println!("Privileges with (*) have the propagate flag set\n");
|
||||||
|
let data:HashMap<String, HashMap<String, bool>> = serde_json::from_value(data)?;
|
||||||
|
let mut paths:Vec<String> = data.keys().cloned().collect();
|
||||||
|
paths.sort_unstable();
|
||||||
|
for path in paths {
|
||||||
|
println!("Path: {}", path);
|
||||||
|
let priv_map = data.get(&path).unwrap();
|
||||||
|
let mut privs:Vec<String> = priv_map.keys().cloned().collect();
|
||||||
|
if privs.is_empty() {
|
||||||
|
println!("- NoAccess");
|
||||||
|
} else {
|
||||||
|
privs.sort_unstable();
|
||||||
|
for privilege in privs {
|
||||||
|
if *priv_map.get(&privilege).unwrap() {
|
||||||
|
println!("- {} (*)", privilege);
|
||||||
|
} else {
|
||||||
|
println!("- {}", privilege);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
format_and_print_result(&mut data, &output_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(Value::Null)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
pub fn user_commands() -> CommandLineInterface {
|
pub fn user_commands() -> CommandLineInterface {
|
||||||
|
|
||||||
let cmd_def = CliCommandMap::new()
|
let cmd_def = CliCommandMap::new()
|
||||||
|
@ -131,6 +191,13 @@ pub fn user_commands() -> CommandLineInterface {
|
||||||
.arg_param(&["userid", "tokenname"])
|
.arg_param(&["userid", "tokenname"])
|
||||||
.completion_cb("userid", config::user::complete_userid)
|
.completion_cb("userid", config::user::complete_userid)
|
||||||
.completion_cb("tokenname", config::user::complete_token_name)
|
.completion_cb("tokenname", config::user::complete_token_name)
|
||||||
|
)
|
||||||
|
.insert(
|
||||||
|
"permissions",
|
||||||
|
CliCommand::new(&&API_METHOD_LIST_PERMISSIONS)
|
||||||
|
.arg_param(&["auth_id"])
|
||||||
|
.completion_cb("auth_id", config::user::complete_authid)
|
||||||
|
.completion_cb("path", config::datastore::complete_acl_path)
|
||||||
);
|
);
|
||||||
|
|
||||||
cmd_def.into()
|
cmd_def.into()
|
||||||
|
|
Loading…
Reference in New Issue