#!/usr/bin/perl # # # use strict; use warnings; use Anvil::Tools; $| = 1; my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0]; my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0]; if (($running_directory =~ /^\./) && ($ENV{PWD})) { $running_directory =~ s/^\./$ENV{PWD}/; } my $anvil = Anvil::Tools->new(); sub system_call { my $parameters = shift; my $shell_call = $parameters->{shell_call}; my ($shell_output, $shell_return_code) = $anvil->System->call({ shell_call => $shell_call }); $anvil->Log->variables({ source => $THIS_FILE, line => __LINE__, level => 2, list => { shell_call => $shell_call, shell_output => $shell_output, shell_return_code => $shell_return_code } }); return ($shell_output, $shell_return_code); } sub is_existing_server_screenshot_outdated { my $parameters = shift; my $server_uuid = $parameters->{server_uuid}; my ($encoded_image, $variable_uuid, $variable_mtime) = $anvil->Database->read_variable({ variable_name => "server_screenshot::".$server_uuid }); my $time_difference = time - $variable_mtime; return $time_difference > 120 ? 1 : 0; } sub get_server_screenshot { my $parameters = shift; my $server_uuid = $parameters->{server_uuid}; my ($resize_x, $resize_y) = split(/x/ , $parameters->{resize_args}); my $shell_call = "virsh screenshot --domain ".$server_uuid." --file /dev/stdout | sed 's/Screenshot.*//'"; if ($resize_x =~ /^\d+$/ && $resize_y =~ /^\d+$/) { $shell_call .= " | pamscale -quiet -xyfit ".$resize_x." ".$resize_y; $shell_call .= " | pamtopng -quiet"; } $shell_call .= " | base64 --wrap 0"; my ($shell_output, $shell_return_code) = system_call({ shell_call => $shell_call }); return $shell_return_code == 0 ? $shell_output : undef; } sub insert_server_screenshot { my $parameters = shift; my $server_uuid = $parameters->{server_uuid}; my $encoded_image = $parameters->{encoded_image}; $anvil->Database->insert_or_update_states({ state_name => "server_screenshot::".$server_uuid, state_note => $encoded_image }); } $anvil->Get->switches; $anvil->Database->connect; $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 2, secure => 0, key => "log_0132"}); if (not $anvil->data->{sys}{database}{connections}) { # No databases, exit. $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, 'print' => 1, priority => "err", key => "error_0003"}); $anvil->nice_exit({exit_code => 1}); } # Try to get a job UUID if not given. if (not $anvil->data->{switches}{'job-uuid'}) { $anvil->data->{switches}{'job-uuid'} = $anvil->Job->get_job_uuid({ program => $THIS_FILE }); $anvil->Log->variables({ source => $THIS_FILE, line => __LINE__, level => 2, list => { "switches::job-uuid" => $anvil->data->{switches}{'job-uuid'} } }); } # Handle this script as a job when job UUID is provided. if ($anvil->data->{switches}{'job-uuid'}) { $anvil->Job->clear(); $anvil->Job->get_job_details(); $anvil->Job->update_progress({ progress => 1, job_picked_up_by => $$, job_picked_up_at => time, message => "message_0263" }); foreach my $line (split/\n/, $anvil->data->{jobs}{job_data}) { if ($line =~ /server-uuid=(.*?)$/) { $anvil->data->{switches}{'server-uuid'} = $1; } if ($line =~ /resize=(.*?)$/) { $anvil->data->{switches}{'resize'} = $1; } if ($line =~ /stdout=(.*?)$/) { $anvil->data->{switches}{'stdout'} = $1; } } } my $server_uuid = $anvil->data->{switches}{'server-uuid'}; my $resize_args = $anvil->data->{switches}{'resize'}; my $is_stdout = $anvil->data->{switches}{'stdout'}; my $job_uuid = $anvil->data->{switches}{'job-uuid'}; $anvil->Log->variables({ source => $THIS_FILE, line => __LINE__, level => 2, list => { server_uuid => $server_uuid, resize_args => $resize_args, is_stdout => $is_stdout, job_uuid => $job_uuid } }); if ($server_uuid) { my $encoded_image; if ($is_stdout) { $encoded_image = get_server_screenshot({ server_uuid => $server_uuid, resize_args => $resize_args }); if (defined $encoded_image) { print($encoded_image); $anvil->Job->update_progress({ progress => 100, message => "message_0264" }); } else { $anvil->Job->update_progress({ progress => 100, message => "message_0265" }); } } elsif (is_existing_server_screenshot_outdated({ server_uuid => $server_uuid })) { $encoded_image = get_server_screenshot({ server_uuid => $server_uuid, resize_args => $resize_args }); if (defined $encoded_image) { insert_server_screenshot({ server_uuid => $server_uuid, encoded_image => $encoded_image }); $anvil->Job->update_progress({ progress => 100, message => "message_0264" }); } else { $anvil->Job->update_progress({ progress => 100, message => "message_0265" }); } } else { $anvil->Job->update_progress({ progress => 100, message => "message_0266" }); } } else { $anvil->Job->update_progress({ progress => 100, message => "message_0266" }); }