]> git.proxmox.com Git - qemu-server.git/commitdiff
add Agent helper package
authorDominik Csapak <d.csapak@proxmox.com>
Tue, 26 Jun 2018 12:15:43 +0000 (14:15 +0200)
committerThomas Lamprecht <t.lamprecht@proxmox.com>
Wed, 11 Jul 2018 08:29:45 +0000 (10:29 +0200)
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
PVE/API2/Qemu/Agent.pm
PVE/QemuServer/Agent.pm [new file with mode: 0644]
PVE/QemuServer/Makefile

index 5141b4e2a50312aa002f275b32bda58ad07bcf32..f50fde5e42a257e3c94e0b770c2ca752196bbe90 100644 (file)
@@ -6,6 +6,7 @@ use warnings;
 use PVE::RESTHandler;
 use PVE::JSONSchema qw(get_standard_option);
 use PVE::QemuServer;
+use PVE::QemuServer::Agent qw(agent_available);
 
 use base qw(PVE::RESTHandler);
 
@@ -172,9 +173,7 @@ sub register_command {
 
            my $conf = PVE::QemuConfig->load_config ($vmid); # check if VM exists
 
-           die "No Qemu Guest Agent\n" if !defined($conf->{agent});
-           die "VM $vmid is not running\n" if !PVE::QemuServer::check_running($vmid);
-           die "Qemu Guest Agent is not running\n" if !PVE::QemuServer::qga_check_running($vmid, 1);
+           agent_available($vmid, $conf);
 
            my $cmd = $param->{command} // $command;
            my $res = PVE::QemuServer::vm_mon_cmd($vmid, "guest-$cmd");
diff --git a/PVE/QemuServer/Agent.pm b/PVE/QemuServer/Agent.pm
new file mode 100644 (file)
index 0000000..8fad109
--- /dev/null
@@ -0,0 +1,65 @@
+package PVE::QemuServer::Agent;
+
+use strict;
+use warnings;
+use PVE::QemuServer;
+use base 'Exporter';
+
+our @EXPORT_OK = qw(
+check_agent_error
+agent_available
+agent_cmd
+);
+
+sub check_agent_error {
+    my ($result, $errmsg, $noerr) = @_;
+
+    $errmsg //= '';
+    my $error = '';
+    if (ref($result) eq 'HASH' && $result->{error} && $result->{error}->{desc}) {
+       $error = "Agent Error: $result->{error}->{desc}\n";
+    } elsif (!defined($result)) {
+       $error = "Agent Error: $errmsg\n";
+    }
+
+    if ($error) {
+       die $error if !$noerr;
+
+       warn $error;
+       return undef;
+    }
+
+    return 1;
+}
+
+sub agent_available {
+    my ($vmid, $conf, $noerr) = @_;
+
+    eval {
+       die "No Qemu Guest Agent\n" if !defined($conf->{agent});
+       die "VM $vmid is not running\n" if !PVE::QemuServer::check_running($vmid);
+       die "Qemu Guest Agent is not running\n" if !PVE::QemuServer::qga_check_running($vmid, 1);
+    };
+
+    if (my $err = $@) {
+       die $err if !$noerr;
+       return undef;
+    }
+
+    return 1;
+}
+
+# loads config, checks if available, executes command, checks for errors
+sub agent_cmd {
+    my ($vmid, $cmd, $params, $errormsg, $noerr) = @_;
+
+    my $conf = PVE::QemuConfig->load_config($vmid); # also checks if VM exists
+    agent_available($vmid, $conf, $noerr);
+
+    my $res = PVE::QemuServer::vm_mon_cmd($vmid, "guest-$cmd", %$params);
+    check_agent_error($res, $errormsg, $noerr);
+
+    return $res;
+}
+
+1;
index 0d783240499b671856e36ba77ec5ff3031a5573c..afc39a382d3175c30ec3a1816bbb753cc41acd57 100644 (file)
@@ -4,6 +4,7 @@ SOURCES=PCI.pm          \
        ImportDisk.pm   \
        OVF.pm          \
        Cloudinit.pm    \
+       Agent.pm        \
 
 .PHONY: install
 install: ${SOURCES}