153 lines
5.9 KiB
Scheme
153 lines
5.9 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2012, 2013, 2014 Ludovic Courtès <ludo@gnu.org>
|
|
;;; Copyright © 2014, 2015 Mark H Weaver <mhw@netris.org>
|
|
;;; Copyright © 2014 Ian Denhardt <ian@zenhack.net>
|
|
;;; Copyright © 2015 Andreas Enge <andreas@enge.fr>
|
|
;;;
|
|
;;; This file is part of GNU Guix.
|
|
;;;
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
;;; under the terms of the GNU General Public License as published by
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
;;; your option) any later version.
|
|
;;;
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;;; GNU General Public License for more details.
|
|
;;;
|
|
;;; You should have received a copy of the GNU General Public License
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
(define-module (gnu packages gnutls)
|
|
#:use-module (guix licenses)
|
|
#:use-module (guix packages)
|
|
#:use-module (guix download)
|
|
#:use-module (guix utils)
|
|
#:use-module (guix build-system gnu)
|
|
#:use-module ((gnu packages compression) #:prefix guix:)
|
|
#:use-module (gnu packages)
|
|
#:use-module (gnu packages guile)
|
|
#:use-module (gnu packages libffi)
|
|
#:use-module (gnu packages nettle)
|
|
#:use-module (gnu packages perl)
|
|
#:use-module (gnu packages pkg-config)
|
|
#:use-module (gnu packages texinfo)
|
|
#:use-module (gnu packages which))
|
|
|
|
(define-public libtasn1
|
|
(package
|
|
(name "libtasn1")
|
|
(version "4.2")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "mirror://gnu/libtasn1/libtasn1-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"1fydwh5hlnmprdzmzn4kiqb939br59qv1001k7ah5b626v5l2fv9"))))
|
|
(build-system gnu-build-system)
|
|
(native-inputs `(("perl" ,perl)
|
|
|
|
;; XXX: For some reason, libtasn1.info wants to be
|
|
;; rebuilt, so we must provide 'makeinfo'.
|
|
("texinfo" ,texinfo)))
|
|
(home-page "http://www.gnu.org/software/libtasn1/")
|
|
(synopsis "ASN.1 library")
|
|
(description
|
|
"GNU libtasn1 is a library implementing the ASN.1 notation. It is used
|
|
for transmitting machine-neutral encodings of data objects in computer
|
|
networking, allowing for formal validation of data according to some
|
|
specifications.")
|
|
(license lgpl2.0+)))
|
|
|
|
(define-public p11-kit
|
|
(package
|
|
(name "p11-kit")
|
|
(version "0.22.1")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "http://p11-glue.freedesktop.org/releases/p11-kit-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"0p4sadq2c70jdm7b5a5xw8mk2mqy36krpxr3ihnf783arygk6fpg"))
|
|
(modules '((guix build utils))) ; for substitute*
|
|
(snippet
|
|
'(begin
|
|
;; Drop one test that fails, also when trying to compile manually.
|
|
;; Reported upstream at
|
|
;; https://bugs.freedesktop.org/show_bug.cgi?id=89027
|
|
(substitute* "Makefile.in"
|
|
(("test-module\\$\\(EXEEXT\\) ") ""))))))
|
|
(build-system gnu-build-system)
|
|
(native-inputs
|
|
`(("pkg-config" ,pkg-config)))
|
|
(inputs
|
|
`(("libffi" ,libffi)
|
|
("libtasn1" ,libtasn1)))
|
|
(arguments
|
|
`(#:configure-flags '("--without-trust-paths")))
|
|
(home-page "http://p11-glue.freedesktop.org/p11-kit.html")
|
|
(synopsis "PKCS#11 library")
|
|
(description
|
|
"p11-kit provides a way to load and enumerate PKCS#11 modules. It
|
|
provides a standard configuration setup for installing PKCS#11 modules
|
|
in such a way that they are discoverable. It also solves problems with
|
|
coordinating the use of PKCS#11 by different components or libraries
|
|
living in the same process.")
|
|
(license bsd-3)))
|
|
|
|
(define-public gnutls
|
|
(package
|
|
(name "gnutls")
|
|
(version "3.3.12")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri
|
|
;; Note: Releases are no longer on ftp.gnu.org since the
|
|
;; schism (after version 3.1.5).
|
|
(string-append "mirror://gnupg/gnutls/v"
|
|
(version-major+minor version)
|
|
"/gnutls-" version ".tar.xz"))
|
|
(sha256
|
|
(base32
|
|
"16r96bzsfqx1rlqrkggmhhx6zbxj1fmc3mwpp0ik73ylqn93xav7"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
'(#:configure-flags
|
|
(list (string-append "--with-guile-site-dir="
|
|
(assoc-ref %outputs "out")
|
|
"/share/guile/site/2.0")
|
|
;; GnuTLS doesn't consult any environment variables to specify
|
|
;; the location of the system-wide trust store. Instead it has a
|
|
;; configure-time option. Unless specified, its configure script
|
|
;; attempts to auto-detect the location by looking for common
|
|
;; places in the filesystem, none of which are present in our
|
|
;; chroot build environment. If not found, then no default trust
|
|
;; store is used, so each program has to provide its own
|
|
;; fallback, and users have to configure each program
|
|
;; independently. This seems suboptimal.
|
|
"--with-default-trust-store-dir=/etc/ssl/certs")))
|
|
(native-inputs
|
|
`(("pkg-config" ,pkg-config)
|
|
("which" ,which)))
|
|
(inputs
|
|
`(("guile" ,guile-2.0)
|
|
("perl" ,perl)))
|
|
(propagated-inputs
|
|
;; These are all in the 'Requires.private' field of gnutls.pc.
|
|
`(("libtasn1" ,libtasn1)
|
|
("nettle" ,nettle)
|
|
("zlib" ,guix:zlib)))
|
|
(home-page "http://www.gnu.org/software/gnutls/")
|
|
(synopsis "Transport layer security library")
|
|
(description
|
|
"GnuTLS is a secure communications library implementing the SSL, TLS
|
|
and DTLS protocols. It is provided in the form of a C library to support the
|
|
protocols, as well as to parse and write X.5009, PKCS 12, OpenPGP and other
|
|
required structures.")
|
|
(license lgpl2.1+)))
|