ViitorMake/SysBuild/network/sendmail

124 lines
5.2 KiB
Plaintext
Raw Normal View History

#!/bin/bash
#Framework, welches ein komplettes Linux System aus den Sourcen erstellt
#dieses Framework wird im CVS Repository
#:pserver:cvs.tramp-bbs.de:/opt/cvs zur Verf<72>gung gestellt
#
#Lage dieser Datei im Archiv: $HeadURL: svn://svn.compuextreme.de/Viitor/V963/ViitorMake/SysBuild/network/sendmail $
#
#(c) 2003 Harald Kueller, Germany
#This program is free software; you can redistribute it and/or
#modify ist 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; if not write to the Free Software Foundation,
#Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
#Dies ist ein Module zur Verwendung mit genpkg. Die Erzeugung eines
#Viitor Linux Packetes wird <20>ber die Funktionen premk, mk und postmk
#gesteuert. premk() dient zur Vorbereitung des Sourcecodes. Hier k<>nnen
#diverse <20>nderungen am sourcecode (mit awk/sed usw.) vorgenommen werden
#mk() umfasst die source Konfiguration und das <20>bersetzten des source
#codes. Auch die Installation mu<6D> von mk erledigt werden. Hier gild dass
#die Installation immer nach $TMPROOT erfolgen soll (meisst kann das mit
#"make DESTDIR=$TMPROOT install" angestossen werden). postmk kann
#vor der packeterstellung noch einiges am installationtree <20>ndern. postmk
#l<>uft nachdem die Packetabh<62>ngigkeiten erstellt wurden.
#Das Verhalten von genpkg kann <20>ber die Variable MKPKG gesteuert werden.
#Hier m<>ssen FLAGS zur Steuerung gesetzt werden. Folgende Flags werden
#erkannt:
#
# 1 : Package Erzeugung erzwingen. Packet wird, auch wenn es schon
# vorhanden ist, ohne weitere r<>ckfragen neu Erzeugt.
# 2 : Package Installation erzwingen. Installpkg wird mit -f aufgerufen.
# Das bewirkt, das installpkg keine r<>ckfragen bei der installation
# Stellt, und das packet in jedemfall (neu) installiert.
# 4 : Sourcepacket nicht nach MAKEDIR entpacken. Ist dieses Flag gesetzt
# muss sich das Module selber um das Entpacken der sourcedateien k<>mmern.
# vor allem wichtig bei Packeten, f<>r die es keine source.tgz gibt
# (z.B. aus dem CVS generierte Packete).
# 8 : Erstellung des Packetes aus $TMPROOT wird unterdr<64>ckt. Dies ist bei
# manchen Sonderf<72>llen m<>glich - wenn sich z.B. der Packetnamen nicht
# aus dem Namen des sourcearchives ableiten l<>sst. Packet sollte in
# so einem Fall in der postmk() Funktion erstellt werden.
# 16 : Packet wird nicht installiert. Bei Packeten wie tar oder bash kann
# die installation mittelst installpkg probleme machen.
# 32 : Dependics File so erzeugen, das die Abh<62>ngigkeiten bei der installation
# erf<72>llt sein m<>ssen. installpkg bricht in so einem fall bei fehlenden
# packeten die installation ab, und gibt nicht "nur" warnmeldungen aus.
# Wichtig bei packeten mit postinstallroutine, die software aus dem
# frisch installierten Packet verwendet (wie z.B. postgresql)
# 64 : sourcetree aufr<66>umen nach packeterstellung unterbinden.
#
#Module zur Erstellung des Packetes: sendmail
#Quelle der Source Archive: www.sendmail.org
#Kurzbeschreibung:
#Die Eierlegendewollmilchsau im bereich der E-Mail Server.
#Sendmail ist wohl eines der <20>ltesten Mail-Server Programme (MTA) und
#bietet in der Konfiguration eine m<>chtige Sprache um nahezu alle vorstellbaren
#aufgaben im E-Mail bereich l<>sen zu k<>nnen. Durch das modulare Konzept kann
#sendmail beliebig erweitert werden, und um weitere Mail Protokolle erg<72>nzt
#werden. Sendmail beherscht von sich aus das smtp protokoll.
#
#Letzte <20>nderung von: $Author$
#Datum der letzten <20>nderung: $Date: 2011-02-08 21:01:05 +0100 (Di, 08 Feb 2011) $
#Version der Datei: $Rev$
#
#
#Pfad zu Basis Source Tree eintragen!
SRCPATH=Network/Servers
#Funktion wird nach dem Entpacken der Sourcen, im Tree der Sourcen
#ausgef<65>hrt (sprich unpack src; cd src; premk)
#Hier kann z.B. das Makefile gepatcht werden (SED l<>sst gr<67>ssen
premk() {
WDIR=`pwd`
mkdir -p $TMPROOT/usr/bin $TMPROOT/usr/share/man/man1 \
$TMPROOT/usr/share/man/man8 $TMPROOT/usr/share/man/man5 \
$TMPROOT/usr/sbin
cd $TMPROOT/usr
ln -s share/man man
if ! getent group smmsp 2>&1 >/dev/null; then
groupadd -g 23 smmsp
fi
if ! getent passwd smmsp 2>&1 >/dev/null; then
useradd -u 44 -g smmsp -s /bin/false -d /tmp smmsp
fi
cd $WDIR
}
#Hier
mk() {
./Build
for i in `find obj.* -name "Makefile"`; do
sed -e "s/-ldb/-ldb -lpthread/g" $i >/tmp/`basename $i`
mv /tmp/`basename $i` $i
done
./Build
./Build DESTDIR=$TMPROOT install
}
#Funktion wird nach Ablauf des Make Prozesses ausgef<65>hrt, und kann
#in $TMPROOT noch einiges korrigieren
postmk() {
mkdir $TMPROOT/usr/share/sendmail
cp -rp cf $TMPROOT/usr/share/sendmail
cp obj*/mail.local/mail.local $TMPROOT/usr/bin
cp obj*/mail.local/mail.local.8 $TMPROOT/usr/man/man8
cp obj*/rmail/rmail $TMPROOT/usr/bin
cp obj*/rmail/rmail.8 $TMPROOT/usr/man/man8
cd $TMPROOT/usr/bin
ln -s ../sbin/sendmail mail
cd -
2022-12-13 14:29:18 +00:00
GetGit Viitor_sendmail $TMPROOT
rm $TMPROOT/usr/man
}