#!/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ügung gestellt # #Lage dieser Datei im Archiv: $HeadURL: svn://svn.compuextreme.de/Viitor/V963/ViitorMake/SysBuild/security/openssl $ # #(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 über die Funktionen premk, mk und postmk #gesteuert. premk() dient zur Vorbereitung des Sourcecodes. Hier können #diverse Änderungen am sourcecode (mit awk/sed usw.) vorgenommen werden #mk() umfasst die source Konfiguration und das Übersetzten des source #codes. Auch die Installation muß 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 ändern. postmk #läuft nachdem die Packetabhängigkeiten erstellt wurden. #Das Verhalten von genpkg kann ü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ückt. Dies ist bei # manchen Sonderfä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ängigkeiten bei der installation # erfü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äumen nach packeterstellung unterbinden. # #Module zur Erstellung des Packetes: openssl #Quelle der Source Archive: http://www.openssl.org/source #Kurzbeschreibung: #Offene Secure Socket Layer (SSL) implementierung - wird von vielen #frei erhältlichen tools verwendet # #Letzte Änderung von: $Author$ #Datum der letzten Änderung: $Date: 2009-05-20 12:16:02 +0200 (Mi, 20 Mai 2009) $ #Version der Datei: $Rev$ # # SRCPATH=Security/Lib (( MKPKG = $MKPKG | 4 )) (( MKPKG = $MKPKG | 128 )) #Funktion wird nach dem Entpacken der Sourcen, im Tree der Sourcen #ausgeführt (sprich unpack src; cd src; premk) #Hier kann z.B. das Makefile gepatcht werden (SED lässt grüssen premk() { echo "Nothing to do for premk()" } mk32() { tar -C $MAKEDIR -xvf $LFSSOURCE/$SRCPATH/openssl-*.tar.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-32bit_x86_64-*.patch.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-fix_manpages-*.patch.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-build_fix-*.patch.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-mips_support-*.patch.* cd $MAKEDIR/openssl* USE_ARCH=$UARCH \ ./Configure linux-x86_64-32 \ --openssldir=/etc/sysconfig/ssl \ --prefix=/usr \ shared make -j $NUMCPU MANDIR=/usr/share/man make INSTALL_PREFIX=$TMPROOT MANDIR=/usr/share/man install cd .. rm -r $MAKEDIR/openssl* } #Hier wird der Make Prozess der Sourcen definiert mk() { tar -C $MAKEDIR -xvf $LFSSOURCE/$SRCPATH/openssl-*.tar.* if [ "$MK64BIT" == "true" ]; then SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-allow_lib64-*.patch.* SYSTYPE=linux-x86_64 mv $TMPROOT/usr/lib $TMPROOT/usr/lib32 mkdir -p $TMPROOT/usr/lib64/engines ln -s lib64/engines $TMPROOT/usr/engines ln -s lib64 $TMPROOT/usr/lib else SYSTYPE=linux-generic32 fi SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-fix_manpages-*.patch.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-build_fix-*.patch.* SrcPatch $MAKEDIR/openssl* $LFSSOURCE/$SRCPATH/openssl-*-mips_support-*.patch.* cd $MAKEDIR/openssl* USE_ARCH=$UARCH \ ./Configure $SYSTYPE \ --openssldir=/etc/sysconfig/ssl \ --prefix=/usr \ shared make MANDIR=/usr/share/man make INSTALL_PREFIX=$TMPROOT MANDIR=/usr/share/man install cp -v -r certs $TMPROOT/etc/sysconfig/ssl install -v -d -m755 $TMPROOT/usr/share/doc/openssl-0.9.8k && cp -v -r doc/{HOWTO,README,*.{txt,html,gif}} \ $TMPROOT/usr/share/doc/openssl-0.9.8k } #Funktion wird nach Ablauf des Make Prozesses ausgeführt, und kann #in $TMPROOT noch einiges korrigieren postmk() { if [ "$MK64BIT" == "true" ]; then rm $TMPROOT/usr/engines rm $TMPROOT/usr/lib mv $TMPROOT/usr/lib32 $TMPROOT/usr/lib fi cd rm -r $MAKEDIR/openssl* }