[pve-devel] [PATCH pve-client] Add the remaining guest commands

René Jochum r.jochum at proxmox.com
Thu Jun 14 12:15:38 CEST 2018


Signed-off-by: René Jochum <r.jochum at proxmox.com>
---
 PVE/APIClient/Commands/GuestStatus.pm | 87 +++++++++++++++++++++++++++++++++++
 pveclient                             |  3 ++
 2 files changed, 90 insertions(+)

diff --git a/PVE/APIClient/Commands/GuestStatus.pm b/PVE/APIClient/Commands/GuestStatus.pm
index 57784e5..92f424d 100644
--- a/PVE/APIClient/Commands/GuestStatus.pm
+++ b/PVE/APIClient/Commands/GuestStatus.pm
@@ -61,6 +61,11 @@ __PACKAGE__->register_method ({
 	properties => {
 	    remote => get_standard_option('pveclient-remote-name'),
 	    vmid => get_standard_option('pve-vmid'),
+	    timeout => {
+		description => "Timeout in seconds",
+		type => 'integer',
+		minimum => 1
+	    },
 	},
     },
     returns => { type => 'null'},
@@ -76,6 +81,88 @@ __PACKAGE__->register_method ({
     }});
 
 __PACKAGE__->register_method ({
+    name => 'shutdown',
+    path => 'shutdown',
+    method => 'POST',
+    description => "Stop a guest (VM/Container).",
+    parameters => {
+	additionalProperties => 0,
+	properties => {
+	    remote => get_standard_option('pveclient-remote-name'),
+	    vmid => get_standard_option('pve-vmid'),
+	    force => {
+		description => "Make sure the Container/VM stops.",
+		type => 'boolean',
+		optional => 1,
+	    },
+	    timeout => {
+		description => "Timeout in seconds",
+		type => 'integer',
+		minimum => 1
+	    },
+	},
+    },
+    returns => { type => 'null'},
+    code => sub {
+	my ($param) = @_;
+
+	my $remote = PVE::APIClient::Tools::extract_param($param, 'remote');
+	my $vmid = PVE::APIClient::Tools::extract_param($param, 'vmid');
+
+	$guest_status_command->($remote, $vmid, 'shutdown', $param);
+
+	return undef;
+    }});
+
+__PACKAGE__->register_method ({
+    name => 'suspend',
+    path => 'suspend',
+    method => 'POST',
+    description => "Suspend a guest VM.",
+    parameters => {
+	additionalProperties => 0,
+	properties => {
+	    remote => get_standard_option('pveclient-remote-name'),
+	    vmid => get_standard_option('pve-vmid'),
+	},
+    },
+    returns => { type => 'null'},
+    code => sub {
+	my ($param) = @_;
+
+	my $remote = PVE::APIClient::Tools::extract_param($param, 'remote');
+	my $vmid = PVE::APIClient::Tools::extract_param($param, 'vmid');
+
+	$guest_status_command->($remote, $vmid, 'suspend', $param);
+
+	return undef;
+    }});
+
+__PACKAGE__->register_method ({
+    name => 'resume',
+    path => 'resume',
+    method => 'POST',
+    description => "Resume a guest VM.",
+    parameters => {
+	additionalProperties => 0,
+	properties => {
+	    remote => get_standard_option('pveclient-remote-name'),
+	    vmid => get_standard_option('pve-vmid'),
+	},
+    },
+    returns => { type => 'null'},
+    code => sub {
+	my ($param) = @_;
+
+	my $remote = PVE::APIClient::Tools::extract_param($param, 'remote');
+	my $vmid = PVE::APIClient::Tools::extract_param($param, 'vmid');
+
+	$guest_status_command->($remote, $vmid, 'resume', $param);
+
+	return undef;
+    }});
+
+__PACKAGE__->register_method ({
     name => 'spice',
     path => 'spice',
     method => 'POST',
diff --git a/pveclient b/pveclient
index 404090f..9bcbff2 100755
--- a/pveclient
+++ b/pveclient
@@ -177,9 +177,12 @@ our $cmddef = {
     lxc => $PVE::APIClient::Commands::lxc::cmddef,
     remote => $PVE::APIClient::Commands::remote::cmddef,
 
+    resume => [ 'PVE::APIClient::Commands::GuestStatus', 'resume', ['remote', 'vmid']],
+    shutdown => [ 'PVE::APIClient::Commands::GuestStatus', 'shutdown', ['remote', 'vmid']],
     spice => [ 'PVE::APIClient::Commands::GuestStatus', 'spice', ['remote', 'vmid']],
     start => [ 'PVE::APIClient::Commands::GuestStatus', 'start', ['remote', 'vmid']],
     stop => [ 'PVE::APIClient::Commands::GuestStatus', 'stop', ['remote', 'vmid']],
+    suspend => [ 'PVE::APIClient::Commands::GuestStatus', 'suspend', ['remote', 'vmid']],
 
     api => {
 	get => [ __PACKAGE__, 'pveclient_get', ['remote', 'api_path'], {}, $format_result ],
-- 
2.11.0



More information about the pve-devel mailing list