{ lib, stdenv, fetchgit, gnunet, qrencode, taler-exchange, taler-wallet-core, libtool, pkg-config, autoreconfHook, makeWrapper, jq, }: stdenv.mkDerivation (finalAttrs: { pname = "taler-merchant"; version = "0.13.0"; src = fetchgit { url = "https://git.taler.net/merchant.git"; rev = "v${finalAttrs.version}"; fetchSubmodules = true; hash = "sha256-N3atOOE21OEks3G1LPOM5qo/kq0D5D9gmTfURCBZx6M="; }; postUnpack = '' ln -s ${taler-wallet-core}/spa.html $sourceRoot/contrib/ ''; # Use an absolute path for `templates` and `spa` directories, else a relative # path to the `taler-exchange` package is used. postPatch = '' substituteInPlace src/backend/taler-merchant-httpd.c \ --replace-fail 'TALER_TEMPLATING_init ("merchant");' "TALER_TEMPLATING_init_path (\"merchant\", \"$out/share/taler\");" substituteInPlace src/backend/taler-merchant-httpd_spa.c \ --replace-fail 'GNUNET_DISK_directory_scan (dn,' "GNUNET_DISK_directory_scan (\"$out/share/taler/merchant/spa/\"," ''; nativeBuildInputs = [ pkg-config autoreconfHook makeWrapper ]; buildInputs = taler-exchange.buildInputs ++ [ qrencode taler-exchange # for ltdl.h libtool ]; propagatedBuildInputs = [ gnunet ]; # From ./bootstrap preAutoreconf = '' pushd contrib find wallet-core/backoffice/ -type f -printf ' %p \\\n' | sort > Makefile.am.ext truncate -s -2 Makefile.am.ext cat Makefile.am.in Makefile.am.ext >> Makefile.am popd ''; # NOTE: The executables that need database access fail to detect the # postgresql library in `$out/lib/taler`, so we need to wrap them. postInstall = '' for exec in dbinit httpd webhook wirewatch depositcheck exchange; do wrapProgram $out/bin/taler-merchant-$exec \ --prefix LD_LIBRARY_PATH : "$out/lib/taler" done ''; enableParallelBuilding = true; doInstallCheck = true; nativeCheckInputs = [ jq ]; checkTarget = "check"; meta = { description = '' This is the GNU Taler merchant backend. It provides the logic that should run at every GNU Taler merchant. The GNU Taler merchant is a RESTful backend that can be used to setup orders and process payments. This component allows merchants to receive payments without invading the customers' privacy. Of course, this applies mostly for digital goods, as the merchant does not need to know the customer's physical address. ''; homepage = "https://taler.net/"; changelog = "https://git.taler.net/merchant.git/tree/ChangeLog"; license = lib.licenses.agpl3Plus; maintainers = with lib.maintainers; [ astro ]; platforms = lib.platforms.linux; }; })