# (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");