ზ3በંવવხްុլRxስសلçໂH℅૩/opt/fastcomet/nightwatch/Fastcomet/
Upload File :
Current File : //opt/fastcomet/nightwatch/Fastcomet/Nightwatch.pl
#!/usr/bin/env perl
use strict;
use warnings;

=head1 Perl Artistic License

Copyright 2013 Linode, LLC.  Longview is made available under the terms
of the Perl Artistic License, or GPLv2 at the recipients discretion.

=head2 Perl Artistic License

Read it at L<http://dev.perl.org/licenses/artistic.html>.

=head2 GNU General Public License (GPL) Version 2

  This program is free software; you can redistribute it and/or
  modify it under the terms of the GNU General Public License
  as published by the Free Software Foundation; either version 2
  of the License, or (at your option) any later version.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.

  You should have received a copy of the GNU General Public License
  along with this program.  If not, see http://www.gnu.org/licenses/

See the full license at L<http://www.gnu.org/licenses/>.

=cut

BEGIN {
	use Config;
	use FindBin;
	push @INC, "$FindBin::RealBin/../";
	push @INC, "$FindBin::RealBin/../lib/perl5";
	push @INC, "$FindBin::RealBin/../lib/perl5/${Config{archname}}/";
	push @INC, "$FindBin::RealBin/../usr/include";
	{
		no warnings 'once';
		$Net::HTTP::SOCKET_CLASS = 'IO::Socket::INET6';
	}
	require Net::HTTP;
}

use JSON;
use Try::Tiny;
use Sys::Hostname;
use LWP::UserAgent;
use Compress::Zlib;
use IO::Socket::INET6;
use Fastcomet::Nightwatch::DataGetter;
use Fastcomet::Nightwatch::Util ':DRIVER';

$logger->info("Starting Nightwatch Agent version $VERSION");

$logger->logdie('Nightwatch must be run as root in order to collect data') unless ($< == 0);
my $pid = check_already_running();
$logger->logdie("The Nightwatch agent is already running as PID: $pid") if $pid;

my $confdir    = '/etc/fastcomet/nightwatch.d';
my $api_key_file = "$confdir/nightwatch.key";

$apikey = scalar(slurp_file($api_key_file));
unless ($apikey){
	print "\nNo api key found. Please enter your API Key: " if -t;
	$apikey = <>;
	unless(defined $apikey){
		print "No api key found. Please add your API key to /etc/fastcomet/nightwatch.key before starting nightwatch.\n";
		exit 1;
	}
	chomp($apikey);
	umask 066;
	mkdir $confdir;
	open my $fh, '>', $api_key_file or $logger->logdie("Couldn't open $api_key_file for writing: $!");
	print $fh $apikey;
	close $fh or $logger->logdie("Couldn't close $api_key_file: $!");
}

my $stats = {
	apikey  => $apikey,
	version => '1.0',
	payload => [],
};

_prep_for_main();

my ($quit, $data, $reload) = (0, {}, 0);
while (!$quit) {
	if ($reload){
		reload_modules();
		$reload = 0;
	}
	my $sleep = $SLEEP_TIME;
	$data->{time} = time;
	get($_,$data,) for @{run_order()};

	constant_push($stats->{payload},$data);
	$data = {};

	$stats->{time} = time;
	my $req = post($stats);

	if ($req->is_success){
		$logger->debug($req->status_line);
		$logger->debug($req->decoded_content);
		my $rep;
		try {
			$rep = decode_json($req->decoded_content);
		} catch {
			$logger->debug("Couldn't decode JSON response: $_");
		};
		$sleep = $rep->{sleep} if defined $rep->{sleep};
		if (defined($rep->{die}) && $rep->{die} eq 'please') {
			$logger->logdie('Server has requested this API Key stop sending data');
		}
		if (defined($rep->{result}->{update}) && $rep->{result}->{update}) {
      sleep $sleep;
      $logger->info("Server has requested app update to version \"$rep->{result}->{version}\".");
      system('/etc/init.d/nightwatch update &');
		}
		@{$stats->{payload}} = ();
	}
	else{
		$logger->info($req->status_line);
		$logger->info($req->decoded_content);
	}

	sleep $sleep;
}

sub _prep_for_main {
	chown 0, 0, $api_key_file;
	chmod 0600, $api_key_file;

	daemonize_self();
	enable_debug_logging() if(defined $ARGV[0] && $ARGV[0] =~ /Debug/i);
	load_modules();

	$0 = 'fastcomet-nightwatch';
	$SIG{TERM} = $SIG{INT} = $SIG{QUIT} = sub { $quit = 1 };
	$SIG{HUP} = sub { $reload = 1};
	$logger->info('Start up complete');
}