]>
git.proxmox.com Git - pve-access-control.git/blob - PVE/CLI/pveum.pm
1 package PVE
::CLI
::pveum
;
6 use PVE
::RPCEnvironment
;
11 use PVE
::API2
::AccessControl
;
15 use base
qw(PVE::CLIHandler);
17 sub setup_environment
{
18 PVE
::RPCEnvironment-
>setup_default_cli_env();
25 'change_password' => [
26 PVE
::CLIHandler
::get_standard_mapping
('pve-password'),
29 PVE
::CLIHandler
::get_standard_mapping
('pve-password', {
31 # do not accept values given on cmdline
32 return PVE
::PTY
::read_password
('Enter password: ');
38 return $mapping->{$name};
43 add
=> [ 'PVE::API2::User', 'create_user', ['userid'] ],
44 modify
=> [ 'PVE::API2::User', 'update_user', ['userid'] ],
45 delete => [ 'PVE::API2::User', 'delete_user', ['userid'] ],
48 add
=> [ 'PVE::API2::Group', 'create_group', ['groupid'] ],
49 modify
=> [ 'PVE::API2::Group', 'update_group', ['groupid'] ],
50 delete => [ 'PVE::API2::Group', 'delete_group', ['groupid'] ],
53 add
=> [ 'PVE::API2::Role', 'create_role', ['roleid'] ],
54 modify
=> [ 'PVE::API2::Role', 'update_role', ['roleid'] ],
55 delete => [ 'PVE::API2::Role', 'delete_role', ['roleid'] ],
58 modify
=> [ 'PVE::API2::ACL', 'update_acl', ['path'], { delete => 0 }],
59 delete => [ 'PVE::API2::ACL', 'update_acl', ['path'], { delete => 1 }],
61 ticket
=> [ 'PVE::API2::AccessControl', 'create_ticket', ['username'], undef,
64 print "$res->{ticket}\n";
67 passwd
=> [ 'PVE::API2::AccessControl', 'change_password', ['userid'] ],
69 useradd
=> { alias
=> 'user add' },
70 usermod
=> { alias
=> 'user modify' },
71 userdel
=> { alias
=> 'user delete' },
73 groupadd
=> { alias
=> 'group add' },
74 groupmod
=> { alias
=> 'group modify' },
75 groupdel
=> { alias
=> 'group delete' },
77 roleadd
=> { alias
=> 'role add' },
78 rolemod
=> { alias
=> 'role modify' },
79 roledel
=> { alias
=> 'role delete' },
81 aclmod
=> { alias
=> 'acl modify' },
82 acldel
=> { alias
=> 'acl delete' },