mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-21 18:19:15 -05:00
e5c32a3afa
* gnu/packages/finance (electron-cash)[arguments]: Use substitute-keyword-arguments to re-use arguments from electrum.
1220 lines
46 KiB
Scheme
1220 lines
46 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2015, 2016 Andreas Enge <andreas@enge.fr>
|
|
;;; Copyright © 2016, 2017, 2018 Efraim Flashner <efraim@flashner.co.il>
|
|
;;; Copyright © 2016 Alex Griffin <a@ajgrf.com>
|
|
;;; Copyright © 2016 Hartmut Goebel <h.goebel@crazy-compilers.com>
|
|
;;; Copyright © 2017 Carlo Zancanaro <carlo@zancanaro.id.au>
|
|
;;; Copyright © 2017 Theodoros Foradis <theodoros@foradis.org>
|
|
;;; Copyright © 2017 Vasile Dumitrascu <va511e@yahoo.com>
|
|
;;; Copyright © 2017, 2018, 2019 Tobias Geerinckx-Rice <me@tobias.gr>
|
|
;;; Copyright © 2018 Eric Bavier <bavier@member.fsf.org>
|
|
;;; Copyright © 2018 Adriano Peluso <catonano@gmail.com>
|
|
;;; Copyright © 2018, 2019 Nicolas Goaziou <mail@nicolasgoaziou.fr>
|
|
;;; Copyright © 2018 Arun Isaac <arunisaac@systemreboot.net>
|
|
;;; Copyright © 2019 Guillaume Le Vaillant <glv@posteo.net>
|
|
;;; Copyright © 2019 Tanguy Le Carrour <tanguy@bioneland.org>
|
|
;;; Copyright © 2019 Martin Becze <mjbecze@riseup.net>
|
|
;;; Copyright © 2019 Sebastian Schott <sschott@mailbox.org>
|
|
;;;
|
|
;;; 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 finance)
|
|
#:use-module ((guix licenses) #:prefix license:)
|
|
#:use-module (guix packages)
|
|
#:use-module (guix download)
|
|
#:use-module (guix git-download)
|
|
#:use-module (guix build-system gnu)
|
|
#:use-module (guix build-system cmake)
|
|
#:use-module (guix build-system python)
|
|
#:use-module (guix build-system glib-or-gtk)
|
|
#:use-module (guix build-system go)
|
|
#:use-module (guix utils)
|
|
#:use-module (gnu packages)
|
|
#:use-module (gnu packages aidc)
|
|
#:use-module (gnu packages autotools)
|
|
#:use-module (gnu packages base)
|
|
#:use-module (gnu packages boost)
|
|
#:use-module (gnu packages check)
|
|
#:use-module (gnu packages compression)
|
|
#:use-module (gnu packages crypto)
|
|
#:use-module (gnu packages databases)
|
|
#:use-module (gnu packages documentation)
|
|
#:use-module (gnu packages dns)
|
|
#:use-module (gnu packages emacs)
|
|
#:use-module (gnu packages dbm)
|
|
#:use-module (gnu packages gnome)
|
|
#:use-module (gnu packages glib)
|
|
#:use-module (gnu packages gnupg)
|
|
#:use-module (gnu packages graphviz)
|
|
#:use-module (gnu packages groff)
|
|
#:use-module (gnu packages gtk)
|
|
#:use-module (gnu packages libedit)
|
|
#:use-module (gnu packages libevent)
|
|
#:use-module (gnu packages libunwind)
|
|
#:use-module (gnu packages libusb)
|
|
#:use-module (gnu packages linux)
|
|
#:use-module (gnu packages multiprecision)
|
|
#:use-module (gnu packages networking)
|
|
#:use-module (gnu packages pkg-config)
|
|
#:use-module (gnu packages protobuf)
|
|
#:use-module (gnu packages python)
|
|
#:use-module (gnu packages python-crypto)
|
|
#:use-module (gnu packages python-web)
|
|
#:use-module (gnu packages python-xyz)
|
|
#:use-module (gnu packages qt)
|
|
#:use-module (gnu packages readline)
|
|
#:use-module (gnu packages sphinx)
|
|
#:use-module (gnu packages texinfo)
|
|
#:use-module (gnu packages textutils)
|
|
#:use-module (gnu packages time)
|
|
#:use-module (gnu packages tls)
|
|
#:use-module (gnu packages upnp)
|
|
#:use-module (gnu packages version-control)
|
|
#:use-module (gnu packages web)
|
|
#:use-module (gnu packages xml)
|
|
#:use-module (gnu packages gnuzilla))
|
|
|
|
(define-public bitcoin-core
|
|
(package
|
|
(name "bitcoin-core")
|
|
(version "0.18.1")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri
|
|
(string-append "https://bitcoincore.org/bin/bitcoin-core-"
|
|
version "/bitcoin-" version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"15mz0gmm058gmq2gdpffbw25jpv7mksyhyfws6i7mqvrapqr6zaw"))))
|
|
(build-system gnu-build-system)
|
|
(native-inputs
|
|
`(("pkg-config" ,pkg-config)
|
|
("python" ,python) ; for the tests
|
|
("util-linux" ,util-linux) ; provides the hexdump command for tests
|
|
("qttools" ,qttools)))
|
|
(inputs
|
|
`(("bdb" ,bdb-4.8) ; 4.8 required for compatibility
|
|
("boost" ,boost)
|
|
("libevent" ,libevent)
|
|
("miniupnpc" ,miniupnpc)
|
|
("openssl" ,openssl)
|
|
("protobuf" ,protobuf)
|
|
("qtbase" ,qtbase)))
|
|
(arguments
|
|
`(#:configure-flags
|
|
(list
|
|
;; Boost is not found unless specified manually.
|
|
(string-append "--with-boost="
|
|
(assoc-ref %build-inputs "boost"))
|
|
;; XXX: The configure script looks up Qt paths by
|
|
;; `pkg-config --variable=host_bins Qt5Core`, which fails to pick
|
|
;; up executables residing in 'qttools', so we specify them here.
|
|
(string-append "ac_cv_path_LRELEASE="
|
|
(assoc-ref %build-inputs "qttools")
|
|
"/bin/lrelease")
|
|
(string-append "ac_cv_path_LUPDATE="
|
|
(assoc-ref %build-inputs "qttools")
|
|
"/bin/lupdate"))
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-before 'configure 'make-qt-deterministic
|
|
(lambda _
|
|
;; Make Qt deterministic.
|
|
(setenv "QT_RCC_SOURCE_DATE_OVERRIDE" "1")
|
|
#t))
|
|
(add-before 'check 'set-home
|
|
(lambda _
|
|
(setenv "HOME" (getenv "TMPDIR")) ; tests write to $HOME
|
|
#t))
|
|
(add-after 'check 'check-functional
|
|
(lambda _
|
|
(invoke "python3" "./test/functional/test_runner.py"
|
|
(string-append "--jobs=" (number->string (parallel-job-count))))
|
|
#t)))))
|
|
(home-page "https://bitcoin.org/en/")
|
|
(synopsis "Bitcoin peer-to-peer client")
|
|
(description
|
|
"Bitcoin is a digital currency that enables instant payments to anyone
|
|
anywhere in the world. It uses peer-to-peer technology to operate without
|
|
central authority: managing transactions and issuing money are carried out
|
|
collectively by the network. Bitcoin Core is the reference implementation
|
|
of the bitcoin protocol. This package provides the Bitcoin Core command
|
|
line client and a client based on Qt.")
|
|
(license license:expat)))
|
|
|
|
(define-public homebank
|
|
(package
|
|
(name "homebank")
|
|
(version "5.2.8")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri (string-append "http://homebank.free.fr/public/homebank-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"13ampiv68y30kc0p2560g3yz8whqpwnidfcnb9lndv93b9ca767y"))))
|
|
(build-system glib-or-gtk-build-system)
|
|
(native-inputs
|
|
`(("pkg-config" ,pkg-config)
|
|
("intltool" ,intltool)))
|
|
(inputs
|
|
`(("gtk+" ,gtk+)
|
|
("libsoup" ,libsoup)))
|
|
(arguments
|
|
`(#:configure-flags (list "-without-ofx"))) ; libofx is not available yet
|
|
(home-page "http://homebank.free.fr/")
|
|
(synopsis "Graphical personal accounting application")
|
|
(description "HomeBank allows you to manage your personal accounts at
|
|
home. The seeks to be lightweight, simple and easy to use. It brings
|
|
features that allow you to analyze your finances in a detailed way instantly
|
|
and dynamically with report tools based on filtering and graphical charts.")
|
|
(license license:gpl2+)))
|
|
|
|
(define-public ledger
|
|
(package
|
|
(name "ledger")
|
|
(version "3.1.3")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/ledger/ledger.git")
|
|
(commit (string-append "v" version))))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "0bfnrqrd6wqgsngfpqi30xh6yy86pwl25iwzrqy44q31r0zl4mm3"))))
|
|
(build-system cmake-build-system)
|
|
(arguments
|
|
`(#:configure-flags
|
|
`("-DBUILD_DOCS:BOOL=ON"
|
|
"-DBUILD_WEB_DOCS:BOOL=ON"
|
|
"-DUSE_PYTHON:BOOL=ON"
|
|
"-DCMAKE_INSTALL_LIBDIR:PATH=lib")
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-before 'configure 'install-examples
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let ((examples (string-append (assoc-ref outputs "out")
|
|
"/share/doc/ledger/examples")))
|
|
(install-file "test/input/sample.dat" examples)
|
|
(install-file "test/input/demo.ledger" examples))
|
|
#t))
|
|
(add-after 'build 'build-doc
|
|
(lambda _ (invoke "make" "doc")))
|
|
(add-before 'check 'check-setup
|
|
;; One test fails if it can't set the timezone.
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(setenv "TZDIR"
|
|
(string-append (assoc-ref inputs "tzdata")
|
|
"/share/zoneinfo"))
|
|
;; Skip failing test BaselineTest_cmd-org.
|
|
;; This is a known upstream issue. See
|
|
;; https://github.com/ledger/ledger/issues/550
|
|
(setenv "ARGS" "-E BaselineTest_cmd-org")
|
|
#t)))))
|
|
(inputs
|
|
`(("boost" ,boost)
|
|
("gmp" ,gmp)
|
|
("libedit" ,libedit)
|
|
("mpfr" ,mpfr)
|
|
("python" ,python-2)
|
|
("tzdata" ,tzdata)
|
|
("utfcpp" ,utfcpp)))
|
|
(native-inputs
|
|
`(("groff" ,groff)
|
|
("texinfo" ,texinfo)))
|
|
(home-page "https://ledger-cli.org/")
|
|
(synopsis "Command-line double-entry accounting program")
|
|
(description
|
|
"Ledger is a powerful, double-entry accounting system that is
|
|
accessed from the UNIX command-line. This may put off some users, since
|
|
there is no flashy UI, but for those who want unparalleled reporting
|
|
access to their data there are few alternatives.
|
|
|
|
Ledger uses text files for input. It reads the files and generates
|
|
reports; there is no other database or stored state. To use Ledger,
|
|
you create a file of your account names and transactions, run from the
|
|
command line with some options to specify input and requested reports, and
|
|
get output. The output is generally plain text, though you could generate
|
|
a graph or html instead. Ledger is simple in concept, surprisingly rich
|
|
in ability, and easy to use.")
|
|
;; There are some extra licenses in files which do not presently get
|
|
;; installed when you build this package. Different versions of the GPL
|
|
;; are used in the contrib and python subdirectories. The bundled version
|
|
;; of utfcpp is under the Boost 1.0 license. Also the file
|
|
;; `tools/update_copyright_year` has an Expat license.
|
|
(license (list license:bsd-3
|
|
license:asl2.0 ; src/strptime.cc
|
|
(license:non-copyleft
|
|
"file://src/wcwidth.cc"
|
|
"See src/wcwidth.cc in the distribution.")))))
|
|
|
|
(define-public emacs-ledger-mode
|
|
;; There have been no new releases since 2016.
|
|
(let ((commit "253a20dc62e137ed0ed8e1dd8614ecba116610ea")
|
|
(revision "1"))
|
|
(package
|
|
(name "emacs-ledger-mode")
|
|
(version (git-version "3.1.1" revision commit))
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/ledger/ledger-mode.git")
|
|
(commit commit)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "06wrgkqpgvk17vibrk2qikdlqn8y63jg86marp1wgmram92mb3jk"))))
|
|
(build-system cmake-build-system)
|
|
(arguments
|
|
`(#:modules ((guix build cmake-build-system)
|
|
(guix build utils)
|
|
(guix build emacs-utils))
|
|
#:imported-modules (,@%cmake-build-system-modules
|
|
(guix build emacs-utils))
|
|
#:tests? #f ; there are none
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-before 'build 'patch-path
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(let ((ledger (assoc-ref inputs "ledger")))
|
|
(make-file-writable "ledger-exec.el")
|
|
(emacs-substitute-variables "ledger-exec.el"
|
|
("ledger-binary-path" (string-append ledger "/bin/ledger"))))
|
|
#t))
|
|
(add-after 'build 'build-doc
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let ((target (string-append (assoc-ref outputs "out")
|
|
"/share/info")))
|
|
(mkdir-p target)
|
|
(invoke "makeinfo" "-o" target
|
|
"../source/doc/ledger-mode.texi"))
|
|
#t))
|
|
(add-after 'install 'relocate-elisp
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let* ((site-dir (string-append (assoc-ref outputs "out")
|
|
"/share/emacs/site-lisp"))
|
|
(guix-dir (string-append site-dir "/guix.d"))
|
|
(orig-dir (string-append site-dir "/ledger-mode"))
|
|
(dest-dir (string-append guix-dir "/ledger-mode")))
|
|
(mkdir-p guix-dir)
|
|
(rename-file orig-dir dest-dir)
|
|
(emacs-generate-autoloads ,name dest-dir)
|
|
#t))))))
|
|
(inputs
|
|
`(("ledger" ,ledger)))
|
|
(native-inputs
|
|
`(("emacs-minimal" ,emacs-minimal)
|
|
("texinfo" ,texinfo)))
|
|
(home-page "https://ledger-cli.org/")
|
|
(synopsis "Command-line double-entry accounting program")
|
|
(description
|
|
"Ledger is a powerful, double-entry accounting system that is
|
|
accessed from the UNIX command-line. This may put off some users, since
|
|
there is no flashy UI, but for those who want unparalleled reporting
|
|
access to their data there are few alternatives.
|
|
|
|
Ledger uses text files for input. It reads the files and generates
|
|
reports; there is no other database or stored state. To use Ledger,
|
|
you create a file of your account names and transactions, run from the
|
|
command line with some options to specify input and requested reports, and
|
|
get output. The output is generally plain text, though you could generate
|
|
a graph or html instead. Ledger is simple in concept, surprisingly rich
|
|
in ability, and easy to use.
|
|
|
|
This package provides the Emacs mode.")
|
|
(license license:gpl2+))))
|
|
|
|
(define-public geierlein
|
|
(package
|
|
(name "geierlein")
|
|
(version "0.9.13")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/stesie/geierlein.git")
|
|
(commit (string-append "V" version))))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "00zpwr3lk2vdmd60fgdwdk0xxs52wvnm19ln2m75yfphydvkglic"))))
|
|
(build-system gnu-build-system)
|
|
(arguments
|
|
`(#:tests? #f ; would require npm, python and a lot more
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(delete 'configure) ; no configure script
|
|
(add-after 'unpack 'override-target-directory-and-tool-paths
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(substitute* "Makefile"
|
|
(("prefix := .*")
|
|
(string-append "prefix := " (assoc-ref outputs "out") "\n"))
|
|
;; Required for tests, unused for now:
|
|
;;(("PYTHON := .*")
|
|
;; (string-append (which "python") "\n")))
|
|
(("INSTALL := .*")
|
|
(string-append "INSTALL := " (which "install") "\n")))
|
|
(substitute* "bin/xgeierlein.in"
|
|
;; Use icecat as XULRUNNER
|
|
(("^for search ")
|
|
(string-append "XULRUNNER=" (which "icecat") "\n"
|
|
"for search ")))
|
|
#t)))))
|
|
(inputs
|
|
`(("icecat" ,icecat)))
|
|
(home-page "https://stesie.github.io/geierlein/")
|
|
(synopsis "Free Elster client, for sending Germany VAT declarations")
|
|
(description
|
|
"Geierlein is a free Elster client, i.e. an application that
|
|
allows to send VAT declarations to Germany's fiscal authorities.
|
|
|
|
Currently it is *not* possible to send returns that are due annually
|
|
(especially the income tax return) since the fiscal authority doesn't
|
|
allow to do that off the ERiC library (which is proprietary however).
|
|
It's not clear at the moment whether one day it will be possible to
|
|
do so.")
|
|
(license license:agpl3+)))
|
|
|
|
(define-public electrum
|
|
(package
|
|
(name "electrum")
|
|
(version "3.3.8")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append "https://download.electrum.org/"
|
|
version "/Electrum-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32 "1g00cj1pmckd4xis8r032wmraiv3vd3zc803hnyxa2bnhj8z3bg2"))
|
|
(modules '((guix build utils)))
|
|
(snippet
|
|
'(begin
|
|
;; Delete the bundled dependencies.
|
|
(delete-file-recursively "packages")
|
|
#t))))
|
|
(build-system python-build-system)
|
|
(inputs
|
|
`(("python-pyaes" ,python-pyaes)
|
|
("python-pysocks" ,python-pysocks)
|
|
("python-sip" ,python-sip)
|
|
("python-pyqt" ,python-pyqt)
|
|
("python-ecdsa" ,python-ecdsa)
|
|
("python-pbkdf2" ,python-pbkdf2)
|
|
("python-requests" ,python-requests)
|
|
("python-qrcode" ,python-qrcode)
|
|
("python-protobuf" ,python-protobuf)
|
|
("python-aiohttp" ,python-aiohttp)
|
|
("python-aiohttp-socks" ,python-aiohttp-socks)
|
|
("python-aiorpcx" ,python-aiorpcx)
|
|
("python-certifi" ,python-certifi)
|
|
("python-dnspython" ,python-dnspython)
|
|
("python-jsonrpclib-pelix" ,python-jsonrpclib-pelix)))
|
|
(arguments
|
|
`(#:tests? #f ;; package doesn't have any tests
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-before 'build 'patch-home
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(substitute* "setup.py"
|
|
(("~/.local/share")
|
|
(string-append (assoc-ref outputs "out") "/local/share"))))))))
|
|
(home-page "https://electrum.org/")
|
|
(synopsis "Bitcoin wallet")
|
|
(description
|
|
"Electrum is a lightweight Bitcoin client, based on a client-server
|
|
protocol. It supports Simple Payment Verification (SPV) and deterministic key
|
|
generation from a seed. Your secret keys are encrypted and are never sent to
|
|
other machines/servers. Electrum does not download the Bitcoin blockchain.")
|
|
(license license:expat)))
|
|
|
|
(define-public electron-cash
|
|
(package
|
|
(inherit electrum)
|
|
(name "electron-cash")
|
|
(version "4.0.12")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/Electron-Cash/Electron-Cash.git")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"0gidrx8499v7rig7ljhd70wssshs1qm0gp1553g70i323hcbf62x"))))
|
|
(inputs
|
|
`(,@(package-inputs electrum)
|
|
("libsecp256k1", libsecp256k1)
|
|
("python-dateutil", python-dateutil)
|
|
("python-dnspython", python-dnspython)))
|
|
(arguments
|
|
(substitute-keyword-arguments (package-arguments electrum)
|
|
((#:phases phases)
|
|
`(modify-phases ,phases
|
|
(add-after 'unpack 'use-libsecp256k1-input
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(substitute* "lib/secp256k1.py"
|
|
(("library_paths = .* 'libsecp256k1.so.0'.")
|
|
(string-append "library_paths = ('" (assoc-ref inputs "libsecp256k1") "/lib/libsecp256k1.so.0'")))))))))
|
|
(home-page "https://electroncash.org/")
|
|
(synopsis "Bitcoin Cash wallet")
|
|
(description
|
|
"Electroncash is a lightweight Bitcoin Cash client, based on a client-server
|
|
protocol. It supports Simple Payment Verification (SPV) and deterministic key
|
|
generation from a seed. Your secret keys are encrypted and are never sent to
|
|
other machines/servers. Electroncash does not download the Bitcoin Cash blockchain.")
|
|
(license license:expat)))
|
|
|
|
(define-public monero
|
|
;; This package bundles easylogging++ and lmdb.
|
|
;; The bundled easylogging++ is modified, and the changes will not be
|
|
;; upstreamed.
|
|
;; The devs deem the lmdb driver too critical a consenus component, to use
|
|
;; the system's dynamically linked library.
|
|
(package
|
|
(name "monero")
|
|
(version "0.15.0.1")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/monero-project/monero.git")
|
|
(commit (string-append "v" version))
|
|
(recursive? #t)))
|
|
(file-name (git-file-name name version))
|
|
(patches (search-patches "monero-use-system-miniupnpc.patch"))
|
|
(modules '((guix build utils)))
|
|
(snippet
|
|
'(begin
|
|
;; Delete bundled dependencies.
|
|
(for-each
|
|
delete-file-recursively
|
|
'("external/miniupnp" "external/rapidjson"
|
|
"external/unbound"))
|
|
#t))
|
|
(sha256
|
|
(base32
|
|
"0sypa235lf2bbib4b71xpaw39h9304slgsvnsz8wmy9fq1zx009m"))))
|
|
(build-system cmake-build-system)
|
|
(native-inputs
|
|
`(("doxygen" ,doxygen)
|
|
("git" ,git)
|
|
("graphviz" ,graphviz)
|
|
("pkg-config" ,pkg-config)
|
|
("protobuf" ,protobuf)
|
|
("python" ,python)
|
|
("qttools" ,qttools)))
|
|
(inputs
|
|
`(("boost" ,boost)
|
|
("cppzmq" ,cppzmq)
|
|
("expat" ,expat)
|
|
("hidapi" ,hidapi)
|
|
("libsodium" ,libsodium)
|
|
("libunwind" ,libunwind)
|
|
("libusb" ,libusb)
|
|
("miniupnpc" ,miniupnpc)
|
|
("openssl" ,openssl)
|
|
("protobuf" ,protobuf)
|
|
("rapidjson" ,rapidjson)
|
|
("readline" ,readline)
|
|
("unbound" ,unbound)
|
|
("xz" ,xz)
|
|
("zeromq" ,zeromq)))
|
|
(arguments
|
|
`(#:out-of-source? #t
|
|
#:configure-flags
|
|
(list "-DARCH=default"
|
|
"-DBUILD_TESTS=ON"
|
|
"-DBUILD_GUI_DEPS=ON"
|
|
(string-append "-DReadline_ROOT_DIR="
|
|
(assoc-ref %build-inputs "readline")))
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
;; tests/core_tests need a valid HOME
|
|
(add-before 'configure 'set-home
|
|
(lambda _
|
|
(setenv "HOME" (getcwd))
|
|
#t))
|
|
(add-after 'set-home 'change-log-path
|
|
(lambda _
|
|
(substitute* "contrib/epee/src/mlog.cpp"
|
|
(("epee::string_tools::get_current_module_folder\\(\\)")
|
|
"\".bitmonero\"")
|
|
(("return \\(")
|
|
"return ((std::string(getenv(\"HOME\"))) / "))
|
|
#t))
|
|
(add-after 'change-log-path 'fix-file-permissions-for-tests
|
|
(lambda _
|
|
(for-each make-file-writable
|
|
(find-files "tests/data/" "wallet_9svHk1.*"))
|
|
#t))
|
|
;; Only try tests that don't need access to network or system
|
|
(replace 'check
|
|
(lambda _
|
|
(invoke "make" "ARGS=-R 'hash|core_tests' --verbose" "test")))
|
|
(add-after 'check 'unit-tests
|
|
(lambda _
|
|
(let ((excluded-unit-tests
|
|
(string-join
|
|
'("AddressFromURL.Success"
|
|
"AddressFromURL.Failure"
|
|
"DNSResolver.IPv4Success"
|
|
"DNSResolver.DNSSECSuccess"
|
|
"DNSResolver.DNSSECFailure"
|
|
"DNSResolver.GetTXTRecord"
|
|
"is_hdd.linux_os_root")
|
|
":")))
|
|
(invoke "tests/unit_tests/unit_tests"
|
|
(string-append "--gtest_filter=-"
|
|
excluded-unit-tests)))))
|
|
(add-after 'install 'install-librandomx
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let ((lib (string-append (assoc-ref outputs "out") "/lib")))
|
|
(install-file "external/randomx/librandomx.a" lib)
|
|
#t)))
|
|
(add-after 'install 'delete-dead-links
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let ((out (assoc-ref outputs "out")))
|
|
(delete-file (string-append out "/lib/libprotobuf.so"))
|
|
(delete-file (string-append out "/lib/libusb-1.0.so"))
|
|
#t))))))
|
|
(home-page "https://web.getmonero.org/")
|
|
(synopsis "Command-line interface to the Monero currency")
|
|
(description
|
|
"Monero is a secure, private, untraceable currency. This package provides
|
|
the Monero command line client and daemon.")
|
|
(license license:bsd-3)))
|
|
|
|
(define-public monero-gui
|
|
(package
|
|
(name "monero-gui")
|
|
(version "0.15.0.1")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/monero-project/monero-gui.git")
|
|
(commit (string-append "v" version))))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"08j8kkncdn57xql0bhmlzjpjkdfhqbpda1p07r797q8qi0nl4w8n"))))
|
|
(build-system gnu-build-system)
|
|
(native-inputs
|
|
`(("pkg-config" ,pkg-config)
|
|
("qttools" ,qttools)))
|
|
(inputs
|
|
`(("boost" ,boost)
|
|
("hidapi" ,hidapi)
|
|
("libsodium" ,libsodium)
|
|
("libunwind" ,libunwind)
|
|
("libusb" ,libusb)
|
|
("openssl" ,openssl)
|
|
("protobuf" ,protobuf)
|
|
("qtbase" ,qtbase)
|
|
("qtdeclarative" ,qtdeclarative)
|
|
("qtgraphicaleffects" ,qtgraphicaleffects)
|
|
("qtlocation" ,qtlocation)
|
|
("qtmultimedia" ,qtmultimedia)
|
|
("qtquickcontrols" ,qtquickcontrols)
|
|
("qtquickcontrols2",qtquickcontrols2)
|
|
("qtsvg" ,qtsvg)
|
|
("qtwebchannel" ,qtwebchannel)
|
|
("qtx11extras" ,qtx11extras)
|
|
("qtxmlpatterns" ,qtxmlpatterns)
|
|
("unbound" ,unbound)))
|
|
(propagated-inputs
|
|
`(("monero" ,monero)))
|
|
(arguments
|
|
`(#:modules ((guix build gnu-build-system)
|
|
(guix build qt-utils)
|
|
(guix build utils))
|
|
#:imported-modules (,@%gnu-build-system-modules
|
|
(guix build qt-utils))
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(delete 'configure)
|
|
(delete 'check)
|
|
(add-before 'build 'fix-makefile-vars
|
|
(lambda _
|
|
(substitute* "src/zxcvbn-c/makefile"
|
|
(("\\?=") "="))
|
|
#t))
|
|
(add-after 'fix-makefile-vars 'fix-library-paths
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(substitute* "monero-wallet-gui.pro"
|
|
(("-L/usr/local/lib")
|
|
"")
|
|
(("-L/usr/local/opt/openssl/lib")
|
|
(string-append "-L" (assoc-ref inputs "openssl") "/lib"))
|
|
(("-L/usr/local/opt/boost/lib")
|
|
(string-append "-L" (assoc-ref inputs "boost") "/lib")))
|
|
#t))
|
|
(add-after 'fix-library-paths 'fix-monerod-path
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(substitute* "src/daemon/DaemonManager.cpp"
|
|
(("QApplication::applicationDirPath\\(\\) \\+ \"/monerod")
|
|
(string-append "\"" (assoc-ref inputs "monero")
|
|
"/bin/monerod")))
|
|
#t))
|
|
(add-after 'fix-monerod-path 'fix-qt-paths
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
(substitute* "monero-wallet-gui.pro"
|
|
(("\\$\\$\\[QT_INSTALL_BINS\\]/lrelease")
|
|
(string-append (assoc-ref inputs "qttools") "/bin/lrelease"))
|
|
(("\\$\\$\\[QT_INSTALL_BINS\\]/lupdate")
|
|
(string-append (assoc-ref inputs "qttools") "/bin/lupdate")))
|
|
#t))
|
|
(add-after 'fix-qt-paths 'make-qt-deterministic
|
|
(lambda _
|
|
(setenv "QT_RCC_SOURCE_DATE_OVERRIDE" "1")
|
|
#t))
|
|
(add-after 'make-qt-deterministic 'fix-version
|
|
(lambda _
|
|
(substitute* "build.sh"
|
|
(("echo .*> version.js")
|
|
""))
|
|
(with-output-to-file "version.js"
|
|
(lambda _
|
|
(format #t
|
|
"var GUI_VERSION = \"~a\"~@
|
|
var GUI_MONERO_VERSION = \"~a\"~%"
|
|
,version
|
|
,(package-version monero))))
|
|
#t))
|
|
(replace 'build
|
|
(lambda _
|
|
(invoke "./build.sh")))
|
|
(add-after 'build 'fix-install-path
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(substitute* "build/Makefile"
|
|
(("/opt/monero-wallet-gui")
|
|
(assoc-ref outputs "out")))
|
|
#t))
|
|
(add-before 'install 'change-dir
|
|
(lambda _
|
|
(chdir "build")
|
|
#t))
|
|
(add-after 'install 'wrap-program
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let ((out (assoc-ref outputs "out")))
|
|
(wrap-qt-program out "monero-wallet-gui"))
|
|
#t)))))
|
|
(home-page "https://web.getmonero.org/")
|
|
(synopsis "Graphical user interface for the Monero currency")
|
|
(description
|
|
"Monero is a secure, private, untraceable currency. This package provides
|
|
the Monero GUI client.")
|
|
(license license:bsd-3)))
|
|
|
|
(define-public monero-core
|
|
(deprecated-package "monero-core" monero-gui))
|
|
|
|
(define-public python-trezor-agent
|
|
(package
|
|
(name "python-trezor-agent")
|
|
(version "0.13.1")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/romanz/trezor-agent.git")
|
|
(commit (string-append "v" version))))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32 "0q99vbfd3h85s8rnjipnmldixabqmmlk5w9karv6f0rhyi54f4zv"))))
|
|
(build-system python-build-system)
|
|
(arguments
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
(add-after 'unpack 'remove-requires-backports-shutil-which
|
|
;; Remove requires on backport of shutil_which, as python 3.4+ has
|
|
;; a built-in implementation supported in python-trezor-agent.
|
|
(lambda _
|
|
(substitute* "setup.py"
|
|
(("'backports.shutil_which>=3.5.1',") ""))
|
|
#t))
|
|
(delete 'check)
|
|
(add-after 'install 'check
|
|
(lambda* (#:key outputs inputs #:allow-other-keys)
|
|
;; Make installed package available for running the tests.
|
|
(add-installed-pythonpath inputs outputs)
|
|
(invoke "py.test"))))))
|
|
(propagated-inputs
|
|
`(("python-configargparse" ,python-configargparse)
|
|
("python-daemon" ,python-daemon)
|
|
("python-docutils" ,python-docutils)
|
|
("python-ecdsa" ,python-ecdsa)
|
|
("python-ed25519" ,python-ed25519)
|
|
("python-mnemonic" ,python-mnemonic)
|
|
("python-pymsgbox" ,python-pymsgbox)
|
|
("python-semver" ,python-semver)
|
|
("python-unidecode" ,python-unidecode)
|
|
("python-wheel" ,python-wheel)))
|
|
(native-inputs
|
|
`(("gnupg" ,gnupg)
|
|
("python-mock" ,python-mock)
|
|
("python-pytest" ,python-pytest)))
|
|
(home-page "https://github.com/romanz/trezor-agent")
|
|
(synopsis "Use hardware wallets as SSH and GPG agent")
|
|
(description
|
|
"@code{libagent} is a library that allows using TREZOR, Keepkey and
|
|
Ledger Nano as a hardware SSH/GPG agent.")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public python-mnemonic
|
|
(package
|
|
(name "python-mnemonic")
|
|
(version "0.19")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "mnemonic" version))
|
|
(sha256
|
|
(base32 "0cd9prmdj8wzdmc7lxbf9lz0xrlkvak5ignag406mmfbn81fndsf"))))
|
|
(build-system python-build-system)
|
|
(propagated-inputs
|
|
`(("python-pbkdf2" ,python-pbkdf2)))
|
|
(home-page "https://github.com/trezor/python-mnemonic")
|
|
(synopsis "Implementation of Bitcoin BIP-0039")
|
|
(description "@code{mnemonic} is a library that provides an implementation
|
|
of Bitcoin BIP-0039.")
|
|
(license license:expat)))
|
|
|
|
(define-public python2-mnemonic
|
|
(package-with-python2 python-mnemonic))
|
|
|
|
(define-public python-ledgerblue
|
|
(package
|
|
(name "python-ledgerblue")
|
|
(version "0.1.16")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "ledgerblue" version))
|
|
(sha256
|
|
(base32
|
|
"010mghaqh1cmz3a0ifc3f40mmyplilwlw7kpha2mzyrrff46p9gb"))))
|
|
(build-system python-build-system)
|
|
(propagated-inputs
|
|
`(("python-ecpy" ,python-ecpy)
|
|
("python-future" ,python-future)
|
|
("python-hidapi" ,python-hidapi)
|
|
("python-pillow" ,python-pillow)
|
|
("python-protobuf" ,python-protobuf)
|
|
("python-pycrypto" ,python-pycrypto)))
|
|
(home-page "https://github.com/LedgerHQ/blue-loader-python")
|
|
(synopsis "Python library to communicate with Ledger Blue/Nano S")
|
|
(description "@code{ledgerblue} is a Python library to communicate with
|
|
Ledger Blue/Nano S.")
|
|
(license license:asl2.0)))
|
|
|
|
(define-public python2-ledgerblue
|
|
(package-with-python2 python-ledgerblue))
|
|
|
|
(define-public python-trezor
|
|
(package
|
|
(name "python-trezor")
|
|
(version "0.11.3")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "trezor" version))
|
|
(sha256
|
|
(base32
|
|
"0211m027vlvyqy83kwbjjjxalb04xgf1klv0h0y0f0yhj07516n7"))))
|
|
(build-system python-build-system)
|
|
(arguments
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
;; Default tests run device-specific tests which fail, only run specific tests.
|
|
(replace 'check
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
;; Delete tests that require network access.
|
|
(delete-file "trezorlib/tests/unit_tests/test_tx_api.py")
|
|
(invoke "python" "-m" "pytest" "--pyarg" "trezorlib.tests.unit_tests"))))))
|
|
(propagated-inputs
|
|
`(("python-click" ,python-click)
|
|
("python-construct" ,python-construct)
|
|
("python-ecdsa" ,python-ecdsa)
|
|
("python-libusb1" ,python-libusb1)
|
|
("python-mnemonic" ,python-mnemonic)
|
|
("python-pyblake2" ,python-pyblake2)
|
|
("python-requests" ,python-requests)
|
|
("python-typing-extensions" ,python-typing-extensions)))
|
|
(native-inputs
|
|
;; For tests.
|
|
`(("protobuf" ,protobuf)
|
|
("python-black" ,python-black)
|
|
("python-protobuf" ,python-protobuf)
|
|
("python-isort" ,python-isort)
|
|
("python-pyqt" ,python-pyqt)
|
|
("python-pytest" ,python-pytest)))
|
|
(home-page "https://github.com/trezor/python-trezor")
|
|
(synopsis "Python library for communicating with TREZOR Hardware Wallet")
|
|
(description "@code{trezor} is a Python library for communicating with
|
|
TREZOR Hardware Wallet.")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public python-keepkey
|
|
(package
|
|
(name "python-keepkey")
|
|
(version "6.0.3")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "keepkey" version))
|
|
(sha256
|
|
(base32
|
|
"0z3d0m6364v9dv0njs4cd5m5ai6j6v35xaaxfxl90m9vmyxy81vd"))))
|
|
(build-system python-build-system)
|
|
(arguments
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
(delete 'check)
|
|
(add-after 'install 'check
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(add-installed-pythonpath inputs outputs)
|
|
(apply invoke "python" (find-files "tests/unit" "\\.py$")))))))
|
|
(propagated-inputs
|
|
`(("python-ecdsa" ,python-ecdsa)
|
|
("python-hidapi" ,python-hidapi)
|
|
("python-libusb1" ,python-libusb1)
|
|
("python-mnemonic" ,python-mnemonic)
|
|
("python-protobuf" ,python-protobuf)))
|
|
(home-page "https://github.com/keepkey/python-keepkey")
|
|
(synopsis "Python library for communicating with KeepKey Hardware Wallet")
|
|
(description "@code{keepkey} is a Python library for communicating with
|
|
the KeepKey Hardware Wallet.")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public python2-keepkey
|
|
(package-with-python2 python-keepkey))
|
|
|
|
(define-public ledger-agent
|
|
(package
|
|
(name "ledger-agent")
|
|
(version "0.9.0")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "ledger_agent" version))
|
|
(sha256
|
|
(base32
|
|
"03zj602m2rln9yvr08dswy56vzkbldp8b074ixwzz525dafblr92"))))
|
|
(build-system python-build-system)
|
|
(inputs
|
|
`(("python-ledgerblue" ,python-ledgerblue)
|
|
("python-trezor-agent" ,python-trezor-agent)))
|
|
(home-page "http://github.com/romanz/trezor-agent")
|
|
(synopsis "Ledger as hardware SSH/GPG agent")
|
|
(description "This package allows using Ledger as hardware SSH/GPG agent.
|
|
|
|
Usage for SSH: trezor-agent foo@@example.com --connect
|
|
Usage for GPG: Initialize using trezor-gpg init \"Foo <foo@@example.com>\"
|
|
Then set the environment variable GNUPGHOME to
|
|
\"${HOME}/.gnupg/trezor\".")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public trezor-agent
|
|
(package
|
|
(name "trezor-agent")
|
|
(version "0.10.0")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "trezor_agent" version))
|
|
(sha256
|
|
(base32
|
|
"144657c7bn0a667dq5fv5r6j7iilxf3h9agj29v1m2qpq40g0az8"))))
|
|
(arguments
|
|
;; Tests fail with "AttributeError: module 'attr' has no attribute 's'".
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
(add-after 'wrap 'fixup-agent-py
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(let* ((out (assoc-ref outputs "out")))
|
|
;; overwrite the wrapper with the real thing.
|
|
(install-file "./trezor_agent.py"
|
|
(string-append out "/bin"))
|
|
#t))))))
|
|
(build-system python-build-system)
|
|
(inputs
|
|
`(("python-trezor" ,python-trezor)
|
|
("python-trezor-agent" ,python-trezor-agent)))
|
|
(native-inputs
|
|
`(("python-hidapi" ,python-hidapi)))
|
|
(home-page "https://github.com/romanz/trezor-agent")
|
|
(synopsis "Using Trezor as hardware SSH/GPG agent")
|
|
(description "This package allows using Trezor as a hardware SSH/GPG
|
|
agent.")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public keepkey-agent
|
|
(package
|
|
(name "keepkey-agent")
|
|
(version "0.9.0")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "keepkey_agent" version))
|
|
(sha256
|
|
(base32
|
|
"03779gvlx70i0nnry98i4pl1d92604ix5x6jgdfkrdgzqbh5vj27"))))
|
|
(build-system python-build-system)
|
|
(inputs
|
|
`(("python-keepkey" ,python-keepkey)
|
|
("python-trezor-agent" ,python-trezor-agent)))
|
|
(home-page "http://github.com/romanz/trezor-agent")
|
|
(synopsis "KeepKey as hardware SSH/GPG agent")
|
|
(description "This package allows using KeepKey as a hardware SSH/GPG
|
|
agent.")
|
|
(license license:lgpl3)))
|
|
|
|
(define-public python-stdnum
|
|
(package
|
|
(name "python-stdnum")
|
|
(version "1.8.1")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "python-stdnum" version))
|
|
(sha256
|
|
(base32
|
|
"0hvr47q32xbyiznpmbg4r8rcvxhnf0lwf33hcpnynyik57djy5np"))))
|
|
(build-system python-build-system)
|
|
(home-page
|
|
"https://arthurdejong.org/python-stdnum/")
|
|
(synopsis
|
|
"Python module to handle standardized number and code formats")
|
|
(description
|
|
"This is a Python library that aims to provide functions to handle,
|
|
parse and validate standard numbers.
|
|
The module supports more than 100 different number formats
|
|
amongst which a great number of VAT and other tax numbers,
|
|
personal identity and company identification codes,
|
|
international standard numbers (ISBN, IBAN, EAN, etc.)
|
|
and various other formats.
|
|
The module also inclused implementations of the Verhoeff,
|
|
Luhn and family of ISO/IEC 7064 check digit algorithms. ")
|
|
(license license:lgpl2.1+)))
|
|
|
|
(define-public python2-stdnum
|
|
(package-with-python2 python-stdnum))
|
|
|
|
(define-public python-duniterpy
|
|
(package
|
|
(name "python-duniterpy")
|
|
(version "0.55.1")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
;; Pypi's default URI is missing "requirements.txt" file.
|
|
(uri (git-reference
|
|
(url "https://git.duniter.org/clients/python/duniterpy.git")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"07zsbbkzmnvyv5v0vw2d42vw3ar4iqhlidy9376ysk4ldlj1igf7"))))
|
|
(build-system python-build-system)
|
|
(arguments
|
|
;; Tests fail with "AttributeError: module 'attr' has no attribute 's'".
|
|
`(#:tests? #f
|
|
#:phases
|
|
(modify-phases %standard-phases
|
|
(add-after 'build 'build-documentation
|
|
(lambda _
|
|
(invoke "make" "docs")))
|
|
(add-after 'build-documentation 'install-documentation
|
|
(lambda* (#:key inputs outputs #:allow-other-keys)
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
(doc (string-append out "/share/doc/" ,name)))
|
|
(mkdir-p doc)
|
|
(copy-recursively "docs/_build/html" doc))
|
|
#t)))))
|
|
(native-inputs
|
|
`(("sphinx" ,python-sphinx)
|
|
("sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
|
|
(propagated-inputs
|
|
`(("aiohttp" ,python-aiohttp)
|
|
("attr" ,python-attr)
|
|
("base58" ,python-base58)
|
|
("jsonschema" ,python-jsonschema)
|
|
("libnacl" ,python-libnacl)
|
|
("pyaes" ,python-pyaes)
|
|
("pylibscrypt" ,python-pylibscrypt)
|
|
("pypeg2" ,python-pypeg2)))
|
|
(home-page "https://git.duniter.org/clients/python/duniterpy")
|
|
(synopsis "Python implementation of Duniter API")
|
|
(description "@code{duniterpy} is an implementation of
|
|
@uref{https://github.com/duniter/duniter/, duniter} API. Its
|
|
main features are:
|
|
@itemize
|
|
@item Support Duniter's Basic Merkle API and protocol
|
|
@item Asynchronous/synchronous without threads
|
|
@item Support HTTP, HTTPS and Web Socket transport for Basic Merkle API
|
|
@item Support Elasticsearch Duniter4j API
|
|
@item Duniter signing key
|
|
@item Sign/verify and encrypt/decrypt messages with the Duniter credentials
|
|
@end itemize")
|
|
(license license:gpl3+)))
|
|
|
|
(define-public silkaj
|
|
(package
|
|
(name "silkaj")
|
|
(version "0.7.3")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://git.duniter.org/clients/python/silkaj.git")
|
|
(commit (string-append "v" version))))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"0yk2574yb0d0k0rg7qf0pkmjidblsad04x8hhqpy9k80rvgjcr5w"))))
|
|
(build-system python-build-system)
|
|
(arguments
|
|
`(#:tests? #f)) ;no test
|
|
(inputs
|
|
`(("click" ,python-click)
|
|
("duniterpy" ,python-duniterpy)
|
|
("ipaddress" ,python-ipaddress)
|
|
("pynacl" ,python-pynacl)
|
|
("tabulate" ,python-tabulate)
|
|
("texttable" ,python-texttable)))
|
|
(home-page "https://silkaj.duniter.org/")
|
|
(synopsis "Command line client for Duniter network")
|
|
(description "@code{Silkaj} is a command line client for the
|
|
@uref{https://github.com/duniter/duniter/, Duniter} network.
|
|
|
|
Its features are:
|
|
@itemize
|
|
@item information about currency,
|
|
@item issuers difficulty to generate next block,
|
|
@item network view of nodes,
|
|
@item list of last issuers,
|
|
@item send transactions,
|
|
@item get account amount.
|
|
@end itemize")
|
|
(license license:agpl3+)))
|
|
|
|
(define-public grisbi
|
|
(package
|
|
(name "grisbi")
|
|
(version "1.2.2")
|
|
(source
|
|
(origin
|
|
(method url-fetch)
|
|
(uri (string-append
|
|
"mirror://sourceforge/grisbi/grisbi%20stable/"
|
|
(version-major+minor version) ".x/" version
|
|
"/grisbi-" version ".tar.bz2"))
|
|
(sha256
|
|
(base32
|
|
"1piiyyxjsjbw9gcqydvknzxmmfgh8kdqal12ywrxyxih2afwnvbw"))))
|
|
(build-system glib-or-gtk-build-system)
|
|
(arguments
|
|
`(#:configure-flags (list "--without-ofx")))
|
|
(propagated-inputs
|
|
`(("dconf" ,dconf)))
|
|
(native-inputs
|
|
`(("glib" ,glib "bin") ; glib-compile-schemas
|
|
("pkg-config" ,pkg-config)
|
|
("intltool" ,intltool)))
|
|
(inputs
|
|
`(("gtk+" ,gtk+)
|
|
("libgsf" ,libgsf)))
|
|
(synopsis "Personal accounting application")
|
|
(description "Grisbi is a personal accounting application written by
|
|
French developers that is designed to follow French accounting rules.
|
|
Grisbi can manage multiple accounts, currencies and users. It manages
|
|
third party, expenditure and receipt categories, budgetary lines,
|
|
financial years, budget estimates, bankcard management and other
|
|
information.")
|
|
(home-page "http://grisbi.org")
|
|
(license license:gpl2+)))
|
|
|
|
(define-public trezord
|
|
(package
|
|
(name "trezord")
|
|
(version "2.0.17")
|
|
(source
|
|
(origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/trezor/trezord-go.git")
|
|
(commit (string-append "v" version))))
|
|
(sha256
|
|
(base32
|
|
"0nqzpq0i3crh0i4r1cppja5sn3rwi1fv9afxzwzv63096x5l30a7"))
|
|
(file-name (git-file-name name version))))
|
|
(build-system go-build-system)
|
|
(arguments
|
|
'(#:import-path "github.com/trezor/trezord-go"))
|
|
(home-page "https://trezor.io")
|
|
(synopsis "Trezor Communication Daemon aka Trezor Bridge (written in Go)")
|
|
(description "This allows a Trezor hardware wallet to communicate to the
|
|
Trezor wallet.")
|
|
(license license:lgpl3+)))
|
|
|
|
(define-public bitcoin-abc
|
|
(package
|
|
(inherit bitcoin-core)
|
|
(name "bitcoin-abc")
|
|
(version "0.20.7")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri (string-append "https://download.bitcoinabc.org/"
|
|
version "/src/bitcoin-abc-"
|
|
version ".tar.gz"))
|
|
(sha256
|
|
(base32
|
|
"0py5ilfi4r8qh5r9637vwch27sqrrn0dg9rz8bccnj3lp2xpzw27"))))
|
|
(native-inputs
|
|
`(("autoconf" ,autoconf)
|
|
("automake" ,automake)
|
|
("libtool" ,libtool)
|
|
("pkg-config" ,pkg-config)
|
|
("python" ,python) ; for the tests
|
|
("util-linux" ,util-linux) ; provides the hexdump command for tests
|
|
("qttools" ,qttools)))
|
|
(inputs
|
|
`(("bdb" ,bdb-5.3)
|
|
("boost" ,boost)
|
|
("libevent" ,libevent)
|
|
("miniupnpc" ,miniupnpc)
|
|
("openssl" ,openssl)
|
|
("protobuf" ,protobuf)
|
|
("qrencode" ,qrencode)
|
|
("qtbase" ,qtbase)
|
|
("zlib" ,zlib)))
|
|
(home-page "https://www.bitcoinabc.org/")
|
|
(synopsis "Bitcoin ABC peer-to-peer full node for the Bitcoin Cash protocol")
|
|
(description
|
|
"Bitcoin Cash brings sound money to the world, fulfilling the original
|
|
promise of Bitcoin as Peer-to-Peer Electronic Cash. Merchants and users are
|
|
empowered with low fees and reliable confirmations is a digital currency that
|
|
enables instant payments to anyone anywhere in the world. It uses
|
|
peer-to-peer technology to operate without central authority: managing
|
|
transactions and issuing money are carried out collectively by the network.
|
|
As a fork it implemented changes lowering the time between blocks and now
|
|
offers confimations after less than 5 seconds and have significantly lower
|
|
fees that BTC. Bitcoin ABC is the reference implementation of the Bitcoin
|
|
Cash protocol. This package provides the Bitcoin Cash command line client and
|
|
a client based on Qt. This is a fork of Bitcoin Core.")))
|