From owner-freebsd-ports-bugs@FreeBSD.ORG Thu Apr 20 05:10:18 2006 Return-Path: X-Original-To: freebsd-ports-bugs@hub.freebsd.org Delivered-To: freebsd-ports-bugs@hub.freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id AD84116A402 for ; Thu, 20 Apr 2006 05:10:18 +0000 (UTC) (envelope-from gnats@FreeBSD.org) Received: from freefall.freebsd.org (freefall.freebsd.org [216.136.204.21]) by mx1.FreeBSD.org (Postfix) with ESMTP id 2468243D49 for ; Thu, 20 Apr 2006 05:10:18 +0000 (GMT) (envelope-from gnats@FreeBSD.org) Received: from freefall.freebsd.org (gnats@localhost [127.0.0.1]) by freefall.freebsd.org (8.13.4/8.13.4) with ESMTP id k3K5AHEC022295 for ; Thu, 20 Apr 2006 05:10:17 GMT (envelope-from gnats@freefall.freebsd.org) Received: (from gnats@localhost) by freefall.freebsd.org (8.13.4/8.13.4/Submit) id k3K5AHV7022294; Thu, 20 Apr 2006 05:10:17 GMT (envelope-from gnats) Resent-Date: Thu, 20 Apr 2006 05:10:17 GMT Resent-Message-Id: <200604200510.k3K5AHV7022294@freefall.freebsd.org> Resent-From: FreeBSD-gnats-submit@FreeBSD.org (GNATS Filer) Resent-To: freebsd-ports-bugs@FreeBSD.org Resent-Reply-To: FreeBSD-gnats-submit@FreeBSD.org, Dmitry Frolov Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 8863116A400 for ; Thu, 20 Apr 2006 05:08:06 +0000 (UTC) (envelope-from frol@nerve.riss-telecom.ru) Received: from nerve.riss-telecom.ru (nerve.riss-telecom.ru [80.66.65.3]) by mx1.FreeBSD.org (Postfix) with ESMTP id B834643D4C for ; Thu, 20 Apr 2006 05:08:05 +0000 (GMT) (envelope-from frol@nerve.riss-telecom.ru) Received: from nerve.riss-telecom.ru (1gwenfr1b6n891lo@localhost [127.0.0.1]) by nerve.riss-telecom.ru (8.13.1/8.13.1) with ESMTP id k3K57fII001547; Thu, 20 Apr 2006 12:07:41 +0700 (NOVST) (envelope-from frol@nerve.riss-telecom.ru) Received: (from frol@localhost) by nerve.riss-telecom.ru (8.13.1/8.13.1/Submit) id k3K57f54001546; Thu, 20 Apr 2006 12:07:41 +0700 (NOVST) (envelope-from frol) Message-Id: <200604200507.k3K57f54001546@nerve.riss-telecom.ru> Date: Thu, 20 Apr 2006 12:07:41 +0700 (NOVST) From: Dmitry Frolov To: FreeBSD-gnats-submit@FreeBSD.org X-Send-Pr-Version: 3.113 Cc: Subject: ports/96085: Update port: sysutils/tw_cli X-BeenThere: freebsd-ports-bugs@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list Reply-To: Dmitry Frolov List-Id: Ports bug reports List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 20 Apr 2006 05:10:18 -0000 >Number: 96085 >Category: ports >Synopsis: Update port: sysutils/tw_cli >Confidential: no >Severity: non-critical >Priority: medium >Responsible: freebsd-ports-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: maintainer-update >Submitter-Id: current-users >Arrival-Date: Thu Apr 20 05:10:17 GMT 2006 >Closed-Date: >Last-Modified: >Originator: Dmitry Frolov >Release: FreeBSD 5.3-BETA7 i386 >Organization: RISS-Telecom >Environment: System: FreeBSD *****.riss-telecom.ru 5.3-BETA7 FreeBSD 5.3-BETA7 #18: Wed Jun 8 15:55:56 NOVST 2005 root@*****.riss-telecom.ru:/var/obj/usr/src/sys/NERVE i386 >Description: - Add daily periodic script to report RAID status and alarms >How-To-Repeat: >Fix: Patch is relative to ports/sysutils/tw_cli directory: diff -ruN /usr/ports/sysutils/tw_cli/Makefile ./Makefile --- /usr/ports/sysutils/tw_cli/Makefile Wed Feb 22 23:47:57 2006 +++ ./Makefile Thu Apr 20 10:59:47 2006 @@ -22,7 +22,10 @@ WRKSRC= ${WRKDIR} NO_BUILD= yes STRIP= # empty -PLIST_FILES= sbin/tw_cli sbin/tw_sched +SUB_FILES+= 407.status-3ware-raid +PLIST_FILES= sbin/tw_cli sbin/tw_sched \ + etc/periodic/daily/407.status-3ware-raid +PLIST_DIRS= etc/periodic/daily etc/periodic PORTDOCS= tw_cli.8.html tw_sched.8.html MAN8+= tw_cli.8 tw_sched.8 @@ -38,6 +41,9 @@ ${INSTALL_PROGRAM} ${WRKSRC}/tw_cli ${WRKSRC}/tw_sched ${PREFIX}/sbin/ ${INSTALL_MAN} ${WRKSRC}/tw_cli.8.nroff ${MANPREFIX}/man/man8/tw_cli.8 ${INSTALL_MAN} ${WRKSRC}/tw_sched.8.nroff ${MANPREFIX}/man/man8/tw_sched.8 + @${MKDIR} ${PREFIX}/etc/periodic/daily + ${INSTALL_SCRIPT} ${WRKDIR}/407.status-3ware-raid \ + ${PREFIX}/etc/periodic/daily/ post-install: .if !defined(NOPORTDOCS) diff -ruN /usr/ports/sysutils/tw_cli/files/407.status-3ware-raid.in ./files/407.status-3ware-raid.in --- /usr/ports/sysutils/tw_cli/files/407.status-3ware-raid.in Thu Jan 1 07:00:00 1970 +++ ./files/407.status-3ware-raid.in Wed Apr 19 18:07:57 2006 @@ -0,0 +1,92 @@ +#!/bin/sh +# +# Shows status of 3ware RAID controllers: twa(4), twe(4) +# +# Authors: Bjoern A. Zeeb, Dmitry Frolov +# +# $FreeBSD$ +# + +# If there is a global system configuration file, suck it in. +# +if [ -r /etc/defaults/periodic.conf ] +then + . /etc/defaults/periodic.conf + source_periodic_confs +fi + +# Defaults. +: ${daily_status_3ware_raid_enable:=NO} +# Alarms persist between "tw_cli alarms" invocation? +# Set to YES for twa(4) and to NO for twe(4). +: ${daily_status_3ware_raid_persist_alarms:=YES} + +tw_cli=${tw_cli:-%%PREFIX%%/sbin/tw_cli} +logdir=${logdir:-/var/log} + +case "$daily_status_3ware_raid_enable" in + [Yy][Ee][Ss]) + echo + echo 'Checking status of 3ware RAID controllers:' + + rc=0 + + # Checking each controller. + for ctrl in `${tw_cli} info | awk '/^c/ { print $1 }'` + do + echo "" + echo "Controller ${ctrl}:" + ctrl_log=${logdir}/3ware_raid_${ctrl} + if test ! -f ${ctrl_log}.today; then + touch ${ctrl_log}.today + fi + mv -f ${ctrl_log}.today ${ctrl_log}.yesterday + ${tw_cli} info ${ctrl} > ${ctrl_log}.today + lines=`wc -l ${ctrl_log}.today | awk '{ print $1 }'` + diff -u -$lines ${ctrl_log}.yesterday ${ctrl_log}.today + raid_rc=$? + if test $raid_rc -eq 0; then + cat ${ctrl_log}.today + fi + [ $rc -eq 0 ] && [ $raid_rc -ne 0 ] && rc=3 + done + + # Checking alarms. + echo "Alarms (most recent first):" + alarms_log=${logdir}/3ware_raid_alarms + case "$daily_status_3ware_raid_persist_alarms" in + [Yy][Ee][Ss]) + if test ! -f ${alarms_log}.today; then + touch ${alarms_log}.today + fi + mv -f ${alarms_log}.today ${alarms_log}.yesterday + ${tw_cli} alarms > ${alarms_log}.today + cmp -zs ${alarms_log}.yesterday ${alarms_log}.today + raid_rc=$? + if test $raid_rc -ne 0; then + diff -u ${alarms_log}.yesterday ${alarms_log}.today | \ + grep -v '^-\|^$' + fi + ;; + *) + raid_rc=0 + ${tw_cli} alarms > ${alarms_log}.today + lines=`wc -l ${alarms_log}.today | awk '{ print $1 }'` + if test $lines -gt 4; then + cat ${alarms_log}.today + raid_rc=1 + fi + ;; + esac + if test $raid_rc -eq 0; then + echo " No new alarms." + fi + [ $rc -eq 0 ] && [ $raid_rc -ne 0 ] && rc=3 + ;; + + *) rc=0;; +esac + +exit $rc + +# end >Release-Note: >Audit-Trail: >Unformatted: