2023-06-03 22:49:55 +01:00
|
|
|
(use-modules (gnu packages)
|
2023-06-06 09:37:21 +01:00
|
|
|
((gnu packages bash) #:select (bash-minimal))
|
2021-03-03 19:00:12 +02:00
|
|
|
(gnu packages bison)
|
2023-06-06 09:37:21 +01:00
|
|
|
((gnu packages certs) #:select (nss-certs))
|
|
|
|
((gnu packages cmake) #:select (cmake-minimal))
|
2019-07-12 11:42:36 -04:00
|
|
|
(gnu packages commencement)
|
|
|
|
(gnu packages compression)
|
|
|
|
(gnu packages cross-base)
|
|
|
|
(gnu packages file)
|
|
|
|
(gnu packages gawk)
|
|
|
|
(gnu packages gcc)
|
2023-06-06 09:37:21 +01:00
|
|
|
((gnu packages installers) #:select (nsis-x86_64))
|
2024-11-13 14:54:21 +00:00
|
|
|
((gnu packages linux) #:select (linux-libre-headers-6.1))
|
2020-11-17 13:09:31 -05:00
|
|
|
(gnu packages llvm)
|
2020-01-16 14:40:48 -05:00
|
|
|
(gnu packages mingw)
|
2019-07-12 11:42:36 -04:00
|
|
|
(gnu packages pkg-config)
|
2023-06-06 09:37:21 +01:00
|
|
|
((gnu packages python) #:select (python-minimal))
|
2023-06-23 17:02:49 +01:00
|
|
|
((gnu packages python-build) #:select (python-tomli))
|
2023-06-06 09:37:21 +01:00
|
|
|
((gnu packages python-crypto) #:select (python-asn1crypto))
|
|
|
|
((gnu packages tls) #:select (openssl))
|
|
|
|
((gnu packages version-control) #:select (git-minimal))
|
2022-08-03 10:54:15 +01:00
|
|
|
(guix build-system cmake)
|
2024-11-19 10:36:23 +00:00
|
|
|
(guix build-system gnu)
|
2021-04-09 10:12:14 +08:00
|
|
|
(guix build-system python)
|
2019-07-12 11:42:36 -04:00
|
|
|
(guix build-system trivial)
|
2024-07-23 09:42:04 +01:00
|
|
|
(guix download)
|
2019-07-12 11:42:36 -04:00
|
|
|
(guix gexp)
|
2021-04-09 10:12:14 +08:00
|
|
|
(guix git-download)
|
2020-11-17 13:09:31 -05:00
|
|
|
((guix licenses) #:prefix license:)
|
2019-07-12 11:42:36 -04:00
|
|
|
(guix packages)
|
2024-11-19 10:36:23 +00:00
|
|
|
((guix utils) #:select (cc-for-target substitute-keyword-arguments)))
|
2019-07-12 00:28:29 -04:00
|
|
|
|
2021-01-14 18:10:16 -05:00
|
|
|
(define-syntax-rule (search-our-patches file-name ...)
|
|
|
|
"Return the list of absolute file names corresponding to each
|
|
|
|
FILE-NAME found in ./patches relative to the current file."
|
|
|
|
(parameterize
|
|
|
|
((%patch-path (list (string-append (dirname (current-filename)) "/patches"))))
|
|
|
|
(list (search-patch file-name) ...)))
|
|
|
|
|
2023-07-24 14:38:26 +01:00
|
|
|
(define building-on (string-append "--build=" (list-ref (string-split (%current-system) #\-) 0) "-guix-linux-gnu"))
|
2022-08-17 12:18:57 +01:00
|
|
|
|
2019-07-12 00:28:29 -04:00
|
|
|
(define (make-cross-toolchain target
|
|
|
|
base-gcc-for-libc
|
|
|
|
base-kernel-headers
|
|
|
|
base-libc
|
|
|
|
base-gcc)
|
|
|
|
"Create a cross-compilation toolchain package for TARGET"
|
|
|
|
(let* ((xbinutils (cross-binutils target))
|
|
|
|
;; 1. Build a cross-compiling gcc without targeting any libc, derived
|
|
|
|
;; from BASE-GCC-FOR-LIBC
|
2023-08-18 15:31:20 +01:00
|
|
|
(xgcc-sans-libc (cross-gcc target
|
|
|
|
#:xgcc base-gcc-for-libc
|
|
|
|
#:xbinutils xbinutils))
|
2019-07-12 00:28:29 -04:00
|
|
|
;; 2. Build cross-compiled kernel headers with XGCC-SANS-LIBC, derived
|
|
|
|
;; from BASE-KERNEL-HEADERS
|
|
|
|
(xkernel (cross-kernel-headers target
|
2023-08-22 15:57:23 +01:00
|
|
|
#:linux-headers base-kernel-headers
|
|
|
|
#:xgcc xgcc-sans-libc
|
|
|
|
#:xbinutils xbinutils))
|
2019-07-12 00:28:29 -04:00
|
|
|
;; 3. Build a cross-compiled libc with XGCC-SANS-LIBC and XKERNEL,
|
|
|
|
;; derived from BASE-LIBC
|
2023-08-18 15:08:11 +01:00
|
|
|
(xlibc (cross-libc target
|
2023-08-22 15:57:23 +01:00
|
|
|
#:libc base-libc
|
|
|
|
#:xgcc xgcc-sans-libc
|
|
|
|
#:xbinutils xbinutils
|
|
|
|
#:xheaders xkernel))
|
2019-07-12 00:28:29 -04:00
|
|
|
;; 4. Build a cross-compiling gcc targeting XLIBC, derived from
|
|
|
|
;; BASE-GCC
|
2023-08-18 15:31:20 +01:00
|
|
|
(xgcc (cross-gcc target
|
|
|
|
#:xgcc base-gcc
|
|
|
|
#:xbinutils xbinutils
|
|
|
|
#:libc xlibc)))
|
2019-07-12 00:28:29 -04:00
|
|
|
;; Define a meta-package that propagates the resulting XBINUTILS, XLIBC, and
|
|
|
|
;; XGCC
|
|
|
|
(package
|
|
|
|
(name (string-append target "-toolchain"))
|
|
|
|
(version (package-version xgcc))
|
|
|
|
(source #f)
|
|
|
|
(build-system trivial-build-system)
|
|
|
|
(arguments '(#:builder (begin (mkdir %output) #t)))
|
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list xbinutils
|
|
|
|
xlibc
|
|
|
|
xgcc
|
|
|
|
`(,xlibc "static")
|
|
|
|
`(,xgcc "lib")))
|
2019-07-12 00:28:29 -04:00
|
|
|
(synopsis (string-append "Complete GCC tool chain for " target))
|
|
|
|
(description (string-append "This package provides a complete GCC tool
|
|
|
|
chain for " target " development."))
|
|
|
|
(home-page (package-home-page xgcc))
|
|
|
|
(license (package-license xgcc)))))
|
|
|
|
|
2024-08-20 13:29:09 +01:00
|
|
|
(define base-gcc gcc-12) ;; 12.4.0
|
2024-07-23 09:42:04 +01:00
|
|
|
|
2023-10-15 17:07:54 +02:00
|
|
|
(define base-linux-kernel-headers linux-libre-headers-6.1)
|
2021-05-19 13:47:58 -04:00
|
|
|
|
2019-07-12 00:28:29 -04:00
|
|
|
(define* (make-bitcoin-cross-toolchain target
|
2021-02-04 18:58:26 -05:00
|
|
|
#:key
|
2023-08-18 15:31:20 +01:00
|
|
|
(base-gcc-for-libc linux-base-gcc)
|
2022-04-27 08:32:09 +01:00
|
|
|
(base-kernel-headers base-linux-kernel-headers)
|
2024-04-27 15:36:28 +08:00
|
|
|
(base-libc glibc-2.31)
|
2023-08-18 15:31:20 +01:00
|
|
|
(base-gcc linux-base-gcc))
|
2019-11-04 04:22:53 -05:00
|
|
|
"Convenience wrapper around MAKE-CROSS-TOOLCHAIN with default values
|
2019-07-12 00:28:29 -04:00
|
|
|
desirable for building Bitcoin Core release binaries."
|
|
|
|
(make-cross-toolchain target
|
2021-02-04 18:58:26 -05:00
|
|
|
base-gcc-for-libc
|
|
|
|
base-kernel-headers
|
|
|
|
base-libc
|
|
|
|
base-gcc))
|
2019-07-12 00:28:29 -04:00
|
|
|
|
2023-07-24 14:38:26 +01:00
|
|
|
(define (gcc-mingw-patches gcc)
|
|
|
|
(package-with-extra-patches gcc
|
2024-04-10 12:21:22 +02:00
|
|
|
(search-our-patches "gcc-remap-guix-store.patch")))
|
|
|
|
|
|
|
|
(define (binutils-mingw-patches binutils)
|
|
|
|
(package-with-extra-patches binutils
|
|
|
|
(search-our-patches "binutils-unaligned-default.patch")))
|
2022-04-01 10:43:32 +01:00
|
|
|
|
2024-07-19 16:11:02 +01:00
|
|
|
(define (winpthreads-patches mingw-w64-x86_64-winpthreads)
|
|
|
|
(package-with-extra-patches mingw-w64-x86_64-winpthreads
|
|
|
|
(search-our-patches "winpthreads-remap-guix-store.patch")))
|
|
|
|
|
2020-01-16 14:40:48 -05:00
|
|
|
(define (make-mingw-pthreads-cross-toolchain target)
|
|
|
|
"Create a cross-compilation toolchain package for TARGET"
|
2024-04-10 12:21:22 +02:00
|
|
|
(let* ((xbinutils (binutils-mingw-patches (cross-binutils target)))
|
2024-07-22 17:25:22 +01:00
|
|
|
(machine (substring target 0 (string-index target #\-)))
|
2024-07-19 16:11:02 +01:00
|
|
|
(pthreads-xlibc (winpthreads-patches (make-mingw-w64 machine
|
2024-07-22 17:25:22 +01:00
|
|
|
#:xgcc (cross-gcc target #:xgcc (gcc-mingw-patches base-gcc))
|
2024-07-19 16:11:02 +01:00
|
|
|
#:with-winpthreads? #t)))
|
2023-07-24 14:38:26 +01:00
|
|
|
(pthreads-xgcc (cross-gcc target
|
|
|
|
#:xgcc (gcc-mingw-patches mingw-w64-base-gcc)
|
2020-01-16 14:40:48 -05:00
|
|
|
#:xbinutils xbinutils
|
2023-07-24 14:38:26 +01:00
|
|
|
#:libc pthreads-xlibc)))
|
2020-01-16 14:40:48 -05:00
|
|
|
;; Define a meta-package that propagates the resulting XBINUTILS, XLIBC, and
|
|
|
|
;; XGCC
|
|
|
|
(package
|
|
|
|
(name (string-append target "-posix-toolchain"))
|
|
|
|
(version (package-version pthreads-xgcc))
|
|
|
|
(source #f)
|
|
|
|
(build-system trivial-build-system)
|
|
|
|
(arguments '(#:builder (begin (mkdir %output) #t)))
|
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list xbinutils
|
|
|
|
pthreads-xlibc
|
|
|
|
pthreads-xgcc
|
|
|
|
`(,pthreads-xgcc "lib")))
|
2020-01-16 14:40:48 -05:00
|
|
|
(synopsis (string-append "Complete GCC tool chain for " target))
|
|
|
|
(description (string-append "This package provides a complete GCC tool
|
|
|
|
chain for " target " development."))
|
|
|
|
(home-page (package-home-page pthreads-xgcc))
|
|
|
|
(license (package-license pthreads-xgcc)))))
|
|
|
|
|
2023-06-23 17:02:49 +01:00
|
|
|
;; While LIEF is packaged in Guix, we maintain our own package,
|
|
|
|
;; to simplify building, and more easily apply updates.
|
|
|
|
;; Moreover, the Guix's package uses cmake, which caused build
|
|
|
|
;; failure; see https://github.com/bitcoin/bitcoin/pull/27296.
|
2023-03-21 14:26:01 +00:00
|
|
|
(define-public python-lief
|
2021-04-09 10:12:14 +08:00
|
|
|
(package
|
2023-03-21 14:26:01 +00:00
|
|
|
(name "python-lief")
|
2023-06-23 17:02:49 +01:00
|
|
|
(version "0.13.2")
|
2023-03-21 14:26:01 +00:00
|
|
|
(source (origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/lief-project/LIEF")
|
|
|
|
(commit version)))
|
|
|
|
(file-name (git-file-name name version))
|
2023-06-23 17:02:49 +01:00
|
|
|
(modules '((guix build utils)))
|
|
|
|
(snippet
|
|
|
|
'(begin
|
|
|
|
;; Configure build for Python bindings.
|
|
|
|
(substitute* "api/python/config-default.toml"
|
|
|
|
(("(ninja = )true" all m)
|
|
|
|
(string-append m "false"))
|
|
|
|
(("(parallel-jobs = )0" all m)
|
|
|
|
(string-append m (number->string (parallel-job-count)))))))
|
2023-03-21 14:26:01 +00:00
|
|
|
(sha256
|
|
|
|
(base32
|
2023-06-23 17:02:49 +01:00
|
|
|
"0y48x358ppig5xp97ahcphfipx7cg9chldj2q5zrmn610fmi4zll"))))
|
2023-03-21 14:26:01 +00:00
|
|
|
(build-system python-build-system)
|
2023-06-23 17:02:49 +01:00
|
|
|
(native-inputs (list cmake-minimal python-tomli))
|
2023-03-21 14:26:01 +00:00
|
|
|
(arguments
|
|
|
|
(list
|
|
|
|
#:tests? #f ;needs network
|
|
|
|
#:phases #~(modify-phases %standard-phases
|
2023-06-23 17:02:49 +01:00
|
|
|
(add-before 'build 'change-directory
|
|
|
|
(lambda _
|
|
|
|
(chdir "api/python")))
|
2023-03-21 14:26:01 +00:00
|
|
|
(replace 'build
|
|
|
|
(lambda _
|
2023-06-23 17:02:49 +01:00
|
|
|
(invoke "python" "setup.py" "build"))))))
|
2023-03-21 14:26:01 +00:00
|
|
|
(home-page "https://github.com/lief-project/LIEF")
|
|
|
|
(synopsis "Library to instrument executable formats")
|
|
|
|
(description
|
|
|
|
"@code{python-lief} is a cross platform library which can parse, modify
|
|
|
|
and abstract ELF, PE and MachO formats.")
|
|
|
|
(license license:asl2.0)))
|
2021-04-09 10:12:14 +08:00
|
|
|
|
2021-02-04 19:09:02 -05:00
|
|
|
(define osslsigncode
|
|
|
|
(package
|
|
|
|
(name "osslsigncode")
|
2022-08-03 10:54:15 +01:00
|
|
|
(version "2.5")
|
2021-02-04 19:09:02 -05:00
|
|
|
(source (origin
|
2023-06-03 08:11:56 +01:00
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/mtrojnar/osslsigncode")
|
|
|
|
(commit version)))
|
2021-02-04 19:09:02 -05:00
|
|
|
(sha256
|
|
|
|
(base32
|
2023-06-03 08:11:56 +01:00
|
|
|
"1j47vwq4caxfv0xw68kw5yh00qcpbd56d7rq6c483ma3y7s96yyz"))))
|
2022-08-03 10:54:15 +01:00
|
|
|
(build-system cmake-build-system)
|
2023-06-22 10:20:07 +01:00
|
|
|
(inputs (list openssl))
|
2021-02-04 19:09:02 -05:00
|
|
|
(home-page "https://github.com/mtrojnar/osslsigncode")
|
|
|
|
(synopsis "Authenticode signing and timestamping tool")
|
|
|
|
(description "osslsigncode is a small tool that implements part of the
|
|
|
|
functionality of the Microsoft tool signtool.exe - more exactly the Authenticode
|
|
|
|
signing and timestamping. But osslsigncode is based on OpenSSL and cURL, and
|
|
|
|
thus should be able to compile on most platforms where these exist.")
|
|
|
|
(license license:gpl3+))) ; license is with openssl exception
|
|
|
|
|
|
|
|
(define-public python-elfesteem
|
2022-06-30 11:20:29 +01:00
|
|
|
(let ((commit "2eb1e5384ff7a220fd1afacd4a0170acff54fe56"))
|
2021-02-04 19:09:02 -05:00
|
|
|
(package
|
|
|
|
(name "python-elfesteem")
|
|
|
|
(version (git-version "0.1" "1" commit))
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/LRGH/elfesteem")
|
|
|
|
(commit commit)))
|
|
|
|
(file-name (git-file-name name commit))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2022-06-30 11:20:29 +01:00
|
|
|
"07x6p8clh11z8s1n2kdxrqwqm2almgc5qpkcr9ckb6y5ivjdr5r6"))))
|
2021-02-04 19:09:02 -05:00
|
|
|
(build-system python-build-system)
|
|
|
|
;; There are no tests, but attempting to run python setup.py test leads to
|
|
|
|
;; PYTHONPATH problems, just disable the test
|
|
|
|
(arguments '(#:tests? #f))
|
|
|
|
(home-page "https://github.com/LRGH/elfesteem")
|
|
|
|
(synopsis "ELF/PE/Mach-O parsing library")
|
|
|
|
(description "elfesteem parses ELF, PE and Mach-O files.")
|
|
|
|
(license license:lgpl2.1))))
|
|
|
|
|
|
|
|
(define-public python-oscrypto
|
|
|
|
(package
|
|
|
|
(name "python-oscrypto")
|
guix: update python-oscrypto to 1.3.0
This is required for bumping the time-machine, for compatibility with
OpenSSL:
oscrypto: openssl backend, 1.2.1, /tmp/guix-build-python-oscrypto-1.2.1.drv-0/source/oscrypto
Traceback (most recent call last):
File "/tmp/guix-build-python-oscrypto-1.2.1.drv-0/source/oscrypto/_openssl/_libcrypto_ctypes.py", line 304, in <module>
libcrypto.EVP_PKEY_size.argtypes = [
File "/gnu/store/9dkl9fnidcdpw19ncw5pk0p7dljx7ijb-python-3.10.7/lib/python3.10/ctypes/__init__.py", line 387, in __getattr__
func = self.__getitem__(name)
File "/gnu/store/9dkl9fnidcdpw19ncw5pk0p7dljx7ijb-python-3.10.7/lib/python3.10/ctypes/__init__.py", line 392, in __getitem__
func = self._FuncPtr((name_or_ordinal, self))
AttributeError: /gnu/store/2hr7w64zhr6jjznidyc2xi40d5ynhj9c-openssl-3.0.8/lib/libcrypto.so.3: undefined symbol: EVP_PKEY_size. Did you mean: 'EVP_PKEY_free'?
2023-08-23 12:46:10 +01:00
|
|
|
(version "1.3.0")
|
2021-02-04 19:09:02 -05:00
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/wbond/oscrypto")
|
|
|
|
(commit version)))
|
|
|
|
(file-name (git-file-name name version))
|
|
|
|
(sha256
|
|
|
|
(base32
|
guix: update python-oscrypto to 1.3.0
This is required for bumping the time-machine, for compatibility with
OpenSSL:
oscrypto: openssl backend, 1.2.1, /tmp/guix-build-python-oscrypto-1.2.1.drv-0/source/oscrypto
Traceback (most recent call last):
File "/tmp/guix-build-python-oscrypto-1.2.1.drv-0/source/oscrypto/_openssl/_libcrypto_ctypes.py", line 304, in <module>
libcrypto.EVP_PKEY_size.argtypes = [
File "/gnu/store/9dkl9fnidcdpw19ncw5pk0p7dljx7ijb-python-3.10.7/lib/python3.10/ctypes/__init__.py", line 387, in __getattr__
func = self.__getitem__(name)
File "/gnu/store/9dkl9fnidcdpw19ncw5pk0p7dljx7ijb-python-3.10.7/lib/python3.10/ctypes/__init__.py", line 392, in __getitem__
func = self._FuncPtr((name_or_ordinal, self))
AttributeError: /gnu/store/2hr7w64zhr6jjznidyc2xi40d5ynhj9c-openssl-3.0.8/lib/libcrypto.so.3: undefined symbol: EVP_PKEY_size. Did you mean: 'EVP_PKEY_free'?
2023-08-23 12:46:10 +01:00
|
|
|
"1v5wkmzcyiqy39db8j2dvkdrv2nlsc48556h73x4dzjwd6kg4q0a"))
|
2021-02-04 19:09:02 -05:00
|
|
|
(patches (search-our-patches "oscrypto-hard-code-openssl.patch"))))
|
|
|
|
(build-system python-build-system)
|
|
|
|
(native-search-paths
|
|
|
|
(list (search-path-specification
|
|
|
|
(variable "SSL_CERT_FILE")
|
|
|
|
(file-type 'regular)
|
|
|
|
(separator #f) ;single entry
|
|
|
|
(files '("etc/ssl/certs/ca-certificates.crt")))))
|
|
|
|
|
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list python-asn1crypto openssl))
|
2021-02-04 19:09:02 -05:00
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'hard-code-path-to-libscrypt
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(let ((openssl (assoc-ref inputs "openssl")))
|
|
|
|
(substitute* "oscrypto/__init__.py"
|
|
|
|
(("@GUIX_OSCRYPTO_USE_OPENSSL@")
|
|
|
|
(string-append openssl "/lib/libcrypto.so" "," openssl "/lib/libssl.so")))
|
|
|
|
#t)))
|
|
|
|
(add-after 'unpack 'disable-broken-tests
|
|
|
|
(lambda _
|
|
|
|
;; This test is broken as there is no keyboard interrupt.
|
|
|
|
(substitute* "tests/test_trust_list.py"
|
|
|
|
(("^(.*)class TrustListTests" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
(substitute* "tests/test_tls.py"
|
|
|
|
(("^(.*)class TLSTests" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
#t))
|
|
|
|
(replace 'check
|
|
|
|
(lambda _
|
|
|
|
(invoke "python" "run.py" "tests")
|
|
|
|
#t)))))
|
|
|
|
(home-page "https://github.com/wbond/oscrypto")
|
|
|
|
(synopsis "Compiler-free Python crypto library backed by the OS")
|
|
|
|
(description "oscrypto is a compilation-free, always up-to-date encryption library for Python.")
|
|
|
|
(license license:expat)))
|
|
|
|
|
|
|
|
(define-public python-oscryptotests
|
|
|
|
(package (inherit python-oscrypto)
|
|
|
|
(name "python-oscryptotests")
|
2021-11-01 15:17:01 +08:00
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list python-oscrypto))
|
2021-02-04 19:09:02 -05:00
|
|
|
(arguments
|
|
|
|
`(#:tests? #f
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'hard-code-path-to-libscrypt
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(chdir "tests")
|
|
|
|
#t)))))))
|
|
|
|
|
|
|
|
(define-public python-certvalidator
|
2022-03-08 12:11:13 +00:00
|
|
|
(let ((commit "a145bf25eb75a9f014b3e7678826132efbba6213"))
|
2021-02-04 19:09:02 -05:00
|
|
|
(package
|
|
|
|
(name "python-certvalidator")
|
|
|
|
(version (git-version "0.1" "1" commit))
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/achow101/certvalidator")
|
|
|
|
(commit commit)))
|
|
|
|
(file-name (git-file-name name commit))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2022-03-08 12:11:13 +00:00
|
|
|
"1qw2k7xis53179lpqdqyylbcmp76lj7sagp883wmxg5i7chhc96k"))))
|
2021-02-04 19:09:02 -05:00
|
|
|
(build-system python-build-system)
|
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list python-asn1crypto
|
|
|
|
python-oscrypto
|
|
|
|
python-oscryptotests)) ;; certvalidator tests import oscryptotests
|
2021-02-04 19:09:02 -05:00
|
|
|
(arguments
|
|
|
|
`(#:phases
|
|
|
|
(modify-phases %standard-phases
|
|
|
|
(add-after 'unpack 'disable-broken-tests
|
|
|
|
(lambda _
|
|
|
|
(substitute* "tests/test_certificate_validator.py"
|
|
|
|
(("^(.*)class CertificateValidatorTests" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
(substitute* "tests/test_crl_client.py"
|
|
|
|
(("^(.*)def test_fetch_crl" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
(substitute* "tests/test_ocsp_client.py"
|
|
|
|
(("^(.*)def test_fetch_ocsp" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
(substitute* "tests/test_registry.py"
|
|
|
|
(("^(.*)def test_build_paths" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
|
|
|
(substitute* "tests/test_validate.py"
|
|
|
|
(("^(.*)def test_revocation_mode_hard" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
2022-08-04 13:24:20 +01:00
|
|
|
(substitute* "tests/test_validate.py"
|
|
|
|
(("^(.*)def test_revocation_mode_soft" line indent)
|
|
|
|
(string-append indent
|
|
|
|
"@unittest.skip(\"Disabled by Guix\")\n"
|
|
|
|
line)))
|
2021-02-04 19:09:02 -05:00
|
|
|
#t))
|
|
|
|
(replace 'check
|
|
|
|
(lambda _
|
|
|
|
(invoke "python" "run.py" "tests")
|
|
|
|
#t)))))
|
|
|
|
(home-page "https://github.com/wbond/certvalidator")
|
|
|
|
(synopsis "Python library for validating X.509 certificates and paths")
|
|
|
|
(description "certvalidator is a Python library for validating X.509
|
|
|
|
certificates or paths. Supports various options, including: validation at a
|
|
|
|
specific moment in time, whitelisting and revocation checks.")
|
|
|
|
(license license:expat))))
|
|
|
|
|
|
|
|
(define-public python-signapple
|
2023-11-13 13:24:05 +00:00
|
|
|
(let ((commit "62155712e7417aba07565c9780a80e452823ae6a"))
|
2021-02-04 19:09:02 -05:00
|
|
|
(package
|
|
|
|
(name "python-signapple")
|
|
|
|
(version (git-version "0.1" "1" commit))
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
2021-06-08 16:30:43 -04:00
|
|
|
(url "https://github.com/achow101/signapple")
|
2021-02-04 19:09:02 -05:00
|
|
|
(commit commit)))
|
|
|
|
(file-name (git-file-name name commit))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2023-11-13 13:24:05 +00:00
|
|
|
"1nm6rm4h4m7kbq729si4cm8rzild62mk4ni8xr5zja7l33fhv3gb"))))
|
2021-02-04 19:09:02 -05:00
|
|
|
(build-system python-build-system)
|
|
|
|
(propagated-inputs
|
2023-06-22 10:20:07 +01:00
|
|
|
(list python-asn1crypto
|
|
|
|
python-oscrypto
|
|
|
|
python-certvalidator
|
|
|
|
python-elfesteem))
|
2021-02-04 19:09:02 -05:00
|
|
|
;; There are no tests, but attempting to run python setup.py test leads to
|
|
|
|
;; problems, just disable the test
|
|
|
|
(arguments '(#:tests? #f))
|
|
|
|
(home-page "https://github.com/achow101/signapple")
|
|
|
|
(synopsis "Mach-O binary signature tool")
|
|
|
|
(description "signapple is a Python tool for creating, verifying, and
|
|
|
|
inspecting signatures in Mach-O binaries.")
|
|
|
|
(license license:expat))))
|
|
|
|
|
2023-07-24 14:38:26 +01:00
|
|
|
(define-public mingw-w64-base-gcc
|
|
|
|
(package
|
|
|
|
(inherit base-gcc)
|
|
|
|
(arguments
|
|
|
|
(substitute-keyword-arguments (package-arguments base-gcc)
|
|
|
|
((#:configure-flags flags)
|
|
|
|
`(append ,flags
|
|
|
|
;; https://gcc.gnu.org/install/configure.html
|
|
|
|
(list "--enable-threads=posix",
|
2023-09-12 14:39:20 +01:00
|
|
|
"--enable-default-ssp=yes",
|
2024-11-20 11:24:30 +00:00
|
|
|
"--disable-gcov",
|
2023-09-12 13:04:51 +01:00
|
|
|
building-on)))))))
|
2023-07-24 14:38:26 +01:00
|
|
|
|
2023-08-18 15:31:20 +01:00
|
|
|
(define-public linux-base-gcc
|
|
|
|
(package
|
|
|
|
(inherit base-gcc)
|
|
|
|
(arguments
|
|
|
|
(substitute-keyword-arguments (package-arguments base-gcc)
|
|
|
|
((#:configure-flags flags)
|
|
|
|
`(append ,flags
|
|
|
|
;; https://gcc.gnu.org/install/configure.html
|
|
|
|
(list "--enable-initfini-array=yes",
|
|
|
|
"--enable-default-ssp=yes",
|
|
|
|
"--enable-default-pie=yes",
|
2023-08-14 13:23:25 +01:00
|
|
|
"--enable-standard-branch-protection=yes",
|
2024-07-10 10:20:27 +01:00
|
|
|
"--enable-cet=yes",
|
2024-11-20 11:24:30 +00:00
|
|
|
"--disable-gcov",
|
2023-08-18 15:31:20 +01:00
|
|
|
building-on)))
|
|
|
|
((#:phases phases)
|
|
|
|
`(modify-phases ,phases
|
|
|
|
;; Given a XGCC package, return a modified package that replace each instance of
|
|
|
|
;; -rpath in the default system spec that's inserted by Guix with -rpath-link
|
|
|
|
(add-after 'pre-configure 'replace-rpath-with-rpath-link
|
|
|
|
(lambda _
|
|
|
|
(substitute* (cons "gcc/config/rs6000/sysv4.h"
|
|
|
|
(find-files "gcc/config"
|
|
|
|
"^gnu-user.*\\.h$"))
|
|
|
|
(("-rpath=") "-rpath-link="))
|
|
|
|
#t))))))))
|
|
|
|
|
2024-04-27 15:36:28 +08:00
|
|
|
(define-public glibc-2.31
|
2024-11-14 11:02:15 +00:00
|
|
|
(let ((commit "7b27c450c34563a28e634cccb399cd415e71ebfe"))
|
2021-11-01 15:17:01 +08:00
|
|
|
(package
|
2024-04-27 15:36:28 +08:00
|
|
|
(inherit glibc) ;; 2.35
|
|
|
|
(version "2.31")
|
2021-11-01 15:17:01 +08:00
|
|
|
(source (origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://sourceware.org/git/glibc.git")
|
2024-04-27 15:36:28 +08:00
|
|
|
(commit commit)))
|
|
|
|
(file-name (git-file-name "glibc" commit))
|
2021-11-01 15:17:01 +08:00
|
|
|
(sha256
|
|
|
|
(base32
|
2024-11-14 11:02:15 +00:00
|
|
|
"017qdpr5id7ddb4lpkzj2li1abvw916m3fc6n7nw28z4h5qbv2n0"))
|
2024-04-27 15:36:28 +08:00
|
|
|
(patches (search-our-patches "glibc-guix-prefix.patch"))))
|
2023-08-18 15:08:11 +01:00
|
|
|
(arguments
|
|
|
|
(substitute-keyword-arguments (package-arguments glibc)
|
|
|
|
((#:configure-flags flags)
|
|
|
|
`(append ,flags
|
|
|
|
;; https://www.gnu.org/software/libc/manual/html_node/Configuring-and-compiling.html
|
|
|
|
(list "--enable-stack-protector=all",
|
2024-08-20 13:59:10 +01:00
|
|
|
"--enable-cet",
|
2023-08-18 15:08:11 +01:00
|
|
|
"--enable-bind-now",
|
|
|
|
"--disable-werror",
|
2024-11-14 11:02:32 +00:00
|
|
|
"--disable-timezone-tools",
|
|
|
|
"--disable-profile",
|
2023-08-18 15:08:11 +01:00
|
|
|
building-on)))
|
|
|
|
((#:phases phases)
|
|
|
|
`(modify-phases ,phases
|
|
|
|
(add-before 'configure 'set-etc-rpc-installation-directory
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
;; Install the rpc data base file under `$out/etc/rpc'.
|
|
|
|
;; Otherwise build will fail with "Permission denied."
|
2024-04-27 15:36:28 +08:00
|
|
|
;; Can be removed when we are building 2.32 or later.
|
2023-08-18 15:08:11 +01:00
|
|
|
(let ((out (assoc-ref outputs "out")))
|
|
|
|
(substitute* "sunrpc/Makefile"
|
|
|
|
(("^\\$\\(inst_sysconfdir\\)/rpc(.*)$" _ suffix)
|
|
|
|
(string-append out "/etc/rpc" suffix "\n"))
|
|
|
|
(("^install-others =.*$")
|
2024-04-27 15:36:28 +08:00
|
|
|
(string-append "install-others = " out "/etc/rpc\n")))))))))))))
|
2021-06-25 20:49:33 -04:00
|
|
|
|
2024-11-19 10:36:23 +00:00
|
|
|
;; The sponge tool from moreutils.
|
|
|
|
(define-public sponge
|
|
|
|
(package
|
|
|
|
(name "sponge")
|
|
|
|
(version "0.69")
|
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (string-append
|
|
|
|
"https://git.joeyh.name/index.cgi/moreutils.git/snapshot/
|
|
|
|
moreutils-" version ".tar.gz"))
|
|
|
|
(file-name (string-append "moreutils-" version ".tar.gz"))
|
|
|
|
(sha256
|
|
|
|
(base32
|
|
|
|
"1l859qnzccslvxlh5ghn863bkq2vgmqgnik6jr21b9kc6ljmsy8g"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
(list #:phases
|
|
|
|
#~(modify-phases %standard-phases
|
|
|
|
(delete 'configure)
|
|
|
|
(replace 'install
|
|
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
|
|
(let ((bin (string-append (assoc-ref outputs "out") "/bin")))
|
|
|
|
(install-file "sponge" bin)))))
|
|
|
|
#:make-flags
|
|
|
|
#~(list "sponge" (string-append "CC=" #$(cc-for-target)))))
|
|
|
|
(home-page "https://joeyh.name/code/moreutils/")
|
|
|
|
(synopsis "Miscellaneous general-purpose command-line tools")
|
|
|
|
(description "Just sponge")
|
|
|
|
(license license:gpl2+)))
|
|
|
|
|
2019-07-12 00:28:29 -04:00
|
|
|
(packages->manifest
|
2020-01-16 14:40:48 -05:00
|
|
|
(append
|
|
|
|
(list ;; The Basics
|
2023-02-28 09:25:04 +00:00
|
|
|
bash-minimal
|
2020-01-16 14:40:48 -05:00
|
|
|
which
|
2023-02-28 09:25:21 +00:00
|
|
|
coreutils-minimal
|
2020-01-16 14:40:48 -05:00
|
|
|
;; File(system) inspection
|
|
|
|
file
|
|
|
|
grep
|
|
|
|
diffutils
|
|
|
|
findutils
|
|
|
|
;; File transformation
|
|
|
|
patch
|
|
|
|
gawk
|
|
|
|
sed
|
2024-11-19 10:36:23 +00:00
|
|
|
sponge
|
2020-01-16 14:40:48 -05:00
|
|
|
;; Compression and archiving
|
|
|
|
tar
|
|
|
|
gzip
|
|
|
|
xz
|
|
|
|
;; Build tools
|
2024-07-23 12:19:54 +01:00
|
|
|
gcc-toolchain-12
|
2024-03-22 14:24:28 +00:00
|
|
|
cmake-minimal
|
2020-01-16 14:40:48 -05:00
|
|
|
gnu-make
|
|
|
|
;; Scripting
|
2022-08-03 15:46:30 +01:00
|
|
|
python-minimal ;; (3.10)
|
2020-04-22 13:05:37 -04:00
|
|
|
;; Git
|
2022-09-07 14:10:55 +01:00
|
|
|
git-minimal
|
2021-04-09 10:12:14 +08:00
|
|
|
;; Tests
|
2023-06-23 17:02:49 +01:00
|
|
|
python-lief)
|
2020-01-16 14:40:48 -05:00
|
|
|
(let ((target (getenv "HOST")))
|
|
|
|
(cond ((string-suffix? "-mingw32" target)
|
2024-07-23 12:19:54 +01:00
|
|
|
(list zip
|
2021-01-14 18:10:16 -05:00
|
|
|
(make-mingw-pthreads-cross-toolchain "x86_64-w64-mingw32")
|
2023-08-27 15:08:56 +01:00
|
|
|
nsis-x86_64
|
2022-08-03 10:54:15 +01:00
|
|
|
nss-certs
|
2021-02-04 19:09:02 -05:00
|
|
|
osslsigncode))
|
2020-01-16 14:40:48 -05:00
|
|
|
((string-contains target "-linux-")
|
2024-07-26 17:17:45 +01:00
|
|
|
(list bison
|
2024-11-11 15:37:53 +00:00
|
|
|
pkg-config
|
2024-07-26 17:17:45 +01:00
|
|
|
(list gcc-toolchain-12 "static")
|
2023-06-14 16:58:44 +01:00
|
|
|
(make-bitcoin-cross-toolchain target)))
|
2020-11-17 13:09:31 -05:00
|
|
|
((string-contains target "darwin")
|
2024-07-23 12:19:54 +01:00
|
|
|
(list clang-toolchain-18
|
2024-05-02 15:57:43 +08:00
|
|
|
lld-18
|
|
|
|
(make-lld-wrapper lld-18 #:lld-as-ld? #t)
|
2023-06-14 16:58:44 +01:00
|
|
|
python-signapple
|
|
|
|
zip))
|
2020-01-16 14:40:48 -05:00
|
|
|
(else '())))))
|