/[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 185 by dpavlin, Sun Aug 9 21:13:36 2009 UTC revision 225 by dpavlin, Sun Aug 16 00:03:30 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 => $$ } unless defined $pids; # keep pids on refresh  $pids = {
14            httpd => $$,
15            kvm => 'not started',
16            wireshark => 'not started',
17    } unless defined $pids; # keep pids on refresh
18    
19  sub DESTROY {  sub DESTROY {
20          warn "pids ",dump( $pids );          warn "pids ",dump( $pids );
# Line 21  sub DESTROY { Line 26  sub DESTROY {
26    
27  $SIG{CHLD} = 'IGNORE';  $SIG{CHLD} = 'IGNORE';
28    
29    sub audit {
30            my $msg = shift;
31            my $daemon = shift;
32            CouchDB::audit( $msg, $daemon, { daemon => $daemon, message => $msg, @_ } );
33    }
34    
35  sub start_stop {  sub start_stop {
36          my $daemon = shift;          my $daemon = shift;
37    
38          my $pid = $pids->{$daemon};          my $pid = $pids->{$daemon};
39          my $pid_path = "$server::conf/$daemon.pid";          my $pid_path = "$daemon.pid";
40            $pid_path =~ s{/}{-}g;
41            $pid_path = "$server::conf/$pid_path";
42    
43          if ( ! $pid && -e $pid_path ) {          if ( ! $pid && -e $pid_path ) {
44                  my $p = read_file $pid_path;                  my $p = read_file $pid_path;
45                  if ( kill 0, $p ) {                  if ( kill 0, $p ) {
46                          warn "adopted $daemon $p\n";                          audit 'adopted', $daemon, pid => $p;
47                          return $pids->{$daemon} = $p;                          return $pids->{$daemon} = $p;
48                  } else {                  } else {
49                          warn "old $daemon $p not running";                          audit 'not running', $daemon, pid => $p;
50                          unlink $pid_path;                          unlink $pid_path;
51                  }                  }
52          }          }
# Line 47  sub start_stop { Line 60  sub start_stop {
60                  warn "pstree $pstree pids ",dump( @pids );                  warn "pstree $pstree pids ",dump( @pids );
61                  kill 1, $_ foreach reverse @pids;                  kill 1, $_ foreach reverse @pids;
62                  $pids->{$daemon} = 'stopped';                  $pids->{$daemon} = 'stopped';
63                    audit 'stopped', $daemon, pid => $pid;
64                  return qq|$daemon pid $pid stopped|;                  return qq|$daemon pid $pid stopped|;
65          } else {          } else {
66                  if ( $pid = fork ) {                  if ( $pid = fork ) {
67                          # parent                          # parent
68                          $pids->{$daemon} = $pid;                          $pids->{$daemon} = $pid;
69                          write_file $pid_path, $pid;                          write_file $pid_path, $pid;
70                          warn "forked $daemon $pid\n";                          audit 'forked', $daemon, pid => $pid;
71                          return qq|$daemon pid $pid started|;                          return qq|$daemon pid $pid started|;
72                  } elsif ( defined $pid ) {                  } elsif ( defined $pid ) {
73                          # child                          # child
# Line 61  sub start_stop { Line 75  sub start_stop {
75                          $invoke = $1 if $daemon =~ s{/(.+)}{};                          $invoke = $1 if $daemon =~ s{/(.+)}{};
76                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {                          if ( $daemon =~ m{dhcpd|tftpd|dnsd} ) {
77                                  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}";
78                                  warn "exec $exec";                                  audit 'exec', $daemon, 'exec' => $exec;
79                                  x11::xterm( $daemon => $exec );                                  x11::xterm( $daemon => $exec );
80                          } else {                          } else {
81                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';                                  my $eval = $daemon . '::' . $invoke . '(' . ( @_ ? dump(@_) : '' ) . ')';
82                                  warn "eval $eval";                                  audit 'eval', $daemon, 'eval' => $eval;
83                                  eval $eval;                                  eval $eval;
84                                  warn "can't start $daemon: $@" if $@;                                  audit 'error', $daemon, error => $@  if $@;
85                          }                          }
86                          exit;                          exit;
87                  } else {                  } else {
88                            audit 'error', $daemon, error => $!;
89                          die "fork error $!";                          die "fork error $!";
90                  }                  }
91          }          }

Legend:
Removed from v.185  
changed lines
  Added in v.225

  ViewVC Help
Powered by ViewVC 1.1.26