annotate security/shadow/shadow.sh @ 822:a73b34fe66ec

security/shadow: add custom PAM files recommended per LFS
author David Demelier <markand@malikania.fr>
date Wed, 21 Aug 2019 20:50:00 +0200
parents 59a2fa6992bc
children ae55d9077f70
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 #!/bin/sh
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 #
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 # Copyright (c) 2019 David Demelier <markand@malikania.fr>
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
4 #
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 # Permission to use, copy, modify, and/or distribute this software for any
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 # purpose with or without fee is hereby granted, provided that the above
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 # copyright notice and this permission notice appear in all copies.
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 #
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 #
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
17
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
18 PKGNAME=shadow
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
19 PKGVERSION=4.6
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
20 PKGREVISION=1
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
21 PKGLICENSE="BSD"
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
22 PKGSUMMARY="password and account management"
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
23 PKGDOWNLOAD="https://github.com/shadow-maint/shadow/releases/download/$PKGVERSION/$PKGNAME-$PKGVERSION.tar.xz"
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
24 PKGOPTIONS="ACL ATTR NLS PAM SELINUX"
822
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
25 PKGPROTECT="etc/login.defs
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
26 etc/pam.d/chage
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
27 etc/pam.d/chfn
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
28 etc/pam.d/chgpasswd
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
29 etc/pam.d/chpasswd
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
30 etc/pam.d/chsh
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
31 etc/pam.d/groupadd
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
32 etc/pam.d/groupdel
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
33 etc/pam.d/groupmems
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
34 etc/pam.d/groupmod
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
35 etc/pam.d/login
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
36 etc/pam.d/newusers
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
37 etc/pam.d/passwd
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
38 etc/pam.d/su
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
39 etc/pam.d/useradd
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
40 etc/pam.d/userdel
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
41 etc/pam.d/usermod"
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
42
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
43 : ${CHOST:=$(uname -m)-linux-musl}
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
44 : ${CBUILD:=$(uname -m)-linux-musl}
499
e26b9aeac296 security: convert packages to clang
David Demelier <markand@malikania.fr>
parents: 431
diff changeset
45 : ${CC:=clang}
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
46 : ${CFLAGS:=-O2}
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
47 : ${LDFLAGS:=}
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
48 : ${LIBS:=}
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
49 : ${ACL:=yes}
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
50 : ${ATTR:=yes}
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
51 : ${NLS:=yes}
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
52 : ${PAM:=yes}
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
53 : ${SELINUX:=no}
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
54
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
55 if [ "$ACL" = "yes" ]; then
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
56 PKGDEPENDS="core/acl $PKGDEPENDS"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
57 with_acl="--with-acl"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
58 else
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
59 with_acl="--without-acl"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
60 fi
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
61
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
62 if [ "$ATTR" = "yes" ]; then
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
63 PKGDEPENDS="core/acl $PKGDEPENDS"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
64 with_attr="--with-attr"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
65 else
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
66 with_attr="--without-attr"
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
67 fi
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
68
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
69 if [ "$NLS" = "yes" ]; then
431
515778c3a417 vanilla: core/gettext is only required for build
David Demelier <markand@malikania.fr>
parents: 388
diff changeset
70 PKGDEPENDS="core/gettext:build $PKGDEPENDS"
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
71 with_nls="--enable-nls"
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
72 else
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
73 with_nls="--disable-nls"
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
74 fi
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
75
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
76 if [ "$PAM" = "yes" ]; then
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
77 PKGDEPENDS="security/pam $PKGDEPENDS"
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
78 with_pam="--with-libpam"
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
79 else
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
80 with_pam="--without-libpam"
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
81 fi
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
82
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
83 if [ "$SELINUX" = "yes" ]; then
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
84 with_selinux="--with-selinux"
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
85 else
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
86 with_selinux="--without-selinux"
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
87 fi
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
88
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
89 build()
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
90 {
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
91 rm -rf $PKGNAME-$PKGVERSION
606
25cecc6dca48 vanilla: use POSIX shell and busybox tar
David Demelier <markand@malikania.fr>
parents: 549
diff changeset
92 tar xvf $PKGNAME-$PKGVERSION.tar.xz
25cecc6dca48 vanilla: use POSIX shell and busybox tar
David Demelier <markand@malikania.fr>
parents: 549
diff changeset
93 cd $PKGNAME-$PKGVERSION
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
94
639
9de04ddc6f6d vanilla: be more POSIX
David Demelier <markand@malikania.fr>
parents: 606
diff changeset
95 #
822
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
96 # Disable groups, it's provided by busybox/coreutils and documentation
639
9de04ddc6f6d vanilla: be more POSIX
David Demelier <markand@malikania.fr>
parents: 606
diff changeset
97 # by man-pages.
9de04ddc6f6d vanilla: be more POSIX
David Demelier <markand@malikania.fr>
parents: 606
diff changeset
98 #
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
99 sed -i 's/groups$(EXEEXT) //' src/Makefile.in
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
100 find man -name Makefile.in -exec sed -i 's/groups\.1 / /' {} \;
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
101 find man -name Makefile.in -exec sed -i 's/getspnam\.3 / /' {} \;
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
102 find man -name Makefile.in -exec sed -i 's/passwd\.5 / /' {} \;
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
103
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
104 CC="$CC" \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
105 CFLAGS="$CFLAGS" \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
106 LDFLAGS="$LDFLAGS" \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
107 LIBS="$LIBS" \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
108 ./configure \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
109 --build=$CBUILD \
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
110 --host=$CHOST \
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
111 --prefix= \
536
adaa1ae0fe9d security: use new FHS
David Demelier <markand@malikania.fr>
parents: 499
diff changeset
112 --bindir=/bin \
adaa1ae0fe9d security: use new FHS
David Demelier <markand@malikania.fr>
parents: 499
diff changeset
113 --sbindir=/bin \
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
114 --enable-shared \
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
115 $with_acl \
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
116 $with_attr \
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
117 $with_nls \
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
118 $with_pam \
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
119 $with_selinux
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
120 make ubindir=/bin usbindir=/bin
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
121 make DESTDIR=$DESTDIR ubindir=/bin usbindir=/bin install
100
00d0621f86b1 core/shadow: initial import, closes #1046
David Demelier <markand@malikania.fr>
parents:
diff changeset
122
549
bad483aace64 vanilla: use prefix= instead
David Demelier <markand@malikania.fr>
parents: 536
diff changeset
123 if [ "$PAM" = "yes" ]; then
822
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
124 for i in \
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
125 chage chfn chgpasswd chpasswd chsh groupadd groupdel \
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
126 groupmems groupmod login newusers passwd su useradd \
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
127 userdel usermod; do
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
128 install -Dm0600 ../$i $DESTDIR/etc/pam.d/$i
a73b34fe66ec security/shadow: add custom PAM files recommended per LFS
David Demelier <markand@malikania.fr>
parents: 745
diff changeset
129 done
387
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
130 fi
81a30cce56ef core/shadow: add PAM support
David Demelier <markand@malikania.fr>
parents: 147
diff changeset
131
606
25cecc6dca48 vanilla: use POSIX shell and busybox tar
David Demelier <markand@malikania.fr>
parents: 549
diff changeset
132 cd ..
136
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
133 rm -rf $PKGNAME-$PKGVERSION
e737b80da269 core: merge .sh and .info
David Demelier <markand@malikania.fr>
parents: 100
diff changeset
134 }