App-Standby
view release on metacpan or search on metacpan
lib/App/Standby/Group.pm view on Meta::CPAN
'required' => 1,
);
has 'name' => (
'is' => 'ro',
'isa' => 'Str',
'required' => 1,
);
# with ...
# initializers ...
sub _init_services {
my $self = shift;
my %want_sv;
my %has_sv;
my $sql = 'SELECT id,name,class,desc FROM group_services WHERE group_id = ?';
my $sth = $self->dbh()->prepexec($sql,$self->group_id());
if(!$sth) {
$self->logger()->log( message => 'Failed to get required services from DB due to SQL error: '.$self->dbh()->errstr, level => 'error', );
return \%has_sv;
}
while( my ($sv_id, $sv_name, $sv_class, $sv_desc) = $sth->fetchrow_array()) {
$want_sv{$sv_name}->{'id'} = $sv_id;
$want_sv{$sv_name}->{'class'} = 'App::Standby::Service::'.$sv_class;
$want_sv{$sv_name}->{'desc'} = $sv_desc;
}
$sth->finish();
# try to load each requested service
foreach my $sv_name ( sort keys %want_sv) {
my $sv_class = $want_sv{$sv_name}->{'class'};
my $sv_desc = $want_sv{$sv_name}->{'desc'};
my $load_result = $self->_load_class($sv_class);
if($load_result ne $sv_class) {
$self->logger()->log( message => 'Failed to load required class: '.$sv_class.' w/ error: '.$load_result, level => 'error', );
next;
}
try {
my $Service = $sv_class->new({
'name' => $sv_name,
'description' => $sv_desc,
'group_id' => $self->group_id(),
'dbh' => $self->dbh(),
'logger' => $self->logger(),
});
$has_sv{$sv_name} = $Service;
$self->logger()->log( message => "Initialized $sv_name service for ".$self->name().' ('.$self->group_id().')', level => 'debug', );
} catch {
$self->logger()->log( message => "Failed to init $sv_name service for ".$self->name().' ('.$self->group_id().'):'.$_, level => 'warning', );
};
}
return \%has_sv;;
}
# your code here ...
sub _config_values {
my $self = shift;
my $key = shift;
return $self->SUPER::_config_values($key, $self->group_id());
}
sub _update_services {
my $self = shift;
my $contact_ref = shift;
my $count = 0;
foreach my $name (sort keys %{$self->services()}) {
my $service = $self->services()->{$name};
$self->logger()->log( message => "Service: ".$name.' starting ...', level => 'debug', );
try {
if($service->update($contact_ref)) {
$self->logger()->log( message => "Updated service ".$name, level => 'debug', );
$count++;
} else {
$self->logger()->log( message => "Failed to update service ".$name, level => 'warning', );
}
} catch {
$self->logger()->log( message => "Failed to update service ".$name.'. Error: '.$_, level => 'warning', );
};
$self->logger()->log( message => "Service: ".$name.' done.', level => 'debug', );
}
return $count;
}
sub set_janitor {
my $self = shift;
my $contact_id = shift;
my $contact_ref = $self->get_contacts();
# set the last janitor as the last person in the list, so the chances of being notified
# are the least for the last janitor
push @$contact_ref, shift @$contact_ref;
# put the new janitor on the first place, leave everything else as it was before
# This didn't work: my @new_users = (grep { $_->{'id'} == $contact_id } @$contact_ref, grep { $_->{'id'} != $contact_id } @$contact_ref);
my @l1 = grep { $_->{'id'} == $contact_id } @$contact_ref;
my @l2 = grep { $_->{'id'} != $contact_id } @$contact_ref;
my @new_contacts = (@l1, @l2);
#$self->logger()->log( message => "New Ordering: ".Dumper(\@new_users), level => 'debug', );
# Example:
# Current queue: Jim (on duty), Jon, Paul, Dave
# Paul wants to be the new janitor
# Push Jim to the last position:
# Jon, Paul, Dave, Jim
# Push Paul to the first position:
# Paul, Jon, Dave, Jim
if($self->_update_services($self->_set_ordering(\@new_contacts))) {
$self->logger()->log( message => "Updated all services", level => 'debug', );
} else {
$self->logger()->log( message => "Failed to update all services", level => 'debug', );
}
return \@new_contacts;
}
sub _set_ordering {
my $self = shift;
( run in 1.262 second using v1.01-cache-2.11-cpan-5a3173703d6 )