diff options
author | Efraim Flashner <efraim@flashner.co.il> | 2025-01-15 10:14:30 +0200 |
---|---|---|
committer | Efraim Flashner <efraim@flashner.co.il> | 2025-01-15 14:27:43 +0200 |
commit | 6f87c38e85b90c2b0393268b63a1f5c1540c6315 (patch) | |
tree | 8621ca770a3b9f73db7b01a7ea876755f99dda15 /gnu/packages/sequoia.scm | |
parent | a889f1f30b870b721e0656d70a99763aaa09ce73 (diff) |
gnu: Add sequoia-chameleon-gnupg.
* gnu/packages/sequoia.scm (sequoia-chameleon-gnupg): New variable.
Change-Id: Ia5e759c55f94e9daf52a3ad56a1dfc34d6a1bef6
Diffstat (limited to 'gnu/packages/sequoia.scm')
-rw-r--r-- | gnu/packages/sequoia.scm | 147 |
1 files changed, 147 insertions, 0 deletions
diff --git a/gnu/packages/sequoia.scm b/gnu/packages/sequoia.scm index 0d73b72ca1..1607d2debc 100644 --- a/gnu/packages/sequoia.scm +++ b/gnu/packages/sequoia.scm @@ -914,6 +914,153 @@ This Guix package is built to use the nettle cryptographic library.") "This package provides an implementation of @code{OpenPGP's} web of trust.") (license license:lgpl2.0+))) +(define-public sequoia-chameleon-gnupg + (package + (name "sequoia-chameleon-gnupg") + (version "0.11.2") + (source + (origin + (method url-fetch) + (uri (crate-uri "sequoia-chameleon-gnupg" version)) + (file-name (string-append name "-" version ".tar.gz")) + (sha256 + (base32 "1rdmyhnvll9r2g4r8xbcjfg5cjw32204cfj6my94p0bc5v6lhv2h")) + (snippet + #~(begin (use-modules (guix build utils)) + ;; According to Debian and Upstream these substitutions are okay. + (copy-file "Cargo.toml.orig" "Cargo.toml") + (substitute* "Cargo.toml" + (("sequoia-policy-config = \"0\\.6\"") + "sequoia-policy-config = \"0.7\"") + (("sequoia-wot = \\{ version = \"0\\.12\"") + "sequoia-wot = { version = \"0.13\"")))))) + (build-system cargo-build-system) + (arguments + (list + #:install-source? #f + #:features '(list "crypto-nettle") + #:cargo-test-flags + '(list "--" + ;; Some tests overly depend on specific versions of input crates. + "--skip=gpg::generate_key" + "--skip=gpg::list_keys" + "--skip=gpg::migrate::migration_from_secring" + "--skip=gpg::print_mds" + "--skip=gpg::quick::add_key_default_default_iso_date" + "--skip=gpg::quick::generate_key_default_default_iso_date" + "--skip=gpg::sign" + "--skip=gpg::verify" + ;; No such file or directory + "--skip=password_store_git") + #:cargo-inputs + (list rust-anyhow-1 + rust-base64-0.21 + rust-buffered-reader-1 + rust-chrono-0.4 + rust-clap-4 + rust-clap-complete-4 + rust-clap-mangen-0.2 + rust-daemonize-0.5 + rust-dirs-5 + rust-fd-lock-3 + rust-filetime-0.2 + rust-futures-0.3 + rust-indexmap-2 + rust-interprocess-1 + rust-libc-0.2 + rust-memchr-2 + rust-openssh-keys-0.6 + rust-percent-encoding-2 + rust-rand-0.8 + rust-rand-distr-0.4 + rust-rayon-1 + rust-reqwest-0.11 + rust-roff-0.2 + rust-rpassword-7 + rust-rusqlite-0.29 + rust-sequoia-cert-store-0.6 + rust-sequoia-gpg-agent-0.4 + rust-sequoia-ipc-0.35 + rust-sequoia-net-0.28 + rust-sequoia-openpgp-1 + rust-sequoia-policy-config-0.7 + rust-sequoia-wot-0.13 + rust-serde-1 + rust-serde-json-1 + rust-shellexpand-3 + rust-tempfile-3 + rust-thiserror-1 + rust-tokio-1) + #:cargo-development-inputs + (list rust-anyhow-1 + rust-bzip2-0.4 + rust-diff-0.1 + rust-editdistancek-1 + rust-histo-1 + rust-interprocess-1 + rust-ntest-0.9 + rust-regex-1 + rust-reqwest-0.11 + rust-serde-with-3 + rust-stfu8-0.2 + rust-tar-0.4 + rust-tempfile-3) + #:phases + #~(modify-phases %standard-phases + (add-after 'unpack 'set-asset-out-dir + (lambda _ + (setenv "ASSET_OUT_DIR" "target/assets"))) + (add-after 'install 'install-more + (lambda* (#:key outputs #:allow-other-keys) + (let* ((out (assoc-ref outputs "out")) + (share (string-append out "/share")) + (bash-completions-dir + (string-append out "/etc/bash_completion.d")) + (zsh-completions-dir + (string-append share "/zsh/site-functions")) + (fish-completions-dir + (string-append share "/fish/vendor_completions.d")) + (elvish-completions-dir + (string-append share "/elvish/lib")) + (man1 (string-append share "/man/man1"))) + ;; The completions are generated in build.rs. + (mkdir-p bash-completions-dir) + (mkdir-p elvish-completions-dir) + (for-each (lambda (file) + (install-file file man1)) + (find-files "target/assets/man-pages" "\\.1$")) + (copy-file "target/assets/shell-completions/gpg-sq.bash" + (string-append bash-completions-dir "/gpg-sq")) + (copy-file "target/assets/shell-completions/gpgv-sq.bash" + (string-append bash-completions-dir "/gpgv-sq")) + (copy-file "target/assets/shell-completions/gpg-sq.elv" + (string-append elvish-completions-dir "/gpg-sq")) + (copy-file "target/assets/shell-completions/gpgv-sq.elv" + (string-append elvish-completions-dir "/gpgv-sq")) + (install-file "target/assets/shell-completions/_gpg-sq" + zsh-completions-dir) + (install-file "target/assets/shell-completions/_gpgv-sq" + zsh-completions-dir) + (install-file "target/assets/shell-completions/gpg-sq.fish" + fish-completions-dir) + (install-file "target/assets/shell-completions/gpgv-sq.fish" + fish-completions-dir))))))) + (inputs + (list nettle openssl sqlite)) + (native-inputs + (list clang gnupg pkg-config sequoia-sq)) + (home-page "https://sequoia-pgp.org/") + (synopsis "Sequoia's reimplementation of the GnuPG interface") + (description "This package provides Sequoia's reimplementation of the +@code{GnuPG} interface. + +@code{gpg-sq} is Sequoia's alternative implementation of a tool following the +GnuPG command line interface. It provides a drop-in but not feature-complete +replacement for the GnuPG project's @code{gpg}. + +This Guix package is built to use the nettle cryptographic library.") + (license license:gpl3+))) + (define-public sequoia-sq (package (name "sequoia-sq") |