blob: ba1030ad6efe81c7f601109f4656019b47d692c0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
package PerlDaemon::RunModules;
use Time::HiRes qw(gettimeofday tv_interval);
sub new ($$) {
my ($class, $conf) = @_;
my $self = bless { conf => $conf }, $class;
my $modulesdir = $conf->{'daemon.modules.dir'};
my $logger = $conf->{logger};
my %loadedmodules;
my %scheduler;
if (-d $modulesdir) {
$logger->logmsg("Loading modules from $modulesdir");
for my $module (<$modulesdir/*.pm>) {
$logger->logmsg("Loading $module");
require $module;
}
for my $name (grep /PerlDaemonModules/, keys %INC) {
$name =~ s#.*(PerlDaemonModules)/(.*)\.pm$#$1::$2#;
$logger->logmsg("Creating module instance of $name");
# TODO: Add eval catching jost un case for errors
$loadedmodules{$name} = eval "${name}->new(\$conf)";
$scheduler{$name}{lastrun} = 0.0;
$scheduler{$name}{interval} = $conf->{'modules.runinterval'};
}
} else {
$logger->warn("Modules dir $modulesdir does not exist!");
}
$conf->{modules} = \%loadedmodules;
$conf->{scheduler} = \%scheduler;
return $self;
}
sub do ($) {
my $self = shift;
my $conf = $self->{conf};
my $logger = $conf->{logger};
my $modules = $conf->{modules};
my $scheduler = $conf->{scheduler};
unless (%$modules) {
$logger->warn("No modules are loaded!");
} else {
while (my ($k, $v) = each %$modules) {
$logger->logmsg("Triggering $k");
$scheduler->{$k}{lastrun} = gettimeofday;
$v->do();
}
}
}
1;
|