2018-02-22 14:51:12 +01:00
|
|
|
/*
|
|
|
|
This file is part of TALER
|
2021-07-31 21:48:36 +02:00
|
|
|
Copyright (C) 2018-2021 Taler Systems SA
|
2018-02-22 14:51:12 +01:00
|
|
|
|
|
|
|
TALER 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, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
TALER 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 TALER; see the file COPYING. If not, see
|
|
|
|
<http://www.gnu.org/licenses/>
|
|
|
|
*/
|
|
|
|
/**
|
2020-01-19 15:23:19 +01:00
|
|
|
* @file testing/testing_api_helpers_bank.c
|
2020-01-13 18:16:01 +01:00
|
|
|
* @brief convenience functions for bank tests.
|
2018-02-22 14:51:12 +01:00
|
|
|
* @author Marcello Stanisci
|
2020-01-13 18:16:01 +01:00
|
|
|
* @author Christian Grothoff
|
2018-02-22 14:51:12 +01:00
|
|
|
*/
|
|
|
|
#include "platform.h"
|
|
|
|
#include <gnunet/gnunet_util_lib.h>
|
2020-01-13 00:27:48 +01:00
|
|
|
#include "taler_testing_lib.h"
|
2019-09-09 16:46:01 +02:00
|
|
|
#include "taler_fakebank_lib.h"
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2019-09-15 10:27:39 +02:00
|
|
|
#define BANK_FAIL() \
|
|
|
|
do {GNUNET_break (0); return NULL; } while (0)
|
|
|
|
|
|
|
|
|
2019-09-09 16:46:01 +02:00
|
|
|
struct TALER_FAKEBANK_Handle *
|
2020-02-04 21:59:43 +01:00
|
|
|
TALER_TESTING_run_fakebank (const char *bank_url,
|
|
|
|
const char *currency)
|
2019-09-09 16:46:01 +02:00
|
|
|
{
|
|
|
|
const char *port;
|
|
|
|
long pnum;
|
|
|
|
struct TALER_FAKEBANK_Handle *fakebankd;
|
|
|
|
|
|
|
|
port = strrchr (bank_url,
|
|
|
|
(unsigned char) ':');
|
|
|
|
if (NULL == port)
|
|
|
|
pnum = 80;
|
|
|
|
else
|
|
|
|
pnum = strtol (port + 1, NULL, 10);
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Starting Fakebank on port %u (%s)\n",
|
|
|
|
(unsigned int) pnum,
|
|
|
|
bank_url);
|
2020-02-04 21:59:43 +01:00
|
|
|
fakebankd = TALER_FAKEBANK_start ((uint16_t) pnum,
|
|
|
|
currency);
|
2019-09-09 16:46:01 +02:00
|
|
|
if (NULL == fakebankd)
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
return fakebankd;
|
|
|
|
}
|
|
|
|
|
2019-09-09 23:20:18 +02:00
|
|
|
|
|
|
|
int
|
2020-01-18 16:41:24 +01:00
|
|
|
TALER_TESTING_has_in_name (const char *prog,
|
2019-09-09 23:20:18 +02:00
|
|
|
const char *marker)
|
|
|
|
{
|
|
|
|
size_t name_pos;
|
|
|
|
size_t pos;
|
|
|
|
|
2020-01-18 16:41:24 +01:00
|
|
|
if (! prog || ! marker)
|
2019-09-09 23:20:18 +02:00
|
|
|
return GNUNET_NO;
|
|
|
|
|
|
|
|
pos = 0;
|
|
|
|
name_pos = 0;
|
2020-01-18 16:41:24 +01:00
|
|
|
while (prog[pos])
|
2019-09-09 23:20:18 +02:00
|
|
|
{
|
2020-01-18 16:41:24 +01:00
|
|
|
if ('/' == prog[pos])
|
2019-09-09 23:20:18 +02:00
|
|
|
name_pos = pos + 1;
|
|
|
|
pos++;
|
|
|
|
}
|
|
|
|
if (name_pos == pos)
|
|
|
|
return GNUNET_YES;
|
2020-01-18 16:41:24 +01:00
|
|
|
return (NULL != strstr (prog + name_pos, marker));
|
2019-09-09 23:20:18 +02:00
|
|
|
}
|
|
|
|
|
2019-10-31 12:59:50 +01:00
|
|
|
|
2020-06-02 11:36:51 +02:00
|
|
|
struct TALER_TESTING_LibeufinServices
|
|
|
|
TALER_TESTING_run_libeufin (const struct TALER_TESTING_BankConfiguration *bc)
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
2020-06-02 11:36:51 +02:00
|
|
|
struct GNUNET_OS_Process *nexus_proc;
|
|
|
|
struct GNUNET_OS_Process *sandbox_proc;
|
2020-06-14 15:40:28 +02:00
|
|
|
struct TALER_TESTING_LibeufinServices ret = { 0 };
|
2020-04-17 00:32:18 +02:00
|
|
|
unsigned int iter;
|
|
|
|
char *curl_check_cmd;
|
2020-05-27 15:03:19 +02:00
|
|
|
|
2020-07-18 00:25:35 +02:00
|
|
|
nexus_proc = GNUNET_OS_start_process (
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_OS_INHERIT_STD_ERR,
|
2020-07-18 00:25:35 +02:00
|
|
|
NULL, NULL, NULL,
|
|
|
|
"libeufin-nexus",
|
|
|
|
"libeufin-nexus",
|
|
|
|
"serve",
|
|
|
|
"--db-name", "/tmp/nexus-exchange-test.sqlite3",
|
|
|
|
NULL);
|
2020-06-02 11:36:51 +02:00
|
|
|
if (NULL == nexus_proc)
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
2020-12-20 20:03:59 +01:00
|
|
|
GNUNET_log_strerror_file (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
"exec",
|
|
|
|
"libeufin-nexus");
|
2020-06-02 11:36:51 +02:00
|
|
|
return ret;
|
2020-04-17 00:32:18 +02:00
|
|
|
}
|
|
|
|
GNUNET_asprintf (&curl_check_cmd,
|
|
|
|
"curl -s %s",
|
|
|
|
bc->exchange_auth.wire_gateway_url);
|
|
|
|
/* give child time to start and bind against the socket */
|
|
|
|
fprintf (stderr,
|
|
|
|
"Waiting for `nexus' to be ready (via %s)\n", curl_check_cmd);
|
|
|
|
iter = 0;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
if (10 == iter)
|
|
|
|
{
|
|
|
|
fprintf (
|
|
|
|
stderr,
|
|
|
|
"Failed to launch `nexus'\n");
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_OS_process_kill (nexus_proc,
|
2020-04-17 00:32:18 +02:00
|
|
|
SIGTERM);
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_OS_process_wait (nexus_proc);
|
|
|
|
GNUNET_OS_process_destroy (nexus_proc);
|
2020-04-17 00:32:18 +02:00
|
|
|
GNUNET_free (curl_check_cmd);
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_break (0);
|
|
|
|
return ret;
|
2020-04-17 00:32:18 +02:00
|
|
|
}
|
|
|
|
fprintf (stderr, ".");
|
|
|
|
sleep (1);
|
|
|
|
iter++;
|
|
|
|
}
|
|
|
|
while (0 != system (curl_check_cmd));
|
2020-06-02 14:58:30 +02:00
|
|
|
|
|
|
|
// start sandbox.
|
2020-04-17 00:32:18 +02:00
|
|
|
GNUNET_free (curl_check_cmd);
|
|
|
|
fprintf (stderr, "\n");
|
2020-06-02 11:36:51 +02:00
|
|
|
|
2020-07-18 00:25:35 +02:00
|
|
|
sandbox_proc = GNUNET_OS_start_process (
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_OS_INHERIT_STD_ERR,
|
2020-07-18 00:25:35 +02:00
|
|
|
NULL, NULL, NULL,
|
|
|
|
"libeufin-sandbox",
|
|
|
|
"libeufin-sandbox",
|
|
|
|
"serve",
|
|
|
|
"--db-name", "/tmp/sandbox-exchange-test.sqlite3",
|
|
|
|
NULL);
|
2020-06-02 11:36:51 +02:00
|
|
|
if (NULL == sandbox_proc)
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* give child time to start and bind against the socket */
|
|
|
|
fprintf (stderr,
|
2020-06-02 14:58:30 +02:00
|
|
|
"Waiting for `sandbox' to be ready.\n");
|
2020-06-02 11:36:51 +02:00
|
|
|
iter = 0;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
if (10 == iter)
|
|
|
|
{
|
|
|
|
fprintf (
|
|
|
|
stderr,
|
|
|
|
"Failed to launch `sandbox'\n");
|
|
|
|
GNUNET_OS_process_kill (sandbox_proc,
|
|
|
|
SIGTERM);
|
|
|
|
GNUNET_OS_process_wait (sandbox_proc);
|
|
|
|
GNUNET_OS_process_destroy (sandbox_proc);
|
|
|
|
GNUNET_break (0);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
fprintf (stderr, ".");
|
|
|
|
sleep (1);
|
|
|
|
iter++;
|
|
|
|
}
|
2020-06-02 14:58:30 +02:00
|
|
|
while (0 != system ("curl -s http://localhost:5000/"));
|
2020-06-02 11:36:51 +02:00
|
|
|
fprintf (stderr, "\n");
|
|
|
|
|
2020-06-01 14:17:05 +02:00
|
|
|
// Creates nexus user + bank loopback connection + Taler facade.
|
|
|
|
if (0 != system ("taler-nexus-prepare"))
|
|
|
|
{
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_OS_process_kill (nexus_proc, SIGTERM);
|
|
|
|
GNUNET_OS_process_wait (nexus_proc);
|
|
|
|
GNUNET_OS_process_destroy (nexus_proc);
|
|
|
|
GNUNET_OS_process_kill (sandbox_proc, SIGTERM);
|
|
|
|
GNUNET_OS_process_wait (sandbox_proc);
|
|
|
|
GNUNET_OS_process_destroy (sandbox_proc);
|
2020-06-06 02:02:48 +02:00
|
|
|
TALER_LOG_ERROR ("Could not prepare nexus\n");
|
2020-06-02 11:36:51 +02:00
|
|
|
GNUNET_break (0);
|
|
|
|
return ret;
|
2020-06-01 14:17:05 +02:00
|
|
|
}
|
2020-06-02 11:36:51 +02:00
|
|
|
ret.nexus = nexus_proc;
|
|
|
|
ret.sandbox = sandbox_proc;
|
|
|
|
return ret;
|
2020-04-17 00:32:18 +02:00
|
|
|
}
|
|
|
|
|
2020-06-13 17:19:04 +02:00
|
|
|
|
2018-02-22 14:51:12 +01:00
|
|
|
struct GNUNET_OS_Process *
|
2018-05-04 15:46:07 +02:00
|
|
|
TALER_TESTING_run_bank (const char *config_filename,
|
|
|
|
const char *bank_url)
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
|
|
|
struct GNUNET_OS_Process *bank_proc;
|
|
|
|
unsigned int iter;
|
2018-05-04 15:46:07 +02:00
|
|
|
char *wget_cmd;
|
|
|
|
char *database;
|
|
|
|
struct GNUNET_CONFIGURATION_Handle *cfg;
|
|
|
|
|
|
|
|
cfg = GNUNET_CONFIGURATION_create ();
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_load (cfg,
|
|
|
|
config_filename))
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
exit (77);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_string (cfg,
|
|
|
|
"bank",
|
|
|
|
"database",
|
|
|
|
&database))
|
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
"bank",
|
|
|
|
"database");
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
exit (77);
|
|
|
|
}
|
2019-09-15 10:27:39 +02:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-07-18 00:25:35 +02:00
|
|
|
bank_proc = GNUNET_OS_start_process (
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_OS_INHERIT_STD_ERR,
|
2020-07-18 00:25:35 +02:00
|
|
|
NULL, NULL, NULL,
|
|
|
|
"taler-bank-manage-testing",
|
|
|
|
"taler-bank-manage-testing",
|
|
|
|
config_filename,
|
|
|
|
database,
|
2020-10-03 16:13:06 +02:00
|
|
|
"serve", NULL);
|
2019-09-15 10:27:39 +02:00
|
|
|
GNUNET_free (database);
|
2018-02-22 14:51:12 +01:00
|
|
|
if (NULL == bank_proc)
|
2019-09-15 10:27:39 +02:00
|
|
|
{
|
2018-02-22 14:51:12 +01:00
|
|
|
BANK_FAIL ();
|
2019-09-15 10:27:39 +02:00
|
|
|
}
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2018-05-04 15:46:07 +02:00
|
|
|
GNUNET_asprintf (&wget_cmd,
|
2020-01-09 16:20:28 +01:00
|
|
|
"wget -q -t 2 -T 1 %s -o /dev/null -O /dev/null",
|
2018-05-04 15:46:07 +02:00
|
|
|
bank_url);
|
|
|
|
|
2018-02-22 14:51:12 +01:00
|
|
|
/* give child time to start and bind against the socket */
|
|
|
|
fprintf (stderr,
|
2020-01-17 12:15:57 +01:00
|
|
|
"Waiting for `taler-bank-manage' to be ready (via %s)\n", wget_cmd);
|
2018-02-22 14:51:12 +01:00
|
|
|
iter = 0;
|
|
|
|
do
|
2019-08-25 16:18:24 +02:00
|
|
|
{
|
|
|
|
if (10 == iter)
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
2019-08-25 16:18:24 +02:00
|
|
|
fprintf (
|
|
|
|
stderr,
|
|
|
|
"Failed to launch `taler-bank-manage' (or `wget')\n");
|
|
|
|
GNUNET_OS_process_kill (bank_proc,
|
|
|
|
SIGTERM);
|
|
|
|
GNUNET_OS_process_wait (bank_proc);
|
|
|
|
GNUNET_OS_process_destroy (bank_proc);
|
2019-09-15 10:27:39 +02:00
|
|
|
GNUNET_free (wget_cmd);
|
2019-08-25 16:18:24 +02:00
|
|
|
BANK_FAIL ();
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
2019-08-25 16:18:24 +02:00
|
|
|
fprintf (stderr, ".");
|
|
|
|
sleep (1);
|
|
|
|
iter++;
|
|
|
|
}
|
2018-05-04 15:46:07 +02:00
|
|
|
while (0 != system (wget_cmd));
|
2019-09-15 10:27:39 +02:00
|
|
|
GNUNET_free (wget_cmd);
|
2018-02-22 14:51:12 +01:00
|
|
|
fprintf (stderr, "\n");
|
|
|
|
|
|
|
|
return bank_proc;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-06-13 17:19:04 +02:00
|
|
|
|
2021-11-07 19:37:06 +01:00
|
|
|
enum GNUNET_GenericReturnValue
|
2020-04-17 00:32:18 +02:00
|
|
|
TALER_TESTING_prepare_nexus (const char *config_filename,
|
|
|
|
int reset_db,
|
|
|
|
const char *config_section,
|
|
|
|
struct TALER_TESTING_BankConfiguration *bc)
|
|
|
|
{
|
|
|
|
struct GNUNET_CONFIGURATION_Handle *cfg;
|
|
|
|
unsigned long long port;
|
|
|
|
char *database = NULL; // silence compiler
|
|
|
|
char *exchange_payto_uri;
|
|
|
|
|
2021-08-03 21:58:36 +02:00
|
|
|
GNUNET_assert (0 ==
|
|
|
|
strncasecmp (config_section,
|
|
|
|
"exchange-account-",
|
|
|
|
strlen ("exchange-account-")));
|
2020-04-17 00:32:18 +02:00
|
|
|
cfg = GNUNET_CONFIGURATION_create ();
|
|
|
|
if (GNUNET_OK !=
|
2021-08-03 21:58:36 +02:00
|
|
|
GNUNET_CONFIGURATION_load (cfg,
|
|
|
|
config_filename))
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
GNUNET_break (0);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_string (cfg,
|
|
|
|
config_section,
|
|
|
|
"PAYTO_URI",
|
|
|
|
&exchange_payto_uri))
|
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
config_section,
|
|
|
|
"PAYTO_URI");
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_number (cfg,
|
|
|
|
"bank",
|
|
|
|
"HTTP_PORT",
|
|
|
|
&port))
|
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"bank",
|
|
|
|
"HTTP_PORT");
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
GNUNET_free (database);
|
|
|
|
GNUNET_break (0);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_NETWORK_test_port_free (IPPROTO_TCP,
|
|
|
|
(uint16_t) port))
|
|
|
|
{
|
|
|
|
fprintf (stderr,
|
|
|
|
"Required port %llu not available, skipping.\n",
|
|
|
|
port);
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_free (database);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* DB preparation */
|
|
|
|
if (GNUNET_YES == reset_db)
|
|
|
|
{
|
2020-06-13 17:19:04 +02:00
|
|
|
if (0 != system (
|
|
|
|
"rm -f /tmp/nexus-exchange-test.sqlite3 && rm -f /tmp/sandbox-exchange-test.sqlite3"))
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"Failed to invoke db-removal command.\n");
|
|
|
|
GNUNET_free (database);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
}
|
2020-06-06 02:02:48 +02:00
|
|
|
|
2020-04-17 00:32:18 +02:00
|
|
|
{
|
2021-08-03 21:58:36 +02:00
|
|
|
char *csn;
|
|
|
|
|
|
|
|
GNUNET_asprintf (&csn,
|
|
|
|
"exchange-accountcredentials-%s",
|
|
|
|
&config_section[strlen ("exchange-account-")]);
|
|
|
|
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
TALER_BANK_auth_parse_cfg (cfg,
|
|
|
|
csn,
|
|
|
|
&bc->exchange_auth))
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
GNUNET_free (csn);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
GNUNET_free (csn);
|
2020-04-17 00:32:18 +02:00
|
|
|
}
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
bc->exchange_payto = exchange_payto_uri;
|
2020-06-13 17:19:04 +02:00
|
|
|
bc->user42_payto =
|
|
|
|
"payto://iban/BIC/FR7630006000011234567890189?receiver-name=User42";
|
|
|
|
bc->user43_payto =
|
|
|
|
"payto://iban/BIC/GB33BUKB20201555555555?receiver-name=User43";
|
2020-04-17 00:32:18 +02:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Relying on nexus %s on port %u\n",
|
|
|
|
bc->exchange_auth.wire_gateway_url,
|
|
|
|
(unsigned int) port);
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "exchange payto: %s\n",
|
|
|
|
bc->exchange_payto);
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "user42_payto: %s\n",
|
|
|
|
bc->user42_payto);
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "user42_payto: %s\n",
|
|
|
|
bc->user43_payto);
|
|
|
|
return GNUNET_OK;
|
|
|
|
}
|
2018-05-29 10:27:41 +02:00
|
|
|
|
2020-06-13 17:19:04 +02:00
|
|
|
|
2021-11-07 19:37:06 +01:00
|
|
|
enum GNUNET_GenericReturnValue
|
2020-01-13 00:27:48 +01:00
|
|
|
TALER_TESTING_prepare_bank (const char *config_filename,
|
2020-03-19 21:44:54 +01:00
|
|
|
int reset_db,
|
2020-01-18 03:50:54 +01:00
|
|
|
const char *config_section,
|
2020-01-13 00:27:48 +01:00
|
|
|
struct TALER_TESTING_BankConfiguration *bc)
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
|
|
|
struct GNUNET_CONFIGURATION_Handle *cfg;
|
|
|
|
unsigned long long port;
|
|
|
|
struct GNUNET_OS_Process *dbreset_proc;
|
|
|
|
enum GNUNET_OS_ProcessStatusType type;
|
|
|
|
unsigned long code;
|
2018-05-29 10:27:41 +02:00
|
|
|
char *database;
|
2020-01-18 03:50:54 +01:00
|
|
|
char *exchange_payto_uri;
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2021-08-03 21:58:36 +02:00
|
|
|
GNUNET_assert (0 ==
|
|
|
|
strncasecmp (config_section,
|
|
|
|
"exchange-account-",
|
|
|
|
strlen ("exchange-account-")));
|
2018-02-22 14:51:12 +01:00
|
|
|
cfg = GNUNET_CONFIGURATION_create ();
|
|
|
|
|
2019-09-15 10:27:39 +02:00
|
|
|
if (GNUNET_OK !=
|
2021-08-03 21:58:36 +02:00
|
|
|
GNUNET_CONFIGURATION_load (cfg,
|
|
|
|
config_filename))
|
2019-09-15 10:27:39 +02:00
|
|
|
{
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-01-13 00:27:48 +01:00
|
|
|
GNUNET_break (0);
|
|
|
|
return GNUNET_SYSERR;
|
2019-09-15 10:27:39 +02:00
|
|
|
}
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_string (cfg,
|
|
|
|
"bank",
|
|
|
|
"DATABASE",
|
|
|
|
&database))
|
2018-05-29 10:27:41 +02:00
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"bank",
|
|
|
|
"DATABASE");
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-01-13 00:27:48 +01:00
|
|
|
GNUNET_break (0);
|
|
|
|
return GNUNET_SYSERR;
|
2018-05-29 10:27:41 +02:00
|
|
|
}
|
|
|
|
|
2020-01-18 03:50:54 +01:00
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_string (cfg,
|
|
|
|
config_section,
|
2020-01-19 17:03:19 +01:00
|
|
|
"PAYTO_URI",
|
2020-01-18 03:50:54 +01:00
|
|
|
&exchange_payto_uri))
|
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
config_section,
|
2020-01-19 17:03:19 +01:00
|
|
|
"PAYTO_URI");
|
2020-01-18 03:50:54 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
|
2019-09-15 10:27:39 +02:00
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_number (cfg,
|
|
|
|
"bank",
|
|
|
|
"HTTP_PORT",
|
|
|
|
&port))
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"bank",
|
|
|
|
"HTTP_PORT");
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2019-09-15 10:27:39 +02:00
|
|
|
GNUNET_free (database);
|
2020-01-13 00:27:48 +01:00
|
|
|
GNUNET_break (0);
|
|
|
|
return GNUNET_SYSERR;
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
|
|
|
|
2020-01-13 00:27:48 +01:00
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_NETWORK_test_port_free (IPPROTO_TCP,
|
|
|
|
(uint16_t) port))
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
|
|
|
fprintf (stderr,
|
|
|
|
"Required port %llu not available, skipping.\n",
|
2019-08-25 16:18:24 +02:00
|
|
|
port);
|
2020-01-13 00:27:48 +01:00
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_free (database);
|
2020-01-16 20:44:35 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-01-13 00:27:48 +01:00
|
|
|
return GNUNET_SYSERR;
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* DB preparation */
|
2020-03-19 21:44:54 +01:00
|
|
|
if (GNUNET_YES == reset_db)
|
2018-02-22 14:51:12 +01:00
|
|
|
{
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Flushing bank database\n");
|
2020-03-19 21:44:54 +01:00
|
|
|
if (NULL ==
|
|
|
|
(dbreset_proc = GNUNET_OS_start_process (
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_OS_INHERIT_STD_ERR,
|
2020-03-19 21:44:54 +01:00
|
|
|
NULL, NULL, NULL,
|
|
|
|
"taler-bank-manage",
|
|
|
|
"taler-bank-manage",
|
|
|
|
"-c", config_filename,
|
|
|
|
"--with-db", database,
|
|
|
|
"django",
|
|
|
|
"flush",
|
|
|
|
"--no-input", NULL)))
|
|
|
|
{
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"Failed to flush the bank db.\n");
|
|
|
|
GNUNET_free (database);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
2018-02-22 14:51:12 +01:00
|
|
|
|
2020-03-19 21:44:54 +01:00
|
|
|
if (GNUNET_SYSERR ==
|
|
|
|
GNUNET_OS_process_wait_status (dbreset_proc,
|
|
|
|
&type,
|
|
|
|
&code))
|
|
|
|
{
|
|
|
|
GNUNET_OS_process_destroy (dbreset_proc);
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_free (database);
|
2020-03-19 21:44:54 +01:00
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
if ( (type == GNUNET_OS_PROCESS_EXITED) &&
|
|
|
|
(0 != code) )
|
|
|
|
{
|
|
|
|
fprintf (stderr,
|
2020-10-30 22:12:02 +01:00
|
|
|
"Failed to setup database `%s'\n",
|
|
|
|
database);
|
2020-03-19 21:44:54 +01:00
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_free (database);
|
2020-03-19 21:44:54 +01:00
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_free (database);
|
2020-03-19 21:44:54 +01:00
|
|
|
if ( (type != GNUNET_OS_PROCESS_EXITED) ||
|
|
|
|
(0 != code) )
|
|
|
|
{
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
|
|
|
|
"Unexpected error running `taler-bank-manage django flush'!\n");
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
2018-02-22 14:51:12 +01:00
|
|
|
GNUNET_OS_process_destroy (dbreset_proc);
|
|
|
|
}
|
2020-01-13 18:16:01 +01:00
|
|
|
{
|
2021-08-03 21:58:36 +02:00
|
|
|
char *csn;
|
|
|
|
|
|
|
|
GNUNET_asprintf (&csn,
|
|
|
|
"exchange-accountcredentials-%s",
|
|
|
|
&config_section[strlen ("exchange-account-")]);
|
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
|
|
|
TALER_BANK_auth_parse_cfg (cfg,
|
|
|
|
csn,
|
|
|
|
&bc->exchange_auth))
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
|
|
|
GNUNET_free (csn);
|
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
GNUNET_free (csn);
|
2020-01-13 18:16:01 +01:00
|
|
|
}
|
2020-01-16 20:44:35 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
2020-01-18 03:50:54 +01:00
|
|
|
bc->exchange_payto = exchange_payto_uri;
|
2020-01-17 12:15:57 +01:00
|
|
|
bc->user42_payto = "payto://x-taler-bank/localhost/42";
|
|
|
|
bc->user43_payto = "payto://x-taler-bank/localhost/43";
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Using pybank %s on port %u\n",
|
|
|
|
bc->exchange_auth.wire_gateway_url,
|
|
|
|
(unsigned int) port);
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"exchange payto: %s\n",
|
2020-01-17 12:15:57 +01:00
|
|
|
bc->exchange_payto);
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"user42_payto: %s\n",
|
2020-01-17 12:15:57 +01:00
|
|
|
bc->user42_payto);
|
2020-10-30 22:12:02 +01:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"user43_payto: %s\n",
|
2020-01-17 12:15:57 +01:00
|
|
|
bc->user43_payto);
|
2020-01-13 00:27:48 +01:00
|
|
|
return GNUNET_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-11-07 19:37:06 +01:00
|
|
|
enum GNUNET_GenericReturnValue
|
2020-01-13 00:27:48 +01:00
|
|
|
TALER_TESTING_prepare_fakebank (const char *config_filename,
|
|
|
|
const char *config_section,
|
|
|
|
struct TALER_TESTING_BankConfiguration *bc)
|
|
|
|
{
|
|
|
|
struct GNUNET_CONFIGURATION_Handle *cfg;
|
2020-01-17 02:23:38 +01:00
|
|
|
unsigned long long fakebank_port;
|
2020-01-18 03:50:54 +01:00
|
|
|
char *exchange_payto_uri;
|
2020-01-13 00:27:48 +01:00
|
|
|
|
|
|
|
cfg = GNUNET_CONFIGURATION_create ();
|
|
|
|
if (GNUNET_OK != GNUNET_CONFIGURATION_load (cfg,
|
|
|
|
config_filename))
|
|
|
|
return GNUNET_SYSERR;
|
2020-01-17 01:23:32 +01:00
|
|
|
|
|
|
|
if (GNUNET_OK !=
|
2020-01-17 02:23:38 +01:00
|
|
|
GNUNET_CONFIGURATION_get_value_number (cfg,
|
|
|
|
"BANK",
|
|
|
|
"HTTP_PORT",
|
|
|
|
&fakebank_port))
|
2020-01-17 01:23:32 +01:00
|
|
|
{
|
2020-01-17 02:23:38 +01:00
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
"BANK",
|
|
|
|
"HTTP_PORT");
|
2020-01-17 01:23:32 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
2020-01-18 03:50:54 +01:00
|
|
|
if (GNUNET_OK !=
|
|
|
|
GNUNET_CONFIGURATION_get_value_string (cfg,
|
|
|
|
config_section,
|
2020-01-19 17:03:19 +01:00
|
|
|
"PAYTO_URI",
|
2020-01-18 03:50:54 +01:00
|
|
|
&exchange_payto_uri))
|
|
|
|
{
|
|
|
|
GNUNET_log_config_missing (GNUNET_ERROR_TYPE_WARNING,
|
|
|
|
config_section,
|
2020-01-19 17:03:19 +01:00
|
|
|
"PAYTO_URI");
|
2020-01-18 03:50:54 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
{
|
2020-01-18 18:04:59 +01:00
|
|
|
char *exchange_xtalerbank_account;
|
2020-01-17 01:23:32 +01:00
|
|
|
|
2020-01-18 18:04:59 +01:00
|
|
|
exchange_xtalerbank_account
|
|
|
|
= TALER_xtalerbank_account_from_payto (exchange_payto_uri);
|
|
|
|
if (NULL == exchange_xtalerbank_account)
|
|
|
|
{
|
|
|
|
GNUNET_break (0);
|
2020-03-28 12:53:10 +01:00
|
|
|
GNUNET_free (exchange_payto_uri);
|
2020-01-18 18:04:59 +01:00
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
|
|
|
GNUNET_asprintf (&bc->exchange_auth.wire_gateway_url,
|
|
|
|
"http://localhost:%u/%s/",
|
|
|
|
(unsigned int) fakebank_port,
|
|
|
|
exchange_xtalerbank_account);
|
|
|
|
GNUNET_free (exchange_xtalerbank_account);
|
|
|
|
}
|
2020-01-17 02:23:38 +01:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO,
|
|
|
|
"Using fakebank %s on port %u\n",
|
|
|
|
bc->exchange_auth.wire_gateway_url,
|
|
|
|
(unsigned int) fakebank_port);
|
2020-01-17 01:23:32 +01:00
|
|
|
|
2020-01-13 00:27:48 +01:00
|
|
|
GNUNET_CONFIGURATION_destroy (cfg);
|
|
|
|
if (GNUNET_OK !=
|
2020-01-18 04:00:35 +01:00
|
|
|
TALER_TESTING_url_port_free (bc->exchange_auth.wire_gateway_url))
|
2020-01-13 00:27:48 +01:00
|
|
|
{
|
2020-01-18 04:00:35 +01:00
|
|
|
GNUNET_free (bc->exchange_auth.wire_gateway_url);
|
|
|
|
bc->exchange_auth.wire_gateway_url = NULL;
|
2020-03-28 12:53:10 +01:00
|
|
|
GNUNET_free (exchange_payto_uri);
|
2020-01-13 00:27:48 +01:00
|
|
|
return GNUNET_SYSERR;
|
|
|
|
}
|
2020-01-17 01:23:32 +01:00
|
|
|
/* Now we know it's the fake bank, for purpose of authentication, we
|
|
|
|
* don't have any auth. */
|
2020-01-13 18:16:01 +01:00
|
|
|
bc->exchange_auth.method = TALER_BANK_AUTH_NONE;
|
2020-01-18 03:50:54 +01:00
|
|
|
bc->exchange_payto = exchange_payto_uri;
|
2020-01-17 02:23:38 +01:00
|
|
|
bc->user42_payto = "payto://x-taler-bank/localhost/42";
|
|
|
|
bc->user43_payto = "payto://x-taler-bank/localhost/43";
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "exchange payto: %s\n",
|
|
|
|
bc->exchange_payto);
|
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "user42_payto: %s\n",
|
|
|
|
bc->user42_payto);
|
2020-06-06 02:02:48 +02:00
|
|
|
GNUNET_log (GNUNET_ERROR_TYPE_INFO, "user43_payto: %s\n",
|
2020-01-17 02:23:38 +01:00
|
|
|
bc->user43_payto);
|
2020-01-13 00:27:48 +01:00
|
|
|
return GNUNET_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
json_t *
|
|
|
|
TALER_TESTING_make_wire_details (const char *payto)
|
|
|
|
{
|
2022-02-07 12:33:35 +01:00
|
|
|
struct TALER_WireSaltP salt;
|
2021-10-13 18:52:59 +02:00
|
|
|
|
|
|
|
/* salt must be constant for aggregation tests! */
|
|
|
|
memset (&salt,
|
|
|
|
47,
|
|
|
|
sizeof (salt));
|
2021-07-31 21:48:36 +02:00
|
|
|
return GNUNET_JSON_PACK (
|
|
|
|
GNUNET_JSON_pack_string ("payto_uri",
|
|
|
|
payto),
|
2021-10-13 18:52:59 +02:00
|
|
|
GNUNET_JSON_pack_data_auto ("salt",
|
|
|
|
&salt));
|
2018-02-22 14:51:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-13 00:27:48 +01:00
|
|
|
/* end of testing_api_helpers_bank.c */
|