You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

96 lines
2.9 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# Copyright 1999-2022 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
DESCRIPTION="Установка корневого сертификата для работы сайтов с российскими сертификатами"
HOMEPAGE="https://www.gosuslugi.ru/crt"
SRC_URI="
https://gu-st.ru/content/lending/russian_trusted_root_ca_pem.crt -> ${PF}_root.crt
https://gu-st.ru/content/lending/russian_trusted_sub_ca_pem.crt -> ${PF}_sub.crt
"
LICENSE=""
SLOT="0"
KEYWORDS="~alpha amd64 arm arm64 hppa ~ia64 ~loong ~m68k ~mips ppc ppc64 ~riscv ~s390 sparc x86 ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris ~x86-winnt"
IUSE=""
# Зависимости
RDEPEND="
app-misc/ca-certificates
"
RESTRICT="bindist mirror strip"
S="${WORKDIR}"
CA=usr/local/share/ca-certificates
RU_TR_R=${PF}_root.crt
RU_TR_S=${PF}_sub.crt
RU_TR_R_NAME="Russian Trusted Root CA - The Ministry of Digital Development and Communications"
RU_TR_S_NAME="Russian Trusted Sub CA - The Ministry of Digital Development and Communications"
## Ассоциативный массив {имя сертификата:файл}
declare -A massiv
massiv[${RU_TR_R_NAME}]=${RU_TR_R}
massiv[${RU_TR_S_NAME}]=${RU_TR_S}
src_prepare() {
mkdir -p ${CA} || die
cp ${DISTDIR}/* ${CA} || die
default
}
src_install() {
mv * "${D}" || die
}
pkg_postinst() {
/usr/sbin/update-ca-certificates && \
elog Установка корневых сертификатов в /etc/ssl/certs/ выполнено
# Установка для браузеров
# Создаём базу nssdb для системы
mkdir -p /etc/pki/nssdb || die
nssdir=$(find /home/ -name "cert9.db")
nssdir+=$'\n/etc/pki/nssdb/cert9.db'
for certDB in ${nssdir}
do
certdir=$(dirname ${certDB});
for k in "${!massiv[@]}"; do
certutil -A -n "${k}" -t "CTu,Cu,Cu" -i /${CA}/${massiv[$k]} -d sql:${certdir} && \
elog Установка корневого сертификата \"${k}\" в ${certdir} выполнено
done
done
if [[ -n "$(find -L /etc/ssl/certs/ -type l)" ]] ; then
ewarn "Следующие неработающие символические ссылки удалены:"
ewarn "$(find -L /etc/ssl/certs/ -type l -printf '%p -> %l\n' -delete)"
fi
}
pkg_prerm() {
# Удаляем сертификаты из nss
nssdir=$(find /home/ -name "cert9.db")
nssdir+=$'\n/etc/pki/nssdb/cert9.db'
for certDB in ${nssdir}
do
certdir=$(dirname ${certDB});
for k in "${!massiv[@]}"; do
certutil -D -n "${k}" -d sql:${certdir} && \
elog Удаление корневого сертификата \"${k}\" из ${certdir} выполнено
done
done
}
pkg_postrm() {
/usr/sbin/update-ca-certificates --fresh && \
elog Очистка удалённых корневых сертификата из /etc/ssl/certs/ выполнено
}