commit:     fdae1196b3a9e3ee1f597449fc0098fce0229306
Author:     Georgy Yakovlev <gyakovlev <AT> gentoo <DOT> org>
AuthorDate: Thu May  9 20:51:30 2019 +0000
Commit:     Georgy Yakovlev <gyakovlev <AT> gentoo <DOT> org>
CommitDate: Thu May  9 23:04:52 2019 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fdae1196

sys-apps/baselayout-java: generate system-wide java keystore

keystore is created in etc/ssl/certs/java/cacerts

ebuild now installs ca-certificates/update.d snippet which
will regenerate certs on every ca-certificates run/update
allowing us to have all system certs in java keystore.

Bug: https://bugs.gentoo.org/682308
Package-Manager: Portage-2.3.66, Repoman-2.3.12
Signed-off-by: Georgy Yakovlev <gyakovlev <AT> gentoo.org>

 .../baselayout-java-0.1.0-r1.ebuild                | 49 ++++++++++++++++++++++
 1 file changed, 49 insertions(+)

diff --git a/sys-apps/baselayout-java/baselayout-java-0.1.0-r1.ebuild 
b/sys-apps/baselayout-java/baselayout-java-0.1.0-r1.ebuild
new file mode 100644
index 00000000000..51a9dee76bc
--- /dev/null
+++ b/sys-apps/baselayout-java/baselayout-java-0.1.0-r1.ebuild
@@ -0,0 +1,49 @@
+# Copyright 1999-2019 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit xdg-utils
+
+DESCRIPTION="Baselayout for Java"
+HOMEPAGE="https://wiki.gentoo.org/wiki/Project:Java";
+SRC_URI="https://dev.gentoo.org/~sera/distfiles/${P}.tar.gz";
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~ia64 ~ppc ~ppc64 ~x86 ~amd64-fbsd ~x86-fbsd 
~amd64-linux ~ppc-macos ~x64-macos ~x86-macos ~sparc-solaris ~sparc64-solaris 
~x64-solaris ~x86-solaris"
+IUSE=""
+
+BDEPEND="
+       app-crypt/p11-kit[trust]
+       app-misc/ca-certificates
+"
+
+RDEPEND="${BDEPEND}
+       !<dev-java/java-config-2.2"
+
+src_install() {
+       default
+       keepdir /etc/ssl/certs/java/
+       exeinto /etc/ca-certificates/update.d
+       newexe - java-cacerts <<-_EOF_
+               #!/bin/sh
+               exec trust extract --overwrite --format=java-cacerts 
--filter=ca-anchors --purpose server-auth "${EROOT}"/etc/ssl/certs/java/cacerts
+       _EOF_
+}
+
+pkg_postrm() {
+       xdg_desktop_database_update
+       xdg_icon_cache_update
+}
+
+pkg_postinst() {
+       xdg_desktop_database_update
+       xdg_icon_cache_update
+       # on first installation generate java cacert file
+       # so jdk ebuilds can create symlink to in into security directory
+       if [[ ! -f "${EROOT}"/etc/ssl/certs/java/cacerts ]]; then
+               einfo "Generating java cacerts file from system ca-certificates"
+               "${EROOT}"/etc/ca-certificates/update.d/java-cacerts || die
+       fi
+}

Reply via email to