2022-02-20 05:27:41 +00:00
{ lib
, stdenv
, fetchurl
2023-05-24 13:37:59 +00:00
, fetchpatch
2022-02-20 05:27:41 +00:00
, gettext
, libgpg-error
, enableCapabilities ? false , libcap
, buildPackages
# for passthru.tests
, gnupg
, libotr
, rsyslog
} :
2020-04-24 23:36:52 +00:00
assert enableCapabilities -> stdenv . isLinux ;
stdenv . mkDerivation rec {
pname = " l i b g c r y p t " ;
2023-05-24 13:37:59 +00:00
version = " 1 . 1 0 . 2 " ;
2020-04-24 23:36:52 +00:00
src = fetchurl {
url = " m i r r o r : / / g n u p g / l i b g c r y p t / ${ pname } - ${ version } . t a r . b z 2 " ;
2023-05-24 13:37:59 +00:00
hash = " s h a 2 5 6 - O 5 w C o A S 2 j C V q 3 Z l w H e A L O D r M z P N x d + D W x Y K J Z k z O D A M = " ;
2020-04-24 23:36:52 +00:00
} ;
2023-05-24 13:37:59 +00:00
patches = lib . optionals ( ! stdenv . isLinux ) [ # not everywhere to avoid rebuild for now
( fetchpatch {
name = " g e t r a n d o m - c o n d i t i o n a l i z e . p a t c h " ;
url = " h t t p s : / / g i t . g n u p g . o r g / c g i - b i n / g i t w e b . c g i ? p = l i b g c r y p t . g i t ; a = c o m m i t d i f f _ p l a i n ; h = d 4 1 1 7 7 9 3 7 c e a 4 a a 1 e 9 0 4 2 e b c d 1 9 5 a 3 4 9 c 4 0 e 8 0 7 1 " ;
hash = " s h a 2 5 6 - C g Q j N t C 1 q L e 5 L i c I c 8 r E S c 6 Z 1 u 4 f k 7 E r M U V c G / 2 G 9 g M = " ;
} )
] ;
2020-04-24 23:36:52 +00:00
outputs = [ " o u t " " d e v " " i n f o " ] ;
outputBin = " d e v " ;
# The CPU Jitter random number generator must not be compiled with
# optimizations and the optimize -O0 pragma only works for gcc.
# The build enables -O2 by default for everything else.
2021-02-05 17:12:51 +00:00
hardeningDisable = lib . optional stdenv . cc . isClang " f o r t i f y " ;
2020-04-24 23:36:52 +00:00
depsBuildBuild = [ buildPackages . stdenv . cc ] ;
2021-10-08 15:17:17 +00:00
buildInputs = [ libgpg-error ]
2021-02-05 17:12:51 +00:00
++ lib . optional stdenv . isDarwin gettext
++ lib . optional enableCapabilities libcap ;
2020-04-24 23:36:52 +00:00
2021-03-09 03:18:52 +00:00
strictDeps = true ;
2021-10-08 15:17:17 +00:00
configureFlags = [ " - - w i t h - l i b g p g - e r r o r - p r e f i x = ${ libgpg-error . dev } " ]
2021-02-22 21:28:39 +00:00
++ lib . optional ( stdenv . hostPlatform . isMusl || ( stdenv . hostPlatform . isDarwin && stdenv . hostPlatform . isAarch64 ) ) " - - d i s a b l e - a s m " ; # for darwin see https://dev.gnupg.org/T5157
2020-04-24 23:36:52 +00:00
2020-07-18 16:06:22 +00:00
# Necessary to generate correct assembly when compiling for aarch32 on
# aarch64
configurePlatforms = [ " h o s t " " b u i l d " ] ;
2021-01-05 17:05:55 +00:00
postConfigure = ''
sed - i configure \
- e ' s/NOEXECSTACK_FLAGS = $ /NOEXECSTACK_FLAGS = " - W a , - - n o e x e c s t a c k " / '
'' ;
2020-04-24 23:36:52 +00:00
# Make sure libraries are correct for .pc and .la files
# Also make sure includes are fixed for callers who don't use libgpgcrypt-config
postFixup = ''
2021-10-08 15:17:17 +00:00
sed - i ' s , #include <gpg-error.h>,#include "${libgpg-error.dev}/include/gpg-error.h",g' "$dev/include/gcrypt.h"
2021-02-05 17:12:51 +00:00
'' + l i b . o p t i o n a l S t r i n g e n a b l e C a p a b i l i t i e s ''
2020-04-24 23:36:52 +00:00
sed - i ' s , \ ( - lcap \ ) , - L $ { libcap . lib } /lib \ 1 , ' $ out/lib/libgcrypt.la
'' ;
# TODO: figure out why this is even necessary and why the missing dylib only crashes
# random instead of every test
2021-02-05 17:12:51 +00:00
preCheck = lib . optionalString stdenv . isDarwin ''
2020-04-24 23:36:52 +00:00
mkdir - p $ out/lib
cp src/.libs/libgcrypt.20.dylib $ out/lib
'' ;
doCheck = true ;
2022-02-20 05:27:41 +00:00
passthru . tests = {
inherit gnupg libotr rsyslog ;
} ;
2021-02-05 17:12:51 +00:00
meta = with lib ; {
2020-04-24 23:36:52 +00:00
homepage = " h t t p s : / / w w w . g n u . o r g / s o f t w a r e / l i b g c r y p t / " ;
2023-05-24 13:37:59 +00:00
changelog = " h t t p s : / / g i t . g n u p g . o r g / c g i - b i n / g i t w e b . c g i ? p = ${ pname } . g i t ; a = b l o b ; f = N E W S ; h b = r e f s / t a g s / ${ pname } - ${ version } " ;
2020-04-24 23:36:52 +00:00
description = " G e n e r a l - p u r p o s e c r y p t o g r a p h i c l i b r a r y " ;
license = licenses . lgpl2Plus ;
platforms = platforms . all ;
maintainers = with maintainers ; [ vrthra ] ;
} ;
}