wok-next view cacerts/receipt @ rev 20434

Up cacerts (20180212), flag-icons, sdft.
author Aleksej Bobylev <al.bobylev@gmail.com>
date Wed Feb 21 17:35:15 2018 +0200 (2018-02-21)
parents 0b55786d7d72
children c4e53a39395a
line source
1 # SliTaz package receipt v2.
3 # This receipt will follow actual version on each recook
4 PACKAGE="cacerts"
5 VERSION="20180212"
6 CATEGORY="security"
7 SHORT_DESC="Certificate Authority Certificates"
8 MAINTAINER="al.bobylev@gmail.com"
9 LICENSE="MPL2"
10 WEB_SITE="http://www.linuxfromscratch.org/blfs/view/svn/postlfs/cacerts.html"
11 HOST_ARCH="any"
13 wget_url="https://hg.mozilla.org/releases/mozilla-release/raw-file/tip/security/nss/lib/ckfw/builtins/certdata.txt"
14 #wget_url="http://anduin.linuxfromscratch.org/BLFS/other/certdata.txt"
16 BUILD_DEPENDS="perl openssl locale-en-base"
18 compile_rules() {
19 # Determine date of certdata.txt
20 # FIXME: please point me to elegant way to determine this file timestamp
21 # in Mercurial.
22 string=$(wget -O- ${wget_url/raw-/} | fgrep 'date age')
23 # string example:
24 # <td class="date age">Thu, 28 Sep 2017 10:02:22 -0700</td>
25 date_d=$(echo "$string" | cut -d' ' -f5)
26 case $(echo "$string" | cut -d' ' -f6) in
27 Jan) date_m='01';;
28 Feb) date_m='02';;
29 Mar) date_m='03';;
30 Apr) date_m='04';;
31 May) date_m='05';;
32 Jun) date_m='06';;
33 Jul) date_m='07';;
34 Aug) date_m='08';;
35 Sep) date_m='09';;
36 Oct) date_m='10';;
37 Nov) date_m='11';;
38 Dec) date_m='12';;
39 esac
40 date_Y=$(echo "$string" | cut -d' ' -f7)
41 date_Ymd="$date_Y$date_m$date_d"
43 [ -f '/tmp/certdata.txt' ] && rm /tmp/certdata.txt
44 wget -P/tmp $wget_url
46 # Insert header (or process will fail)
47 sed -i "1i\
48 #CVS_ID @# \$ RCSfile: certdata.txt \$ \$Revision: $date_Ymd \$ \$Date: \$" \
49 /tmp/certdata.txt
51 # VERSION=$(sed -n '/\$Revision:/s|.*Revision: \([0-9]*\).*$|\1|p' /tmp/certdata.txt)
52 VERSION="$date_Ymd"
53 echo -e "\nActual version: $VERSION\n"
55 # Update receipt version
56 sed -i "s|^VERSION=.*|VERSION=\"$VERSION\"|" $WOK/cacerts/receipt
58 src="$WOK/cacerts/source/cacerts-$VERSION"
59 mkdir -p $src
60 mv /tmp/certdata.txt $src
61 cd $src
63 # Save certdata in $SRC
64 TARBALL="$PACKAGE-$VERSION.txt"
65 [ -e "$SRC/$TARBALL" ] || cp $src/certdata.txt $SRC/$TARBALL
67 # Process...
68 cp -a $stuff/* $src
69 ./make-ca.sh &&
70 ./remove-expired-certs.sh $src/certs
72 # "Installing"
73 mkdir -p $install/etc/ssl/certs
74 cp -a $src/certs/*.pem $install/etc/ssl/certs
75 cp -a $src/ca-bundle.crt $install/etc/ssl
76 ln -s ../ca-bundle.crt $install/etc/ssl/certs/ca-certificates.crt
77 }
79 genpkg_rules() {
80 copy @std
81 DEPENDS="openssl"
82 }
84 # Rehash certificates.
85 # Use simplified plain shell equivalent to the Perl `c_rehash`
86 # (see openssl package). Normal no output here.
87 post_install() {
88 cd "$1/etc/ssl/certs"
89 find . -type l -delete
90 for i in $(ls *.pem); do
91 j="$(openssl x509 -hash -noout -in $i)"
92 [ -n "$j" ] && ln -s $i $j.0
93 done
94 }
96 # Remove broken symlinks
97 post_remove() {
98 find "$1/etc/ssl/certs" -type l ! -exec test -e '{}' \; -delete
99 }