#---------------------------------------------------------------------------- # build_libpam.txt - how to build the libpam binaries and create folder and packages # # Creation : 2008-11-08 holbru # Last update: $Id$ # # !!! this is not a script but an step-by-step howto !!! #------------------------------------------------------------------------------ exit 1 ### download the source code from the internet, e.g. # http://www.us.kernel.org/pub/linux/libs/pam/index.html # http://www.us.kernel.org/pub/linux/libs/pam/index.html # libpam-1.0.2.tar.bz2 ### extract file in a temporary location tar -xjvf libpam-1.0.2.tar.bz2 cd libpam-0.80 ### build export CFLAGS='-O2 -march=i486' export CXXFLAGS="${CFLAGS}" # 2010-03-05 # Linux-Pam-1.1.1 # 2010-07-11 # Linux-Pam-1.1.1.90 # require libcrack-dev libdb4-dev libxcrypt-dev ./configure \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu \ --enable-shared \ --enable-static \ --disable-audit \ --libdir=/lib \ --sbindir=/sbin \ --enable-securedir=/lib/security \ --docdir=/usr/share/doc/Linux-Pam \ --enable-read-both-confs # # # # 2013-01-30 -> Linux-Pam-1.1.1.90 # patches from SuSE pam-1.1.1.90-1.4.src.rpm # pam_tally-deprecated.diff # 2013-08-15 -> Linux-Pam-1.1.3 # build with RPM Suse 11.4 # pam-1.1.3-4.7.1.src.rpm # require libcrack-dev libdb-dev libxcrypt-dev ./configure \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu \ --enable-shared \ --enable-static \ --disable-audit \ --disable-prelude \ --libdir=/lib \ --sbindir=/sbin \ --enable-securedir=/lib/security \ --docdir=/usr/share/doc/Linux-Pam \ --enable-read-both-confs # 2016-01-23 -> pam-1.1.8 # build with rpm suse # pam-1.1.8-6.1.src.rpm # 2016-01-24 -> pam_devperm-1.6 # build with rpm Suse # pam_devperm-1.6-2.89.src.rpm # 2016-01-24 -> pam-modules-12.1 # build with rpm Suse # pam-modules-12.1-16.1.1.src.rpm # hbfl # 2017-10-08 -> pam-1.3.0 # build with rpm Suse # pam-1.3.0-135.1.src.rpm # hbfl # 2017-10-08 -> pam-modules-12.1 # build with rpm Suse # pam-modules-12.1-27.2.src.rpm # hbfl # 2019-08-26 -> pam-1.3.1 # build with rpm Suse # pam-1.3.1-3.6.src.rpm # hbfl # 2020-03-05 -> pam-1.3.1+git20190923.ea78d67 # build with rpm Suse # pam-1.3.1+git20190923.ea78d67-2.1.src.rpm # hbfl # 2020-04-06 -> pam-1.3.1+git20190923.ea78d67 # rebuild with rpm Suse -> gcc-9.2.1 -> glibc-2.31 # pam-1.3.1+git20190923.ea78d67-4.1.src.rpm # hbfl # 2021-06-03 -> pam-1.5.1 # build with rpm Suse -> gcc-10 -> glibc-2.33 # pam-1.5.1-4.13.src.rpm # hbfl # 2022-01-19 -> pam-1.5.2 # build with rpm Suse # pam-1.5.2-5.3.src.rpm # hbfl # 2022-03-31 -> pam-1.5.2 # rebuild with rpm Suse # pam-1.5.2-6.1.src.rpm # !! --disable-nis !!! # hbfl # 2023-04-07 -> pam-1.5.2 # rebuild with rpm Suse -> gcc-12 -> glibc-2.37 # pam-1.5.2-14.1.src.rpm # pam-unix -> now reincluded # hbfl # 2024-07-11 -> pam-1.6.1 # build with rpm Suse # pam-1.6.1-1.1.src.rpm # pam-full-src-1.6.1-1.1.src.rpm # hbfl # 2025-03-16 -> pam-1.7.0 # build with rpm Suse -> gcc-14 -> glibc-2.41 # pam-1.7.0-2.4.src.rpm # hbfl # 2025-04-29 -> pam-full-src-1.7.0 # build with rpm Suse -> gcc-14 -> glibc-2.41 # pam-full.src-1.7.0-2.4.src.rpm # drop build doc, required fop make make -k check make DESTDIR=/public/lib/pam/1.1.1.90 install # strip files/binarys for filename in `find /public/lib/pam/1.1.1.90/{sbin/*,lib/{*.so.*,security/{*.so,pam_filter/*}}} -type f` do echo $filename strip -R .note -R .comment "$filename" done cd /lib/security for x in pam_unix_auth pam_unix_acct pam_unix_passwd pam_unix_session do ln -f pam_unix.so $x.so done chmod 4755 /sbin/unix_chkpwd chmod 0700 /sbin/unix_update mkdir -p /var/run/sepermit # 2013-08-17 pam-modules-11.4 # build with RPM Suse 11.4 # pam-modules-11.4-2.1.src.rpm # included # pam_make-1.2 # pam_homecheck-2.0 # pam_pwcheck-3.12.5 # pam_unix2-2.7.4 # # # pam_make-1.2 # 2013-01-30 for pam-1.1.1.90 LibC-2.8 patch -Np1 -i ../pam-modules-10.3-pam_make-fix-open.dif ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu \ --enable-static make check make DESTDIR=/public/lib/pam/pam_make install for filename in `find /public/lib/pam/pam_make/lib/security/*.so -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_homecheck-2.0 # 2013-01-30 for pam-1.1.1.90 LibC-2.8 ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu \ --enable-static make check make DESTDIR=/public/lib/pam/pam_homecheck install for filename in `find /public/lib/pam/pam_homecheck/lib/security/*.so -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_pwcheck-3.12.5 # 2013-01-30 for pam-1.1.1.90 LibC-2.8 ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu make check make DESTDIR=/public/lib/pam/pam_pwcheck install for filename in `find /public/lib/pam/pam_pwcheck/lib/security/*.so -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_unix2-2.7.3 # 2013-01-30 pam-unix2-2.7.4 for pam-1.1.1.90 LibC-2.8 ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu make check make DESTDIR=/public/lib/pam/pam_unix2 install gcc -o unix2_chkpwd unix2_chkpwd.c -lpam mkdir -p /public/lib/pam/pam_unix2/sbin cp unix2_chkpwd /public/lib/pam/pam_unix2/sbin/ chmod 4755 /sbin/unix2_chkpwd for filename in `find /public/lib/pam/pam_unix2/{sbin/*,lib/security/*.so} -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_login-3.40 # 2013-01-30 pam-login-4.0 for pam-1.1.1.90 LibC-2.8 # 2013-08-17 pam-login-4.0 # build with RPM Suse 11.4 # login-4.0-7.10.1.src.rpm patch -Np0 -i ../bugzilla-148065.patch patch -Np0 -i ../pam_login-3.35-pts.patch patch -Np0 -i ../bnc652633.patch ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu make check make DESTDIR=/public/lib/pam/pam_login install for filename in `find /public/lib/pam/pam_login/{bin/*,usr/bin/*} -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_chroot-0.9.2 # 2013-01-30 for pam-1.1.1.90 LibC-2.8 # 2013-08-17 pam_chroot-0.9.2 # build with RPM Suse 11.4 # pam_chroot-0.9.2-50.1.src.rpm patch -Np0 -i ../pam_chroot-0.9.2.dif make CFLAGS='-O2 -march=i486 -fPIC -DHAVE_SHADOW -DLINUX_PAM' make DESTDIR=/public/lib/pam/pam_chroot install for filename in `find /public/lib/pam/pam_chroot/lib/security/*.so -type f` do echo $filename strip -R .note -R .comment "$filename" done # # # pam_devperm-1.6 # 2013-01-30 for pam-1.1.1.90 LibC-2.8 # 2013-08-17 pam_devperm-1.6 # build with RPM Suse 11.4 # pam_devperm-1.6-2.1.src.rpm patch -Np0 -i ../pam_devperm-1.6.diff ./configure \ --libdir=/lib \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu make make check make DESTDIR=/public/lib/pam/pam_devperm install for filename in `find /public/lib/pam/pam_devperm/{sbin/*,lib/security/*.so} -type f` do echo $filename strip -R .note -R .comment "$filename" done pam_imap_0_3_8 - http://pam-imap.sourceforge.net/ ./configure --prefix=/usr --build=i486-pc-linux-gnu make make DESTDIR=/public/libpam-imap strip -R .note -R .comment /public/libpam-imap/lib/*/* pam_mysql_0_7RC1 - http://pam-mysql.sourceforge.net/ ./configure --prefix=/usr --build=i486-pc-linux-gnu make make DESTDIR=/public/libpam-mysql strip -R .note -R .comment /public/libpam-mysql/lib/*/* #--------------------------------------------------------------------------- create folder Um die Folder im Hauptverszeichnis zu erstellen gibt es das Script 'libpam-folder.sh' unter libpam/_ADMIN/ mit libpam-folder.sh -v 0.80 -w create wird die folder Struktur fuer die lib Version 0.80 erstellt nun koennen die files aus dem compilat eingefuegt werden. mit libpam-folder.sh -v 0.80 -w add wird ein svn add auf die erzeugten Folder durchgefuehrt. mit libpam-folder.sh -v 0.80 -w list wird fuer jeden Folder die files-list.txt erzeugt, add muss zwingend vorher ausgefuehrt worden sein mit libpam-folder.sh -v 0.80 -w ci erfolgt der commit der erzeugten Folder In den eis und eis_dev Foldern muessen keine Anpassungen vorgenommen werden. Diese Anpassungen erfolgen beim packen der packages durch mktarball.sh mit den _do_ Scripten unter _ADMIN automatisch. In den Pack-Scripten unter _ADMIN muss dann noch die Pfadangabe geaendert werden, auf den soeben erzeugten Pfad und ein commit ausgefuehrt werden. Nach dem checkout auf eisler koennen nun die packages erzeugt werden. die wichtigsten Parameter fuer mktarball.sh sind dann -setdate now -setversion ${version} mktarball.sh - home -setdate now -setversion [version angeben] libpam libpam-dev duch die Angabe von -home werden die packages in die Folder Struktur /home/user/public_html/packages/ kopiert und koennen von da direkt auf Pack-Eis geladen werden. wichtig ist noch, dass unbedingt die 'lib' Version zuerst gebaut werden muss, da fuer die 'dev' Version Informationen aus der 'lib' Info Datei gelesen werden.