#! /bin/sh -e

# $Id: lr_run.in,v 1.14 2002/04/13 22:55:16 vanbaal Exp $

#
# Copyright (C) 2000-2002 Stichting LogReport Foundation LogReport@LogReport.org
# 
#     This program is free software; you can redistribute it and/or modify
#     it under the terms of the GNU General Public License as published by
#     the Free Software Foundation; either version 2 of the License, or
#     (at your option) any later version.
# 
#     This program is distributed in the hope that it will be useful,
#     but WITHOUT ANY WARRANTY; without even the implied warranty of
#     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#     GNU General Public License for more details.
# 
#     You should have received a copy of the GNU General Public License
#     along with this program (see COPYING); if not, check with
#     http://www.gnu.org/copyleft/gpl.html or write to the Free Software 
#     Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
#

PROGRAM=lr_run
tag="all all none $PROGRAM"

if test $# -eq 0
then
    echo >&2 "$tag err give at least one arg, indicating program to run"
    exit 1
fi

# dereference sysconfdir's prefix dependency
prefix="/usr/local"
etcdir="${prefix}/etc/lire"
. $etcdir/defaults
. $etcdir/profile_lean
# defines LR_DEBUG, LR_LOGGING, LR_FACILITY and LR_LOGGERTAG

#
# Tom Christiansen   in   Csh Programming Considered Harmful
#
# exec 3>&1; grep yyy xxx 2>&1 1>&3 3>&- | sed s/file/foobar/ 1>&2 3>&-
#

exec 3>&1

"$@" 2>&1 1>&3 3>&- | {
    while read superservice service id program level rest
    do
        message="$superservice $service $id $program $level $rest"
        case $level in
        emerg|alert|crit|err|warning|notice)
            if test stderr = $LR_LOGGING
            then
                echo >&2 "$message"
            else
                /usr/bin/logger -p $LR_FACILITY.$level -t $LR_LOGGERTAG "$message"
            fi
            ;;
        info|debug)
            if test -n "$LR_DEBUG"
            then
                if test stderr = $LR_LOGGING
                then
                    echo >&2 "$message"
                else
                    /usr/bin/logger -p $LR_FACILITY.$level -t $LR_LOGGERTAG "$message"
                fi
            fi
            ;;
        *)
            message="bogus message: $message"
            if test stderr = $LR_LOGGING
            then
                echo >&2 "$message"
            else
                /usr/bin/logger -p $LR_FACILITY.alert -t $LR_LOGGERTAG "$message"
            fi
            ;;
        esac
    done
} 1>&2 3>&-

