#!/usr/bin/perl # # This is the master daemon that manages all periodically run processes on Striker dashboards and Anvil! # nodes. # # Exit codes; # 0 = Normal exit # 1 = md5sum of this program changed. Exited to reload. # # TODO: # use strict; use warnings; use Anvil::Tools; my $THIS_FILE = ($0 =~ /^.*\/(.*)$/)[0]; my $running_directory = ($0 =~ /^(.*?)\/$THIS_FILE$/)[0]; if (($running_directory =~ /^\./) && ($ENV{PWD})) { $running_directory =~ s/^\./$ENV{PWD}/; } # Turn off buffering so that the pinwheel will display while waiting for the SSH call(s) to complete. $| = 1; my $anvil = Anvil::Tools->new(); $anvil->Log->level({set => 1}); # There are some things we only want to run on (re)start and don't need to always run. run_once($anvil); # Calculate my sum so that we can exit if it changes later. $anvil->Storage->record_md5sums; # These are the things we always want running. while(1) { # Loop and sleep for 2s. keep_running($anvil); # Exit if called with '--run-once' if ($anvil->data->{switches}{'run-once'}) { $anvil->nice_exit({code => 0}); } # Has the file on disk changed? if ($anvil->Storage->check_md5sums) { $anvil->Log->entry({source => $THIS_FILE, line => __LINE__, level => 0, priority => "warn", key => "message_0014"}); $anvil->nice_exit({code => 1}); } # Sleep now. sleep 2; } $anvil->nice_exit({code => 0}); ############################################################################################################# # Functions # ############################################################################################################# # These are tools that don't need to constantly run. sub run_once { my ($anvil) = @_; # Check that the database is ready. my $shell_call = $anvil->data->{path}{exe}{'anvil-prep-database'}; $anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { shell_call => $shell_call }}); my $database_output = $anvil->System->call({shell_call => $shell_call, source => $THIS_FILE, line => __LINE__}); if ($database_output) { $anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { database_output => $database_output }}); } return(0); } # These are tools that need to keep running. sub keep_running { my ($anvil) = @_; # Update hardware state files. update_state_file($anvil); # Run any pending jobs by calling 'anvil-jobs' with the 'job_uuid' as a background process. # Check the local network and running services and tune the firewall as things change. return(0); } # This calls 'scancore-update-states' which will scan the local machine's state (hardware and software) and # record write it out to an HTML file sub update_state_file { my ($anvil) = @_; my $shell_call = $anvil->data->{path}{exe}{'anvil-update-states'}; $anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { shell_call => $shell_call }}); my $states_output = $anvil->System->call({shell_call => $shell_call, source => $THIS_FILE, line => __LINE__}); if ($states_output) { $anvil->Log->variables({source => $THIS_FILE, line => __LINE__, level => 3, list => { states_output => $states_output }}); } return(0); }