# (2) Added rules based paging (Stephen Johnson Nov 14, 1998)
# (3) Added checks against Acks and downtime (Stephen Johnson Mar 17, 1999)
#
-# $Id: spong-message.pl,v 1.40 2003/07/26 20:36:46 sljohnson Exp $
+# $Id: spong-message.pl,v 1.41 2005/12/04 19:37:24 sljohnson Exp $
use lib "@@LIBDIR@@";
my %opt;
@options = ( "help", "host=s", "service=s", "time=i", "color|status=s",
"summary=s", "duration=i", "message=s", "file=s", "debug",
- "test" );
+ "test", "page" );
Getopt::Long::Configure("pass_through");
if( ! GetOptions( \%opt, @options ) ) { &error("Incorrect usage"); exit 1; }
&error("Only one of --message or --file can be specified"); exit 1; }
if ( ! defined $duration ) {
if ( defined $opt{'duration'} ) { $duration = $opt{'duration'}; } else { $duration = 0; } }
-$debug = $opt{'debug'};
+$debug = $opt{'debug'};
$test = $opt{'test'};
-
+$page = $opt{'page'}; # This message is a type 'page' message
# Handle message file processing if necessary
my ( $message ) = "";
$acks = new Spong::AckList($host);
-if (defined $acks) {
+if (defined $acks && ! $page) { # If this is a 'page' message, ignore acknowlegements
foreach ( $acks->acks() ) {
if ( ( $_->services() =~ m/$service/ or $_->services() eq "all" ) and
( $time >= $_->start() and $time <= $_->end() ) ) {
my $stotal = $shour * 60 + $smin;
my $etotal = $ehour * 60 + $emin;
- if( $ntotal >= $stotal && $ntotal <= $etotal ) {
+ if( $ntotal >= $stotal && $ntotal <= $etotal && ! $page ) { # Ignore downtime for 'page' messages
&debug( "problem during downtime, no message will be sent." );
exit(0);
}
#
# Logic to decide whether to notifiy this contact or not
+ # If sending a page, do no delay processing
+ if ( $page ) {
+ debug("--page flag setup bypassing delay processing");
+ }
# If there is special delay processing to be done...
- if ( $delay != 0 || $escalate != 0 || $repeat != 0) {
+ elsif ( $delay != 0 || $escalate != 0 || $repeat != 0) {
# If there is no np-file
if ( $pagetime eq "") {
debug("First attempt notification for $person:$func");