# Maintainer: Alexey Pavlov _realname=ca-certificates pkgbase=mingw-w64-${_realname} pkgname="${MINGW_PACKAGE_PREFIX}-${_realname}" pkgver=20240203 pkgrel=1 pkgdesc='Common CA certificates (mingw-w64)' arch=('any') mingw_arch=('mingw32' 'mingw64' 'ucrt64' 'clang64' 'clang32' 'clangarm64') url='https://www.mozilla.org/en-US/about/governance/policies/security-group/certs/' license=('MPL' 'GPL') install="ca-certificates-${MSYSTEM}.install" source=("https://ftp.debian.org/debian/pool/main/c/${_realname}/${_realname}_${pkgver}.tar.xz" 'certdata2pem.py' 'certdata2pem.patch' 'update-ca-trust' 'update-ca-trust.8') depends=("${MINGW_PACKAGE_PREFIX}-p11-kit") makedepends=("${MINGW_PACKAGE_PREFIX}-openssl" "${MINGW_PACKAGE_PREFIX}-python") sha256sums=('3286d3fc42c4d11b7086711a85f865b44065ce05cf1fb5376b2abed07622a9c6' '9508738b61cc89bfc1f42580b1091a650f0acbf5c1b49edc2aa4e0313276ea0d' '5736cc3a73ff9bceed43bafad85100a2fcfdfae1cf2cb7e201b5fa6f1421fc2e' 'ad9fd7ba5c304521128a0a15f3c3ccd79480d9414de08c93bca8bbb7a942f1b0' 'b052972dd118a3e25f785b6caa141599f0db6fc1d943e9ebcd6ca0e1f0421f60') prepare() { cd "${srcdir}" mv "${_realname}" "${srcdir}/${_realname}-${pkgver}" sed "s|/usr/bin/python|${MINGW_PREFIX}/bin/python|g" -i certdata2pem.py patch -p0 -i ${srcdir}/certdata2pem.patch cp certdata2pem.py ${srcdir}/${_realname}-${pkgver}/mozilla/certdata2pem.py cd ${srcdir}/${_realname}-${pkgver} cp ${srcdir}/update-ca-trust sbin/ cp ${srcdir}/update-ca-trust.8 sbin/ } build() { cd ${srcdir}/${_realname}-${pkgver}/mozilla mkdir -p legacy-{default,disable} PYTHONUTF8=1 PYTHONIOENCODING=utf-8 ${MINGW_PREFIX}/bin/python ./certdata2pem.py ( cat < ${srcdir}/${_realname}-${pkgver}/ca-bundle.trust.crt touch ${srcdir}/${_realname}-${pkgver}/ca-bundle.legacy.default.crt local NUM_LEGACY_DEFAULT=`find ./legacy-default -type f | wc -l` if [ $NUM_LEGACY_DEFAULT -ne 0 ]; then for f in ./legacy-default/*.crt; do echo "processing $f" tbits=`sed -n '/^# openssl-trust/{s/^.*=//;p;}' $f` alias=`sed -n '/^# alias=/{s/^.*=//;p;q;}' $f | sed "s/'//g" | sed 's/"//g'` targs="" if [ -n "$tbits" ]; then for t in $tbits; do targs="${targs} -addtrust $t" done fi if [ -n "$targs" ]; then echo "legacy default flags $targs for $f" >> info.trust openssl x509 -text -in "$f" -trustout $targs -setalias "$alias" >> ${srcdir}/${_realname}-${pkgver}/ca-bundle.legacy.default.crt fi done fi touch ${srcdir}/${_realname}-${pkgver}/ca-bundle.legacy.disable.crt NUM_LEGACY_DISABLE=`find ./legacy-disable -type f | wc -l` if [ $NUM_LEGACY_DISABLE -ne 0 ]; then for f in ./legacy-disable/*.crt; do echo "processing $f" tbits=`sed -n '/^# openssl-trust/{s/^.*=//;p;}' $f` alias=`sed -n '/^# alias=/{s/^.*=//;p;q;}' $f | sed "s/'//g" | sed 's/"//g'` targs="" if [ -n "$tbits" ]; then for t in $tbits; do targs="${targs} -addtrust $t" done fi if [ -n "$targs" ]; then echo "legacy disable flags $targs for $f" >> info.trust openssl x509 -text -in "$f" -trustout $targs -setalias "$alias" >> ${srcdir}/${_realname}-${pkgver}/ca-bundle.legacy.disable.crt fi done fi local P11FILES=`find . -name \*.tmp-p11-kit | wc -l` if [ $P11FILES -ne 0 ]; then for p in ./*.tmp-p11-kit; do cat "$p" >> ${srcdir}/${_realname}-${pkgver}/ca-bundle.trust.crt done fi } package() { cd ${srcdir}/${_realname}-${pkgver} mkdir -p ${pkgdir}${MINGW_PREFIX}/{bin,lib,share} mkdir -p ${pkgdir}${MINGW_PREFIX}/etc mkdir -p ${pkgdir}${MINGW_PREFIX}/share/man/man8 sed -e "s|@PREFIX@|${MINGW_PREFIX}|g" -i ${srcdir}/update-ca-trust cp -f ${srcdir}/update-ca-trust ${pkgdir}${MINGW_PREFIX}/bin/ cp -f ${srcdir}/update-ca-trust.8 ${pkgdir}${MINGW_PREFIX}/share/man/man8/ # for p11-kit mkdir -p ${pkgdir}${MINGW_PREFIX}/lib/p11-kit cp -f ${srcdir}/update-ca-trust ${pkgdir}${MINGW_PREFIX}/lib/p11-kit/p11-kit-extract-trust mkdir -p ${pkgdir}${MINGW_PREFIX}/share/pki/ca-trust-{source,legacy} install -p -m 644 ca-bundle.trust.crt ${pkgdir}${MINGW_PREFIX}/share/pki/ca-trust-source/ca-bundle.trust.crt install -p -m 644 ca-bundle.legacy.default.crt ${pkgdir}${MINGW_PREFIX}/share/pki/ca-trust-legacy/ca-bundle.legacy.default.crt install -p -m 644 ca-bundle.legacy.disable.crt ${pkgdir}${MINGW_PREFIX}/share/pki/ca-trust-legacy/ca-bundle.legacy.disable.crt # touch all files overwritten by update-ca-trust for easy cleanup mkdir -p ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/{extracted,source} mkdir -p ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/source/{anchors,blacklist} mkdir -p ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/{openssl,pem,java} touch ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/openssl/ca-bundle.trust.crt touch ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/pem/{tls,email,objsign}-ca-bundle.pem touch ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/java/cacerts # for OpenSSL and static ca-certificates consumers mkdir -p ${pkgdir}${MINGW_PREFIX}/etc/ssl/certs cp -f ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem ${pkgdir}${MINGW_PREFIX}/etc/ssl/certs/ca-bundle.crt cp -f ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/pem/tls-ca-bundle.pem ${pkgdir}${MINGW_PREFIX}/etc/ssl/cert.pem cp -f ${pkgdir}${MINGW_PREFIX}/etc/pki/ca-trust/extracted/openssl/ca-bundle.trust.crt ${pkgdir}${MINGW_PREFIX}/etc/ssl/certs/ca-bundle.trust.crt }