summaryrefslogtreecommitdiffstats
path: root/mdvonline_agent.pl
diff options
context:
space:
mode:
authorRomain d'Alverny <rdalverny@mandriva.org>2005-12-08 15:43:47 +0000
committerRomain d'Alverny <rdalverny@mandriva.org>2005-12-08 15:43:47 +0000
commit17d77692201376797d2f959ca2ecaa5169ca3045 (patch)
tree237a9e6033ee63ab614c6fcc93d4138ee6f36ce6 /mdvonline_agent.pl
parent215f2ea989ba6f8655cde40255da0074ed3a31f7 (diff)
downloadmgaonline-17d77692201376797d2f959ca2ecaa5169ca3045.tar
mgaonline-17d77692201376797d2f959ca2ecaa5169ca3045.tar.gz
mgaonline-17d77692201376797d2f959ca2ecaa5169ca3045.tar.bz2
mgaonline-17d77692201376797d2f959ca2ecaa5169ca3045.tar.xz
mgaonline-17d77692201376797d2f959ca2ecaa5169ca3045.zip
*** empty log message ***
Diffstat (limited to 'mdvonline_agent.pl')
-rw-r--r--mdvonline_agent.pl73
1 files changed, 21 insertions, 52 deletions
diff --git a/mdvonline_agent.pl b/mdvonline_agent.pl
index 04709444..3b8ebfb2 100644
--- a/mdvonline_agent.pl
+++ b/mdvonline_agent.pl
@@ -27,7 +27,9 @@ use POSIX;
use lib qw(/usr/lib/libDrakX /usr/lib/libDrakX/drakfirsttime);
use common;
use mdkonline;
+use Switch;
use Data::Dumper;
+use Error qw(:try);
# DNS service discovery
use Discover;
@@ -45,65 +47,32 @@ logconfig(
-priority => [ -display => '[$priority]' ],
);
-# TODO set this in mdkonline.pm ?
-my $conffile = '/etc/sysconfig/mdkonline';
-my $service = 'https://localhost/~romain/online3/htdocs/service';
+logsay "==================";
+mdkonline::is_running('mdvonline_agent') and die "mdvonline_agent already running\n";
+require_root_capability();
-# script starts here
-mdkonline::is_running('mdvonline_agent')
- and die "mdvonline_agent already running\n";
+my %conf = mdkonline::get_configuration();
+print Dumper(%conf);
-#require_root_capability();
+! defined %conf and logwarn "no configuration set", exit 0;
-my %conf;
-my $ret = 0;
+logsay "checking for tasks";
+print Dumper(%conf);
+my $answer = mdkonline::soap_get_task( $conf{HOST_ID}, $conf{HOST_KEY} );
-# 1. check configuration (local) or set from dns if any
-if( ( -e $conffile ) && ( -s $conffile ) ) {
- %conf = getVarsFromSh($conffile);
+print Dumper($answer);
- if( defined $conf{MACHINE} && ! defined $conf{VERSION} ) { #|| $conf{VERSION} lt 3 ) {
- logsay "old configuration detected: trying to migrate to new scheme";
- $ret = mdkonline::upgrade_to_v3();
- if( $ret eq 1 ) { logsay "succeeded"; }
- else { logsay "failed"; }
+if( $answer->{code} eq 0 ) {
+ if( $answer->{data}->{command} eq 'none' ) {
+ logsay "nothing to do";
}
else {
- if( defined $conf{MOBILE} && $conf{MOBILE} eq 'TRUE' ) {
- # TODO check dns service for a specific update server
- # if there is one, it may supersedes default conf update server
- # or the one provided by the Online server?
- }
- $ret = 1;
+ logsay "got something";
+ my $res = mdkonline::run_and_return_task( $answer->{data} );
}
+ exit 1;
}
else {
- logsay "no configuration file found";
- logsay "starting dns service discovery";
- my $sd = new Discover;
- my $serviceinfo = $sd->search();
- if ( $serviceinfo ) {
- logsay "found service with info";
- print Dumper($serviceinfo);
- # TODO check service certificate
- # TODO register to service
- # TODO set config file
- $ret = 0;
- }
- else {
- #print Dumper($sd);
- logsay "no service found";
- $ret = 0;
- }
- $ret = 0;
-}
-
-if( $ret eq 1 ) {
- # 2. now check and run task
- print "checking for somethign to do.\n";
- my $task = mdkonline::soap_get_task( $conf{HOST_ID}, $conf{HOST_KEY} );
- print Dumper($task);
-}
-
-logsay "done";
-$ret; \ No newline at end of file
+ logwarn "something went wrong " . $answer->{message} . " (".$answer->{code}.")";
+ exit 0;
+} \ No newline at end of file