/[pxelator]/lib/PXElator/daemons.pm
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /lib/PXElator/daemons.pm

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 207 by dpavlin, Wed Aug 12 22:56:45 2009 UTC revision 208 by dpavlin, Wed Aug 12 23:59:01 2009 UTC
# Line 7  use File::Slurp; Line 7  use File::Slurp;
7  use Data::Dump qw/dump/;  use Data::Dump qw/dump/;
8    
9  use x11;  use x11;
10    use CouchDB;
11    
12  our $pids;  our $pids;
13  $pids = { httpd => $$, kvm => 'not started' } unless defined $pids; # keep pids on refresh  $pids = { httpd => $$, kvm => 'not started' } unless defined $pids; # keep pids on refresh
# Line 21  sub DESTROY { Line 22  sub DESTROY {
22    
23  $SIG{CHLD} = 'IGNORE';  $SIG{CHLD} = 'IGNORE';
24    
25    sub audit {
26            my $msg = shift;
27            my $daemon = shift;
28            CouchDB::audit( $msg, $daemon, { daemon => $daemon, message => $msg, @_ } );
29    }
30    
31  sub start_stop {  sub start_stop {
32          my $daemon = shift;          my $daemon = shift;
33    
# Line 30  sub start_stop { Line 37  sub start_stop {
37          if ( ! $pid && -e $pid_path ) {          if ( ! $pid && -e $pid_path ) {
38                  my $p = read_file $pid_path;                  my $p = read_file $pid_path;
39                  if ( kill 0, $p ) {                  if ( kill 0, $p ) {
40                          warn "adopted $daemon $p\n";                          audit 'adopted', $daemon, pid => $p;
41                          return $pids->{$daemon} = $p;                          return $pids->{$daemon} = $p;
42                  } else {                  } else {
43                          warn "old $daemon $p not running";                          audit 'not running', $daemon, pid => $p;
44                          unlink $pid_path;                          unlink $pid_path;
45                  }                  }
46          }          }
# Line 47  sub start_stop { Line 54  sub start_stop {
54                  warn "pstree $pstree pids ",dump( @pids );                  warn "pstree $pstree pids ",dump( @pids );
55                  kill 1, $_ foreach reverse @pids;                  kill 1, $_ foreach reverse @pids;
56                  $pids->{$daemon} = 'stopped';                  $pids->{$daemon} = 'stopped';
57                    audit 'stopped', $daemon, pid => $pid;
58                  return qq|$daemon pid $pid stopped|;                  return qq|$daemon pid $pid stopped|;
59          } else {          } else {
60                  if ( $pid = fork ) {                  if ( $pid = fork ) {
61                          # parent                          # parent
62                          $pids->{$daemon} = $pid;                          $pids->{$daemon} = $pid;
63                          write_file $pid_path, $pid;                          write_file $pid_path, $pid;
64                          warn "forked $daemon $pid\n";                          audit 'forked', $daemon, pid => $pid;
65                          return qq|$daemon pid $pid started|;                          return qq|$daemon pid $pid started|;
66                  } elsif ( defined $pid ) {                  } elsif ( defined $pid ) {
67                          # child                          # child
# Line 61  sub start_stop { Line 69  sub start_stop {
69                          $invoke = $1 if $daemon =~ s{/(.+)}{};                          $invoke = $1 if $daemon =~ s{/(.+)}{};
70                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {
71                                  my $exec = "perl -I$server::base_dir/lib -I$server::base_dir/lib/PXElator -M$daemon -e ${daemon}::${invoke}";                                  my $exec = "perl -I$server::base_dir/lib -I$server::base_dir/lib/PXElator -M$daemon -e ${daemon}::${invoke}";
72                                  warn "exec $exec";                                  audit 'exec', $daemon, 'exec' => $exec;
73                                  x11::xterm( $daemon => $exec );                                  x11::xterm( $daemon => $exec );
74                          } else {                          } else {
75                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';
76                                  warn "eval $eval";                                  audit 'eval', $daemon, 'eval' => $eval;
77                                  eval $eval;                                  eval $eval;
78                                  warn "can't start $daemon: $@" if $@;                                  audit 'error', $daemon, error => $@  if $@;
79                          }                          }
80                          exit;                          exit;
81                  } else {                  } else {
82                            audit 'error', $daemon, error => $!;
83                          die "fork error $!";                          die "fork error $!";
84                  }                  }
85          }          }

Legend:
Removed from v.207  
changed lines
  Added in v.208

  ViewVC Help
Powered by ViewVC 1.1.26