From 704343381e435b306648a2d85a77a58e34478643 Mon Sep 17 00:00:00 2001 From: V3n3RiX Date: Sun, 29 Oct 2023 09:35:43 +0000 Subject: gentoo auto-resync : 29:10:2023 - 09:35:42 --- app-crypt/veracrypt/veracrypt-1.26.7.ebuild | 111 ++++++++++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 app-crypt/veracrypt/veracrypt-1.26.7.ebuild (limited to 'app-crypt/veracrypt/veracrypt-1.26.7.ebuild') diff --git a/app-crypt/veracrypt/veracrypt-1.26.7.ebuild b/app-crypt/veracrypt/veracrypt-1.26.7.ebuild new file mode 100644 index 000000000000..e42be259f96c --- /dev/null +++ b/app-crypt/veracrypt/veracrypt-1.26.7.ebuild @@ -0,0 +1,111 @@ +# Copyright 1999-2023 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +WX_GTK_VER="3.2-gtk3" +inherit desktop flag-o-matic linux-info pax-utils toolchain-funcs wxwidgets + +DESCRIPTION="Disk encryption with strong security based on TrueCrypt" +HOMEPAGE="https://www.veracrypt.fr/en/Home.html" +SRC_URI="https://github.com/${PN}/VeraCrypt/archive/VeraCrypt_${PV}.tar.gz -> ${P}.tar.gz" +S="${WORKDIR}/VeraCrypt-VeraCrypt_${PV}/src" + +# The modules not linked against in Linux include (but not limited to): +# libzip, chacha-xmm, chacha256, chachaRng, rdrand, t1ha2 +# Tested by actually removing the source files and performing a build +# For this reason, we don't have to worry about their licenses +LICENSE="Apache-2.0 BSD RSA truecrypt-3.0" +SLOT="0" +KEYWORDS="~amd64" +IUSE="+asm cpu_flags_x86_sse2 cpu_flags_x86_sse4_1 cpu_flags_x86_ssse3 doc X" +RESTRICT="bindist mirror" + +RDEPEND=" + app-admin/sudo + sys-apps/pcsc-lite + sys-fs/fuse:0 + sys-fs/lvm2 + x11-libs/wxGTK:${WX_GTK_VER}[X?]" +DEPEND="${RDEPEND}" +BDEPEND=" + asm? ( dev-lang/yasm ) + virtual/pkgconfig" + +CONFIG_CHECK="~BLK_DEV_DM ~CRYPTO ~CRYPTO_XTS ~DM_CRYPT ~FUSE_FS" + +src_configure() { + setup-wxwidgets + + # https://bugs.gentoo.org/786741 + # std::byte clashes with src/Common/Tcdefs.h typedef + append-cxxflags -std=c++14 +} + +src_compile() { + local myemakeargs=( + NOSTRIP=1 + NOTEST=1 + VERBOSE=1 + CC="$(tc-getCC)" + CXX="$(tc-getCXX)" + AR="$(tc-getAR)" + RANLIB="$(tc-getRANLIB)" + TC_EXTRA_CFLAGS="${CFLAGS}" + TC_EXTRA_CXXFLAGS="${CXXFLAGS}" + TC_EXTRA_LFLAGS="${LDFLAGS}" + WX_CONFIG="${WX_CONFIG}" + $(usex X "" "NOGUI=1") + $(usex asm "" "NOASM=1") + $(usex cpu_flags_x86_sse2 "" "NOSSE2=1") + $(usex cpu_flags_x86_sse4_1 "SSE41=1" "") + $(usex cpu_flags_x86_ssse3 "SSSE3=1" "") + ) + + emake "${myemakeargs[@]}" +} + +src_test() { + ./Main/veracrypt --text --test || die "tests failed" +} + +src_install() { + local DOCS=( Readme.txt ) + + dobin Main/veracrypt + if use doc; then + DOCS+=( "${S}"/../doc/EFI-DCS ) + docompress -x /usr/share/doc/${PF}/EFI-DCS + HTML_DOCS=( "${S}"/../doc/html/. ) + fi + einstalldocs + + newinitd "${FILESDIR}"/veracrypt.init veracrypt + + if use X; then + local s + for s in 16 48 128 256; do + newicon -s ${s} Resources/Icons/VeraCrypt-${s}x${s}.xpm veracrypt.xpm + done + make_desktop_entry veracrypt "VeraCrypt" veracrypt "Utility;Security" + fi + + pax-mark -m "${ED}"/usr/bin/veracrypt +} + +pkg_postinst() { + local version + + ewarn "VeraCrypt has a very restrictive license. Please be explicitly aware" + ewarn "of the limitations on redistribution of binaries or modified source." + + # Remove this when we remove veracrypt-1.25.9.ebuild from the tree. + for version in ${REPLACING_VERSIONS}; do + if ver_test "${version}" -lt "1.26.7"; then + ewarn "Starting with 1.26.7, TrueCrypt volumes are no longer supported." + ewarn "Please explore alternatives such as dm-crypt to mount truecrypt volumes." + ewarn "Moreover, support for RIPEMD160 and GOST89 is dropped." + ewarn "Volumes using these algoritms will no longer mount." + fi + done +} -- cgit v1.2.3