OSSP CVS Repository

ossp - Check-in [4629]
Not logged in
[Honeypot]  [Browse]  [Home]  [Login]  [Reports
[Search]  [Ticket]  [Timeline
  [Patchset]  [Tagging/Branching

Check-in Number: 4629
Date: 2004-Jul-02 21:19:33 (local)
2004-Jul-02 19:19:33 (UTC)
User:rse
Branch:
Comment: Document in install-shiela.pod and install-shiela.sh that CVS version 1.12.6 or higher is required.
Tickets:
Inspections:
Files:
ossp-pkg/shiela/ChangeLog      added-> 1.51
ossp-pkg/shiela/shiela-install.pod      1.23 -> 1.24     22 inserted, 10 deleted
ossp-pkg/shiela/shiela-install.sh      added-> 1.31

ossp-pkg/shiela/ChangeLog -> 1.51

*** /dev/null    Sat Nov 23 01:45:39 2024
--- -    Sat Nov 23 01:45:57 2024
***************
*** 0 ****
--- 1,251 ----
+    _        ___  ____ ____  ____        _     _      _
+   |_|_ _   / _ \/ ___/ ___||  _ \   ___| |__ (_) ___| | __ _
+   _|_||_| | | | \___ \___ \| |_) | / __| '_ \| |/ _ \ |/ _` |
+  |_||_|_| | |_| |___) |__) |  __/  \__ \ | | | |  __/ | (_| |
+   |_|_|_|  \___/|____/____/|_|     |___/_| |_|_|\___|_|\__,_|
+ 
+   OSSP shiela - Access Control and Logging Facility for CVS
+   ____________________________________________________________________
+ 
+   ChangeLog
+ 
+   Changes between 1.1.3 and 1.1.4 (27-Jun-2004 to 02-Jul-2004):
+ 
+    *) Fix determination of the "handle" field under new CVS 1.12.x
+       where ISO format dates are used in the output of "cvs log".
+       [Ralf S. Engelschall]
+ 
+    *) Document in install-shiela.pod and install-shiela.sh that
+       CVS version 1.12.6 or higher is required.
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.1.2 and 1.1.3 (10-May-2004 to 27-Jun-2004):
+ 
+    *) Fix determination of the line counts in the "Changes" field
+       by no longer announcing to the CVS server that OSSP shiela can
+       handle "MT" (message tagged) responses. The problem is CVS 1.12.x
+       starts to send some important responses as "MT" responses now and
+       OSSP shiela only accepts "M" responses.
+       [Ralf S. Engelschall, Geoff Thorpe <geoff@geoffthorpe.net>]
+ 
+   Changes between 1.1.1 and 1.1.2 (10-May-2002 to 10-May-2004):
+ 
+    *) Optimize and bugfix the determination of the number of
+       lines in case of added files.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed two more warnings about undefined variables.
+       [Ralf S. Engelschall, Michael Schloh von Bennewitz]
+ 
+    *) Fixed typos in source comments.
+       [Michael Schloh von Bennewitz]
+ 
+   Changes between 1.1.0 and 1.1.1 (07-May-2002 to 10-May-2004):
+ 
+    *) Workaround a syntax problem under Solaris /bin/sh.
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.0.4 and 1.1.0 (23-Dec-2002 to 07-May-2004):
+ 
+    *) Add "shiela-test.sh" program and "make test" driver
+       for a minimal local test suite.
+       [Ralf S. Engelschall]
+ 
+    *) Upgraded to the new CVS 1.12.x info format strings.
+       OSSP shiela now works with CVS >= 1.12.x only.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed shiela-install: "diff:mime" -> "patch:plain".
+       [Ralf S. Engelschall]
+ 
+    *) Bump year in copyright messages for 2003 and 2004.
+       [Ralf S. Engelschall]
+ 
+    *) Upgrade build environment to GNU autoconf 2.59
+       [Ralf S. Engelschall]
+ 
+    *) Provide CVS 1.12.x "cvs rdiff" support in detail outputs.
+       [Ralf S. Engelschall]
+ 
+    *) Support CVS 1.12.x (option -l no longer existing).
+       [Ralf S. Engelschall]
+ 
+    *) Fix a nasty syntax error in shiela-install.sh occurring
+       if variables are passes as command line parameters.
+       [Ralf S. Engelschall]
+ 
+    *) Allow Shiela to accept CVS 1.12 and higher, too.
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.0.3 and 1.0.4 (23-Dec-2002 to 23-Dec-2002):
+ 
+    *) Log also the user id of the committer in the OSSP shiela logfile
+       to remove the burden on foreign applications having to merge
+       the CVSROOT/history and the shiela logfile in order to get all
+       information. Additionally the seperator character in the OSSP
+       shiela logfile was changed from a comma (",") to a bar ("|")
+       character in order to be more similar to CVSROOT/history.
+       [Ralf S. Engelschall]
+ 
+    *) Added "Setenv <variable <value>" configuration command to
+       "Environment" configuration section which allows one to set
+       environment variables like PATH, etc. This especially allows now
+       non-absolute paths on "Program" configuration commands.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed indentation on "Content files" report part.
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.0.2 and 1.0.3 (23-Dec-2002 to 23-Dec-2002):
+ 
+    *) CVS since 1.11.2 allows verifymsg-hooked scripts to actually
+       change the message and reads the contents back. So we do no longer
+       require CVS with RSE patches applied for the verifymsg hook to be
+       activated.
+       [Ralf S. Engelschall]
+ 
+    *) Added a section to the shiela-install manual page about the
+       internal processing steps performed by CVS. Additionally mention
+       the details about the CVS version with RSE patches applied.
+       [Ralf S. Engelschall]
+ 
+    *) Make sure that the header in reports is not optically destroyed by
+       too long columns (as it is the case all the time for PMOD commits
+       in the OpenPKG project).
+       [Ralf S. Engelschall]
+ 
+    *) Correctly recognize and configure RSE CVS version in
+       shiela-install program.
+       [Ralf S. Engelschall]
+ 
+    *) Be smart and allow a RSE CVS version to be driven like a stock
+       CVS version in loginfo (still using "sVv" instead of "sVvto" as
+       the flags).
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.0.1 and 1.0.2 (22-Dec-2002 to 23-Dec-2002):
+ 
+    *) Make sure that /bin:/usr/bin:/sbin:/usr/sbin is in $PATH
+       when locating tool.
+       [Ralf S. Engelschall]
+ 
+    *) Correctly use the path in "Program uuencode <path>" when
+       running uuencode.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed typos in manual pages.
+       [Ralf S. Engelschall]
+ 
+    *) Avoid over-sized lines in xdelta based patch scripts.
+       [Ralf S. Engelschall]
+ 
+   Changes between 1.0.0 and 1.0.1 (22-Dec-2002 to 22-Dec-2002):
+ 
+    *) Fixed run-time under Perl 5.8.0: import only abs_path()
+       from module Cwd to avoid conflicts with POSIX module.
+       [Ralf S. Engelschall]
+ 
+   Changes between 0.9.2 and 1.0.0 (19-Aug-2002 to 22-Dec-2002):
+ 
+    *) Add branch information to the Subject lines of generated Emails.
+       Additionally, for better readability, use a trailing slash on
+       directory names in the Subject lines of generated Emails.
+       [Ralf S. Engelschall]
+ 
+    *) Line-break single-line log messages into multi-line log messages
+       to make the usual log messages produced by "cvs commit -m '...'"
+       more readable in the report.
+       [Ralf S. Engelschall]
+ 
+    *) Fully reimplemented the "Content" "details" (the change summary in
+       reports). It now supports both textual (via diff(1)) and binary
+       (via xdelta(1)) file changes. Additionally each change report part
+       is now a small executable shell-script which can passed through
+       /bin/sh for reproducing the patch locally. This way, especially
+       binary change reports are more meaningsful and consistent with the
+       textual change reports.
+       INCOMPATIBILITY:
+       "Details diff:plain" -> "Details patch:plain"
+       "Details diff:mime" -> "Details patch:mime"
+       [Ralf S. Engelschall]
+ 
+    *) Make sure that CVS diff handles are calculated correctly
+       if files are added or deleted.
+       [Ralf S. Engelschall]
+ 
+    *) Fix incorrect use (and hence producing a warning for uninitialized
+       variable) of variables in the writing of history files.
+       [Ralf S. Engelschall]
+ 
+    *) Finally really use the "Environment" configuration section to find
+       "cvs" and "sendmail" directly and add a "Program" sub-command to it
+       for easier extension of the "Environment" section in the future.
+       INCOMPATIBILITY:
+       "CVS <path>" -> "Program cvs <path>"
+       "Sendmail <path>" -> "Program sendmail <path>"
+       [Ralf S. Engelschall]
+ 
+    *) Consistently use IO objects instead of the anchient direct
+       fiddling with Perl's filedescriptor symbol globs.
+       [Ralf S. Engelschall]
+ 
+    *) Correctly determine CVS version and optional RSE patches (from
+       OpenPKG "cvs" package).
+       [Ralf S. Engelschall]
+ 
+    *) Upgraded to GNU shtool 1.6.2 and GNU autoconf 2.57.
+       [Ralf S. Engelschall]
+ 
+    *) Fix the "invalid file specification `<absolute path>' for access
+       control" issue by using Cwd::realpath to resolve the absolute path
+       instead of calling `pwd`.
+       [Ralf S. Engelschall]
+ 
+    *) Consistently switch to the "OSSP shiela" branding.
+       [Ralf S. Engelschall]
+ 
+   Changes between 0.9.1 and 0.9.2 (10-Feb-2001 to 19-Aug-2002):
+ 
+    *) Switched to the OSSP devtool build environment
+       and upgraded to GNU shtool 1.6.1 and GNU autoconf 2.53.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed warning in dereferencing uninitialized variable.
+       [Ralf S. Engelschall, Markus Sander]
+ 
+    *) Fixed information gathering for stock CVS version.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed +d/-d output on removed files.
+       [Ralf S. Engelschall]
+ 
+    *) Fixed meta character handling in regex matchings.
+       [Ralf S. Engelschall]
+ 
+    *) Make sure shiela accepts CVS 1.11 and newer, too.
+       [Ralf S. Engelschall]
+ 
+    *) Adjusted shiela-install's Perl tool checks to use
+       the logic of GNU shtool' "path" command.
+       [Ralf S. Engelschall]
+ 
+    *) Upgraded to GNU shtool 1.5.3
+       [Ralf S. Engelschall]
+ 
+   Changes between 0.9.0 and 0.9.1 (18-Jun-2000 to 10-Feb-2001):
+ 
+    *) Upgraded to GNU shtool 1.5.2-pre.
+       [Ralf S. Engelschall]
+ 
+    *) Added --with-perl=PATH and --with-cvs=PATH Autoconf options
+       to allow one to force the use of particular programs.
+       [Ralf S. Engelschall]
+ 
+    *) Added $(DESTDIR) support for "make install".
+       [Ralf S. Engelschall]
+ 
+   Changes between *GENESIS* and 0.9.0 (Apr-2000 to 18-Jun-2000):
+ 
+    *) Created the first OSSP shiela version.
+       [Ralf S. Engelschall]
+ 


ossp-pkg/shiela/shiela-install.pod 1.23 -> 1.24

--- shiela-install.pod   2004/05/06 19:45:39     1.23
+++ shiela-install.pod   2004/07/02 19:19:33     1.24
@@ -53,27 +53,39 @@
 
 =item B<1.>
 
-checkout a working copy of the C<CVSROOT> module from your repository.
+make sure that you are using CVS version 1.12.6 or higher. Older
+versions are no longer supported due to the new I<xxxx>C<info> hooking
+(C<UseNewInfoFmtStrings=yes>) which is a mandatory configuration for
+B<OSSP shiela>.
 
 =item B<2.>
 
+checkout a working copy of the C<CVSROOT> module from your repository.
+
+=item B<3.>
+
+make sure the file C<$CVSROOT/CVSROOT/config>
+contains the directive ``C<UseNewInfoFmtStrings=yes>''.
+
+=item B<4.>
+
 create the files C<$CVSROOT/CVSROOT/shiela>,
 C<$CVSROOT/CVSROOT/shiela.cfg> and C<$CVSROOT/CVSROOT/shiela.msg>
 in this directory and list these three files in
 C<$CVSROOT/CVSROOT/checkoutlist> (so CVS automatically checks them
 out).
 
-=item B<3.>
+=item B<5.>
 
 add to C<$CVSROOT/CVSROOT/rcsinfo> (the hook for providing log
 messages): ``C<ALL $CVSROOT/CVSROOT/shiela.msg>''.
 
-=item B<4.>
+=item B<6.>
 
 add to C<$CVSROOT/CVSROOT/taginfo> (the hook for checking tag
 operations): ``C<ALL $CVSROOT/CVSROOT/shiela --hook=taginfo %t %o %p %{sv}>''.
 
-=item B<5.>
+=item B<7.>
 
 add to C<$CVSROOT/CVSROOT/importinfo> (the hook for checking import
 operations): ``C<ALL $CVSROOT/CVSROOT/shiela --hook=importinfo>''. This
@@ -83,7 +95,7 @@
 controlled by B<OSSP shiela> (because then this hook does not exists at
 all).
 
-=item B<6.>
+=item B<8.>
 
 add to C<$CVSROOT/CVSROOT/admininfo> (the hook for checking admin
 operations): ``C<ALL $CVSROOT/CVSROOT/shiela --hook=admininfo>''. This
@@ -93,17 +105,17 @@
 controlled by B<OSSP shiela> (because then this hook does not exists at
 all).
 
-=item B<7.>
+=item B<9.>
 
 add to C<$CVSROOT/CVSROOT/commitinfo> (the hook for checking commit
 operations): ``C<ALL $CVSROOT/CVSROOT/shiela --hook=commitinfo %r/%p %s>''.
 
-=item B<8.>
+=item B<10.>
 
 add to C<$CVSROOT/CVSROOT/verifymsg> (the hook for post-processing log
 messages): ``C<DEFAULT $CVSROOT/CVSROOT/shiela --hook=verifymsg %l>''.
 
-=item B<9.>
+=item B<11.>
 
 add to C<$CVSROOT/CVSROOT/loginfo> (the hook for performing logging):
 ``C<ALL $CVSROOT/CVSROOT/shiela --hook=loginfo %p %{sVvto}>''.
@@ -114,13 +126,13 @@
 and branch recognition might be less correct (because B<OSSP shiela> has
 to determine details the hard way which CVS already would know easily).
 
-=item B<10.>
+=item B<12.>
 
 edit C<$CVSROOT/CVSROOT/shiela.cfg> to fit your repository and
 project situation. For details, see the description under
 B<CONFIGURATION> in shiela(1).
 
-=item B<11.>
+=item B<13.>
 
 finally commit all modifications at once.
 


ossp-pkg/shiela/shiela-install.sh -> 1.31

*** /dev/null    Sat Nov 23 01:45:39 2024
--- -    Sat Nov 23 01:45:57 2024
***************
*** 0 ****
--- 1,677 ----
+ #!@SH@
+ ##
+ ##  OSSP shiela - CVS Access Control and Logging Facility
+ ##  Copyright (c) 2000-2004 Ralf S. Engelschall <rse@engelschall.com>
+ ##  Copyright (c) 2000-2004 The OSSP Project <http://www.ossp.org/>
+ ##
+ ##  This file is part of OSSP shiela, an access control and logging
+ ##  facility for Concurrent Versions System (CVS) repositories
+ ##  which can be found at http://www.ossp.org/pkg/tool/shiela/.
+ ##
+ ##  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.0 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 file; if not, write to the Free Software
+ ##  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ ##  USA, or contact Ralf S. Engelschall <rse@engelschall.com>.
+ ##
+ ##  shiela-install.sh: repository install program (syntax: Bourne-Shell)
+ ##
+ 
+ version="1.1.3"
+ 
+ prefix="@prefix@"
+ bindir="@bindir@"
+ 
+ if [ ".$TMPDIR" != . ]; then
+     tmpdir=$TMPDIR
+ elif [ ".$TEMPDIR" != . ]; then
+     tmpdir=$TEMPDIR
+ else
+     tmpdir=/tmp
+ fi
+ tmpfile="$tmpdir/shiela-install.$$.tmp"
+ 
+ #   determine terminal bold sequence
+ term_bold='' 
+ term_norm=''
+ case $TERM in
+     #   for the most important terminal types we directly know the sequences
+     xterm|xterm*|vt220|vt220*)
+         term_bold=`awk 'BEGIN { printf("%c%c%c%c", 27, 91, 49, 109); }' </dev/null 2>/dev/null`
+         term_norm=`awk 'BEGIN { printf("%c%c%c", 27, 91, 109); }' </dev/null 2>/dev/null`
+         ;;
+     vt100|vt100*)
+         term_bold=`awk 'BEGIN { printf("%c%c%c%c%c%c", 27, 91, 49, 109, 0, 0); }' </dev/null 2>/dev/null`
+         term_norm=`awk 'BEGIN { printf("%c%c%c%c%c", 27, 91, 109, 0, 0); }' </dev/null 2>/dev/null`
+         ;;
+     #   for all others, we try to use a possibly existing `tput' or `tcout' utility
+     * )
+         paths=`echo $PATH | sed -e 's/:/ /g'`
+         for tool in tput tcout; do
+             for dir in $paths; do
+                 if [ -r "$dir/$tool" ]; then
+                     for seq in bold md smso; do # 'smso' is last
+                         bold="`$dir/$tool $seq 2>/dev/null`"
+                         if [ ".$bold" != . ]; then
+                             term_bold="$bold"
+                             break
+                         fi
+                     done
+                     if [ ".$term_bold" != . ]; then
+                         for seq in sgr0 me rmso reset; do # 'reset' is last
+                             norm="`$dir/$tool $seq 2>/dev/null`"
+                             if [ ".$norm" != . ]; then
+                                 term_norm="$norm"
+                                 break
+                             fi
+                         done
+                     fi
+                     break
+                 fi
+             done
+             if [ ".$term_bold" != . -a ".$term_norm" != . ]; then
+                 break;
+             fi
+         done
+         ;;
+ esac
+ 
+ echo "This is ${term_bold}OSSP shiela Setup${term_norm}, Version ${term_bold}${version}${term_norm}"
+ echo "Copyright (c) 2000-2002 Ralf S. Engelschall <rse@engelschall.com>"
+ echo "Copyright (c) 2000-2002 The OSSP Project <http://www.ossp.org/>"
+ echo ""
+ 
+ echo "${term_bold}PARAMETER DETERMINATION${term_norm}"
+ cat <<EOT
+ 
+ This utility helps you to initially setup OSSP shiela for a particular CVS
+ repository. It asks you a few questions in order to establish an initial
+ OSSP shiela configuration. This can be adjusted later without problems. Only
+ the questions marked with (U) ask for details which are actually used
+ immediately and so have to be correctly entered already now. All other
+ questions ask just for informational (I) details which do not harm if
+ not immediately correct.
+ 
+ EOT
+ 
+ for arg
+ do
+     eval `echo "$arg" | sed -e 's/^\([^=]*\)=\(.*\)$/V_\1="\2"/'`
+ done
+ 
+ query () {
+     vartype=$1
+     varname=$2
+     echo $varname | awk '{ printf("%-16s", $0); }'
+     eval "text=\"($vartype) [\$V_$varname]: \""
+     echo dummy | awk '{ printf("%s", TEXT); }' TEXT="$text"
+     if [ ".$V_batch" = .yes ]; then
+         echo ""
+     else
+         read answer
+         if [ ".$answer" != . ]; then
+             eval "V_${varname}=\"\$answer\""
+         fi
+     fi
+ }
+ 
+ domainname=''
+ hostname="`(uname -n) 2>/dev/null |\
+            awk '{ printf("%s", $1); }'`"
+ if [ ".$hostname" = . ]; then
+     hostname="`(hostname) 2>/dev/null |\
+                awk '{ printf("%s", $1); }'`"
+     if [ ".$hostname" = . ]; then
+         hostname='unknown'
+     fi
+ fi
+ case $hostname in
+     *.* )
+         domainname="`echo $hostname | cut -d. -f2-`"
+         hostname="`echo $hostname | cut -d. -f1`"
+         ;;
+ esac
+ if [ ".$domainname" = . ]; then
+     if [ -f /etc/resolv.conf ]; then
+         domainname="`egrep '^[         ]*domain' /etc/resolv.conf | head -1 |\
+                      sed -e 's/.*domain//' \
+                          -e 's/^[      ]*//' -e 's/^ *//' -e 's/^      *//' \
+                          -e 's/^\.//' |\
+                      awk '{ printf("%s", $1); }'`"
+         if [ ".$domainname" = . ]; then
+             domainname="`egrep '^[     ]*search' /etc/resolv.conf | head -1 |\
+                          sed -e 's/.*search//' \
+                              -e 's/^[  ]*//' -e 's/^ *//' -e 's/^      *//' \
+                              -e 's/ .*//' -e 's/       .*//' \
+                              -e 's/^\.//' |\
+                          awk '{ printf("%s", $1); }'`"
+         fi
+     fi
+ fi
+ if [ ".$V_host_name" = . ]; then
+     V_host_name=$hostname
+ fi
+ query I host_name
+ if [ ".$V_domain_name" = . ]; then
+     V_domain_name=$domainname
+ fi
+ query U domain_name
+ 
+ if [ ".$V_user_name" = . ]; then
+     V_user_name="$LOGNAME"
+     if [ ".$V_user_name" = . ]; then
+         V_user_name="$USER"
+         if [ ".$V_user_name" = . ]; then
+             V_user_name="`(whoami) 2>/dev/null |\
+                           awk '{ printf("%s", $1); }'`"
+             if [ ".$V_user_name" = . ]; then
+                 V_user_name="`(who am i) 2>/dev/null |\
+                               awk '{ printf("%s", $1); }'`"
+                 if [ ".$V_user_name" = . ]; then
+                     V_user_name='unknown'
+                 fi
+             fi
+         fi
+     fi
+ fi
+ query U user_name
+ 
+ if [ ".$V_user_realname" = . ]; then
+     V_user_realname=`(cat /etc/passwd; (ypcat passwd) 2>/dev/null) |\
+                      egrep "^$V_user_name:" 2>/dev/null | \
+                      sed -e 's/[^:]*:[^:]*:[^:]*:[^:]*://' -e 's/:.*$//'`
+ fi
+ query I user_realname
+ 
+ if [ ".$V_user_email" = . ]; then
+     V_user_email="${V_user_name}@${V_domain_name}"
+ fi
+ query U user_email
+ 
+ if [ ".$V_project_tag" = . ]; then
+     V_project_tag="`echo ${V_user_name} |\
+                     tr 'abcdefghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'`"
+ fi
+ query I project_tag
+ 
+ if [ ".$V_project_name" = . ]; then
+     V_project_name="${V_user_realname}'s CVS Test Project"
+ fi
+ query I project_name
+ 
+ if [ ".$V_project_home" = . ]; then
+     V_project_home="http://${V_host_name}.${V_domain_name}/~${V_user_name}/"
+ fi
+ query I project_home
+ 
+ if [ ".$V_project_contact" = . ]; then
+     V_project_contact=${V_user_email}
+ fi
+ query I project_contact
+ 
+ if [ ".$V_repos_tag" = . ]; then
+     V_repos_tag="CVS-`echo ${V_user_name} |\
+                  tr 'abcdefghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'`"
+ fi
+ query I repos_tag
+ 
+ if [ ".$V_repos_name" = . ]; then
+     V_repos_name="${V_user_realname}'s CVS Test Repository"
+ fi
+ query I repos_name
+ 
+ if [ ".$V_repos_contact" = . ]; then
+     V_repos_contact=${V_project_contact}
+ fi
+ query I repos_contact
+ 
+ if [ ".$V_repos_home" = . ]; then
+     V_repos_home=${V_project_home}
+ fi
+ query I repos_home
+ 
+ if [ ".$V_repos_host" = . ]; then
+     V_repos_host="${V_host_name}.${V_domain_name}"
+ fi
+ query U repos_host
+ 
+ if [ ".$V_repos_path" = . ]; then
+     V_repos_path="${CVSROOT-/tmp}"
+ fi
+ query U repos_path
+ if [ ! -d "$V_repos_path/CVSROOT" ]; then
+     echo "shiela-install:Error: \`$V_repos_path' does not look like a CVS repository" 1>&2
+     exit 1
+ fi
+ 
+ if [ ".$V_repos_history" = . ]; then
+     V_repos_history="CVSROOT/shiela.log"
+ fi
+ query U repos_history
+ 
+ if [ ".$V_env_path" = . ]; then
+     V_env_path="/bin:/usr/bin:/sbin:/usr/sbin"
+ fi
+ query I env_path
+ 
+ #   check whether the test command supports the -x option
+ if [ -x /bin/sh ] 2>/dev/null; then
+     minusx="-x"
+ else
+     minusx="-r"
+ fi
+ #   split path string
+ paths="`echo $PATH |\
+         sed -e 's/^:/.:/' \
+             -e 's/::/:.:/g' \
+             -e 's/:$/:./' \
+             -e 's/:/ /g'`"
+ 
+ if [ ".$V_tool_perl" = . ]; then
+     V_tool_perl="perl"
+     rm -f $tmpfile
+     touch $tmpfile
+     found=0
+     pc=99
+     for dir in $paths; do
+         dir=`echo $dir | sed -e 's;/*$;;'`
+         nc=99
+         for name in perl perl5 miniperl; do
+              if [ $minusx "$dir/$name" -a ! -d "$dir/$name" ]; then
+                  perl="$dir/$name"
+                  pv=`$perl -e 'printf("%.3f", $]);'`
+                  echo "$pv:$pc:$nc:$perl" >>$tmpfile
+                  found=1
+              fi
+              nc=`expr $nc - 1`
+         done
+         pc=`expr $pc - 1`
+     done
+     if [ $found = 1 ]; then
+         V_tool_perl="`cat $tmpfile | sort -u | tail -1 | cut -d: -f4`"
+     fi
+     rm -f $tmpfile
+ fi
+ query U tool_perl
+ 
+ if [ ".$V_tool_sendmail" = . ]; then
+     V_tool_sendmail="sendmail"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/sendmail" ] && [ ! -d "$path/sendmail" ]; then
+             V_tool_sendmail="$path/sendmail"
+             break
+         fi
+     done
+ fi
+ query I tool_sendmail
+ 
+ if [ ".$V_tool_diff" = . ]; then
+     V_tool_diff="diff"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/diff" ] && [ ! -d "$path/diff" ]; then
+             V_tool_diff="$path/diff"
+             break
+         fi
+     done
+ fi
+ query I tool_diff
+ 
+ if [ ".$V_tool_xdelta" = . ]; then
+     V_tool_xdelta="xdelta"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/xdelta" ] && [ ! -d "$path/xdelta" ]; then
+             V_tool_xdelta="$path/xdelta"
+             break
+         fi
+     done
+ fi
+ query I tool_xdelta
+ 
+ if [ ".$V_tool_uuencode" = . ]; then
+     V_tool_uuencode="uuencode"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/uuencode" ] && [ ! -d "$path/uuencode" ]; then
+             V_tool_uuencode="$path/uuencode"
+             break
+         fi
+     done
+ fi
+ query I tool_uuencode
+ 
+ if [ ".$V_tool_cvs" = . ]; then
+     V_tool_cvs="cvs"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/cvs" ] && [ ! -d "$path/cvs" ]; then
+             V_tool_cvs="$path/cvs"
+             break
+         fi
+     done
+ fi
+ query U tool_cvs
+ 
+ CVS_VERSION=`$V_tool_cvs --version |\
+              grep "Concurrent Versions System (CVS)" |\
+              sed -e 's;^.*(CVS) ;;' -e 's; .*$;;'`
+ if [ ".`$V_tool_cvs --version | grep RSE`" != . ]; then
+     CVS_VENDOR=RSE
+ else
+     CVS_VENDOR=CVSHome.org
+ fi
+ case $CVS_VERSION in
+    1.12.[6-9] | 1.12.[1-9][0-9] | 1.1[3-9].* )
+        ;;
+    * )
+        echo "ERROR: CVS has to be version 1.12.6 or higher"
+        exit 1
+        ;;
+ esac
+ case $CVS_VENDOR in
+     RSE )
+        ;;
+     * )
+        echo "WARNING: You are using a stock CVS version from $CVS_VENDOR!"
+        echo "         This means that not all OSSP shiela functionality is available"
+        echo "         for you. We recommend to use the OpenPKG CVS version with"
+        echo "         the enhancement patchset from Ralf S. Engelschall applied."
+        echo "         [see http://www.openpkg.org/ for OpenPKG]"
+        echo ""
+        ;;
+ esac
+ 
+ if [ ".$V_tool_shiela" = . ]; then
+     V_tool_shiela="$bindir/shiela"
+     for path in $paths; do
+         path=`echo $path | sed -e 's;/*$;;'`
+         if [ $minusx "$path/shiela" ] && [ ! -d "$path/shiela" ]; then
+             V_tool_shiela="$path/shiela"
+             break
+         fi
+     done
+ fi
+ query U tool_shiela
+ 
+ if [ ".$V_shiela_local" = . ]; then
+     V_shiela_local=yes
+ fi
+ query U shiela_local
+ 
+ cat >$tmpdir/shiela.cfg <<EOT
+ ##
+ ##  OSSP shiela - Access Control and Logging Facility for CVS
+ ##  Copyright (c) 2000-2004 Ralf S. Engelschall <rse@engelschall.com>
+ ##  Copyright (c) 2000-2004 The OSSP Project <http://www.ossp.org/>
+ ##
+ ##  This file is part of OSSP shiela, an access control and logging
+ ##  facility for Concurrent Versions System (CVS) repositories
+ ##  which can be found at http://www.ossp.org/pkg/tool/shiela/.
+ ##
+ ##  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.0 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 file; if not, write to the Free Software
+ ##  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ ##  USA, or contact Ralf S. Engelschall <rse@engelschall.com>.
+ ##
+ ##  shiela.cfg: run-time configuration (syntax: OSSP shiela C-style)
+ ##
+ 
+ Environment {
+     Setenv  PATH     ${V_env_path};
+     Program sendmail ${V_tool_sendmail};
+     Program cvs      ${V_tool_cvs};
+     Program diff     ${V_tool_diff};
+     Program xdelta   ${V_tool_xdelta};
+     Program uuencode ${V_tool_uuencode};
+ };
+ 
+ Project {
+     Tag     ${V_project_tag};
+     Name    "${V_project_name}";
+     Contact ${V_project_contact};
+     Home    ${V_project_home};
+     Users {
+         User ${V_user_name} "${V_user_realname}" ${V_user_email};
+     };
+     Groups {
+         Group users "Repository Users" { ${V_user_name} };
+     };
+ };
+ 
+ Repository {
+     Tag     ${V_repos_tag};
+     Name    "${V_repos_name}";
+     Contact ${V_repos_contact};
+     Home    ${V_repos_home};
+     Host    ${V_repos_host};
+     Path    ${V_repos_path};
+     History ${V_repos_history};
+     Modules {
+         Module CVSROOT "CVS Administrative Files" {
+             Acl * *:users;
+             Log passwd none;
+             Log * mail:${V_user_email};
+         };
+     };
+ };
+ 
+ Logging {
+     Reports {
+         Report mail {
+             Content title rule header files log summary rule details;
+             Details patch:plain;
+         };
+     };
+ };
+ 
+ EOT
+ 
+ cat >$tmpdir/shiela.msg <<EOT
+ 
+ PR:
+ Submitted by:
+ Reviewed by:
+ Approved by:
+ Obtained from:
+ CVS: ----------------------------------------------------------------------
+ CVS: PR:            Fill this in if a problem report is affected
+ CVS: Submitted by:  Fill this in if someone else sent you the change
+ CVS: Reviewed by:   Fill this in if someone else reviewed your modification
+ CVS: Approved by:   Fill this in if you needed approval for this commit
+ CVS: Obtained from: Fill this in if the change is from third party software
+ CVS: ----------------------------------------------------------------------
+ EOT
+ 
+ echo ""
+ echo "${term_bold}SHIELA CONFIGURATION${term_norm}"
+ cat <<EOT
+ 
+ Initial "shiela.cfg" and "shiela.msg" files were generated for you.
+ Before OSSP shiela is installed and activated with these configuration files,
+ you have the chance to adjust them in your editor.
+ 
+ EOT
+ text="Edit \"shiela.cfg\" now with \"${EDITOR-vi}\" [y/N]: "
+ echo dummy | awk '{ printf("%s", TEXT); }' TEXT="$text"
+ if [ ".$V_batch" = .yes ]; then
+     echo ""
+ else
+     read answer
+     if [ ".$answer" = .y ]; then
+         cd $tmpdir && ${EDITOR-vi} shiela.cfg
+     fi
+ fi
+ text="Edit \"shiela.msg\" now with \"${EDITOR-vi}\" [y/N]: "
+ echo dummy | awk '{ printf("%s", TEXT); }' TEXT="$text"
+ if [ ".$V_batch" = .yes ]; then
+     echo ""
+ else
+     read answer
+     if [ ".$answer" = .y ]; then
+         cd $tmpdir && ${EDITOR-vi} shiela.msg
+     fi
+ fi
+ echo ""
+ 
+ echo "${term_bold}CVSROOT MODIFICATION${term_norm}"
+ cat <<EOT
+ 
+ Ok, we are now prepared to modify your repository. We will first
+ checkout CVSROOT and modify it. Then you have a last chance to stop
+ processing before we finally commit the modifications.
+ 
+ EOT
+ 
+ run () {
+     echo "\$ $*" 1>&2
+     eval $* || exit 1
+ }
+ 
+ cvs_file () {
+     op=$1
+     file=$2;
+     name=`echo $file | sed -e 's;\.;_;g'`
+     if [ ".$op" = .tst ]; then
+         if [ -f $file ]; then
+             eval "cvs_file_add_${name}=no"
+         else
+             eval "cvs_file_add_${name}=yes"
+         fi
+     elif [ ".$op" = .add ]; then
+         eval "add=\$cvs_file_add_${name}"
+         if [ ".$add" = .yes ]; then
+             run $V_tool_cvs -q add $file
+         fi
+     fi
+ }
+ 
+ run rm -rf CVSROOT
+ run cvs -Q -q -d${V_repos_path} co CVSROOT
+ run cd CVSROOT
+ 
+ if [ ".$V_shiela_local" = .yes ]; then
+     cvs_file tst shiela
+     run "cp $V_tool_shiela ."
+     run chmod 755 shiela
+     cvs_file add shiela
+     V_tool_shiela="\$CVSROOT/CVSROOT/shiela"
+ fi
+ 
+ cvs_file tst shiela.cfg
+ run cp $tmpdir/shiela.cfg .
+ run chmod 644 shiela.cfg
+ cvs_file add shiela.cfg
+ 
+ cvs_file tst shiela.msg
+ run cp $tmpdir/shiela.msg .
+ run chmod 644 shiela.msg
+ cvs_file add shiela.msg
+ 
+ cvs_file tst config
+ if [ ".`grep -i UseNewInfoFmtStrings config`" != . ]; then
+     run "cp config config.old && sed -e 's;UseNewInfoFmtStrings=.*;UseNewInfoFmtStrings=yes;' <config.old >config && rm -f config.old"
+ else
+     run "(echo ''; echo 'UseNewInfoFmtStrings=yes'; echo '') >>config"
+ fi
+ cvs_file add config
+ 
+ cvs_file tst checkoutlist
+ run "echo 'shiela.cfg' >>checkoutlist"
+ run "echo 'shiela' >>checkoutlist"
+ run "echo 'shiela.msg' >>checkoutlist"
+ cvs_file add checkoutlist
+ 
+ cvs_file tst rcsinfo
+ run "(echo ''; echo 'ALL \$CVSROOT/CVSROOT/shiela.msg'; echo '') >>rcsinfo"
+ cvs_file add rcsinfo
+ 
+ cvs_file tst taginfo
+ run "(echo ''; echo 'ALL $V_tool_shiela --hook=taginfo %t %o %p %{sv}'; echo '') >>taginfo"
+ cvs_file add taginfo
+ 
+ if [ ".$CVS_VENDOR" = .RSE ]; then
+     cvs_file tst importinfo
+     run "(echo ''; echo 'ALL $V_tool_shiela --hook=importinfo'; echo '') >>importinfo"
+     cvs_file add importinfo
+ 
+     cvs_file tst admininfo
+     run "(echo ''; echo 'ALL $V_tool_shiela --hook=admininfo'; echo '') >>admininfo"
+     cvs_file add admininfo
+ fi
+ 
+ cvs_file tst commitinfo
+ run "(echo ''; echo 'ALL $V_tool_shiela --hook=commitinfo %r/%p %s'; echo '') >>commitinfo"
+ cvs_file add commitinfo
+ 
+ cvs_file tst verifymsg
+ run "(echo ''; echo 'DEFAULT $V_tool_shiela --hook=verifymsg %l'; echo '') >>verifymsg"
+ cvs_file add verifymsg
+ 
+ if [ ".$CVS_VENDOR" = .RSE ]; then
+     flags="sVvto"
+ else
+     flags="sVv"
+ fi
+ cvs_file tst loginfo
+ run "(echo ''; echo 'ALL $V_tool_shiela --hook=loginfo %p %{${flags}}'; echo '') >>loginfo"
+ cvs_file add loginfo
+ 
+ run $V_tool_cvs update
+ 
+ echo ""
+ echo "${term_bold}The above modifications were made to CVSROOT.${term_norm}"
+ text="${term_bold}Are you sure to finally commit these modifications [y/N]: ${term_norm}"
+ echo dummy | awk '{ printf("%s", TEXT); }' TEXT="$text"
+ if [ ".$V_batch" = .yes ]; then
+     echo ""
+ else
+     read answer
+     if [ ".$answer" = . -o ".$answer" = .n ]; then
+         cd ..
+         rm -rf CVSROOT
+         echo ""
+         echo "**Break: nothing touched."
+         echo ""
+         exit 0
+     fi
+ fi
+ echo ""
+ run "$V_tool_cvs commit -m 'Add OSSP shiela -- Access Control and Logging Facility for CVS' ."
+ run cd ..
+ run rm -rf CVSROOT
+ 
+ cat <<EOT
+ 
+ Ok, your CVS repository was modified to now use OSSP shiela for access
+ control and logging. You can try it out by checking out CVSROOT
+ yourself and modify some files. You should receive an Email for every
+ modification. Then especially adjust "shiela.cfg" for your particular
+ repository layout.
+ 
+ EOT
+ 
+ rm -f $tmpfile
+ rm -f $tmpdir/shiela.cfg
+ rm -f $tmpdir/shiela.msg
+ 

CVSTrac 2.0.1