2021-01-10 13:27:33 +01:00
|
|
|
/*
|
|
|
|
This file is part of GNUnet
|
2022-05-30 23:55:55 +02:00
|
|
|
Copyright (C) 2020, 2021, 2022 Taler Systems SA
|
2021-01-10 13:27:33 +01:00
|
|
|
|
|
|
|
GNUnet is free software: you can redistribute it and/or modify it
|
|
|
|
under the terms of the GNU Affero General Public License as published
|
|
|
|
by the Free Software Foundation, either version 3 of the License,
|
|
|
|
or (at your option) any later version.
|
|
|
|
|
|
|
|
GNUnet 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
|
|
|
|
Affero General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL3.0-or-later
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @file exchangedb/irbt_callbacks.c
|
|
|
|
* @brief callbacks used by postgres_insert_records_by_table, to be
|
|
|
|
* inlined into the plugin
|
|
|
|
* @author Christian Grothoff
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with denominations records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_denominations (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2022-02-21 00:23:23 +01:00
|
|
|
struct TALER_DenominationHashP denom_hash;
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:06:18 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&denom_hash),
|
2022-02-28 21:02:12 +01:00
|
|
|
GNUNET_PQ_query_param_uint32 (
|
|
|
|
&td->details.denominations.denom_type),
|
|
|
|
GNUNET_PQ_query_param_uint32 (
|
|
|
|
&td->details.denominations.age_mask),
|
2021-10-25 10:52:15 +02:00
|
|
|
TALER_PQ_query_param_denom_pub (
|
|
|
|
&td->details.denominations.denom_pub),
|
2021-01-10 18:06:18 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.denominations.master_sig),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:06:18 +01:00
|
|
|
&td->details.denominations.valid_from),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:06:18 +01:00
|
|
|
&td->details.denominations.expire_withdraw),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:06:18 +01:00
|
|
|
&td->details.denominations.expire_deposit),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:06:18 +01:00
|
|
|
&td->details.denominations.expire_legal),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.denominations.coin),
|
|
|
|
TALER_PQ_query_param_amount (
|
2022-02-17 15:10:14 +01:00
|
|
|
&td->details.denominations.fees.withdraw),
|
2021-01-10 18:06:18 +01:00
|
|
|
TALER_PQ_query_param_amount (
|
2022-02-17 15:10:14 +01:00
|
|
|
&td->details.denominations.fees.deposit),
|
2021-01-10 18:06:18 +01:00
|
|
|
TALER_PQ_query_param_amount (
|
2022-02-17 15:10:14 +01:00
|
|
|
&td->details.denominations.fees.refresh),
|
2021-01-10 18:06:18 +01:00
|
|
|
TALER_PQ_query_param_amount (
|
2022-02-17 15:10:14 +01:00
|
|
|
&td->details.denominations.fees.refund),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-10-25 10:52:15 +02:00
|
|
|
TALER_denom_pub_hash (
|
|
|
|
&td->details.denominations.denom_pub,
|
2021-01-10 18:06:18 +01:00
|
|
|
&denom_hash);
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_denominations",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with denomination_revocations records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
2021-08-23 00:00:32 +02:00
|
|
|
irbt_cb_table_denomination_revocations (
|
|
|
|
struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
2021-01-10 13:27:33 +01:00
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:06:18 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.denomination_revocations.master_sig),
|
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.denomination_revocations.denominations_serial),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_denomination_revocations",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-10-30 21:26:40 +02:00
|
|
|
/**
|
|
|
|
* Function called with denominations records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wire_targets (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2022-02-21 00:23:23 +01:00
|
|
|
struct TALER_PaytoHashP payto_hash;
|
2021-10-30 21:26:40 +02:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
2022-02-28 23:18:40 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-10-30 21:26:40 +02:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&payto_hash),
|
|
|
|
GNUNET_PQ_query_param_string (
|
|
|
|
td->details.wire_targets.payto_uri),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wire_targets.kyc_ok),
|
2022-02-28 23:18:40 +01:00
|
|
|
NULL == td->details.wire_targets.external_id
|
|
|
|
? GNUNET_PQ_query_param_null ()
|
|
|
|
: GNUNET_PQ_query_param_string (
|
2021-11-16 19:31:27 +01:00
|
|
|
td->details.wire_targets.external_id),
|
2021-10-30 21:26:40 +02:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
TALER_payto_hash (
|
|
|
|
td->details.wire_targets.payto_uri,
|
|
|
|
&payto_hash);
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_wire_targets",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-10 13:27:33 +01:00
|
|
|
/**
|
|
|
|
* Function called with reserves records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_reserves (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:06:18 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.reserves.reserve_pub),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.reserves.expiration_date),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.reserves.gc_date),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_reserves",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with reserves_in records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_reserves_in (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.reserves_in.wire_reference),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.reserves_in.credit),
|
2022-03-03 23:52:08 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_in.sender_account_h_payto),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_string (
|
|
|
|
td->details.reserves_in.exchange_account_section),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.reserves_in.execution_date),
|
2021-12-19 13:43:33 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.reserves_in.reserve_pub),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_reserves_in",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with reserves_close records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_reserves_close (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.reserves_close.execution_date),
|
2021-10-31 13:27:50 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_close.wtid),
|
2022-03-03 23:52:08 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_close.sender_account_h_payto),
|
2021-01-10 18:40:39 +01:00
|
|
|
TALER_PQ_query_param_amount (&td->details.reserves_close.amount),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.reserves_close.closing_fee),
|
2021-12-19 13:43:33 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_close.reserve_pub),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_reserves_close",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with reserves_out records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_reserves_out (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-10-31 13:27:50 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_out.h_blind_ev),
|
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.reserves_out.denominations_serial),
|
2021-10-31 18:12:54 +01:00
|
|
|
TALER_PQ_query_param_blinded_denom_sig (
|
2021-10-25 10:52:15 +02:00
|
|
|
&td->details.reserves_out.denom_sig),
|
2021-12-25 13:56:33 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.reserves_out.reserve_uuid),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.reserves_out.reserve_sig),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.reserves_out.execution_date),
|
2021-10-31 13:27:50 +01:00
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.reserves_out.amount_with_fee),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_reserves_out",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with auditors records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_auditors (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.auditors.auditor_pub),
|
|
|
|
GNUNET_PQ_query_param_string (td->details.auditors.auditor_name),
|
|
|
|
GNUNET_PQ_query_param_string (td->details.auditors.auditor_url),
|
2022-02-28 22:41:21 +01:00
|
|
|
GNUNET_PQ_query_param_bool (&td->details.auditors.is_active),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.auditors.last_change),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_auditors",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with auditor_denom_sigs records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_auditor_denom_sigs (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.auditor_denom_sigs.auditor_uuid),
|
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.auditor_denom_sigs.denominations_serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.auditor_denom_sigs.auditor_sig),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_auditor_denom_sigs",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with exchange_sign_keys records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_exchange_sign_keys (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.exchange_sign_keys.exchange_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.exchange_sign_keys.master_sig),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.exchange_sign_keys.meta.start),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.exchange_sign_keys.meta.expire_sign),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 18:40:39 +01:00
|
|
|
&td->details.exchange_sign_keys.meta.expire_legal),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_exchange_sign_keys",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with signkey_revocations records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_signkey_revocations (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.signkey_revocations.esk_serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.signkey_revocations.master_sig),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_signkey_revocations",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with known_coins records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_known_coins (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-10-31 13:27:50 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.known_coins.coin_pub),
|
2021-10-25 10:52:15 +02:00
|
|
|
TALER_PQ_query_param_denom_sig (
|
|
|
|
&td->details.known_coins.denom_sig),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.known_coins.denominations_serial),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_known_coins",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with refresh_commitments records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_refresh_commitments (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.refresh_commitments.rc),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.refresh_commitments.old_coin_sig),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.refresh_commitments.amount_with_fee),
|
|
|
|
GNUNET_PQ_query_param_uint32 (
|
|
|
|
&td->details.refresh_commitments.noreveal_index),
|
2021-12-25 13:56:33 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.refresh_commitments.old_coin_pub),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_refresh_commitments",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with refresh_revealed_coins records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
2021-08-23 00:00:32 +02:00
|
|
|
irbt_cb_table_refresh_revealed_coins (
|
|
|
|
struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
2021-01-10 13:27:33 +01:00
|
|
|
{
|
2021-01-10 18:40:39 +01:00
|
|
|
struct GNUNET_HashCode h_coin_ev;
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint32 (
|
|
|
|
&td->details.refresh_revealed_coins.freshcoin_index),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.refresh_revealed_coins.link_sig),
|
|
|
|
GNUNET_PQ_query_param_fixed_size (
|
|
|
|
td->details.refresh_revealed_coins.coin_ev,
|
|
|
|
td->details.refresh_revealed_coins.
|
|
|
|
coin_ev_size),
|
2021-01-13 19:47:45 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&h_coin_ev),
|
2021-10-31 18:12:54 +01:00
|
|
|
TALER_PQ_query_param_blinded_denom_sig (
|
2021-10-25 10:52:15 +02:00
|
|
|
&td->details.refresh_revealed_coins.ev_sig),
|
2022-02-10 23:39:00 +01:00
|
|
|
TALER_PQ_query_param_exchange_withdraw_values (
|
|
|
|
&td->details.refresh_revealed_coins.ewv),
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.refresh_revealed_coins.denominations_serial),
|
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.refresh_revealed_coins.melt_serial_id),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-01-10 18:40:39 +01:00
|
|
|
GNUNET_CRYPTO_hash (td->details.refresh_revealed_coins.coin_ev,
|
|
|
|
td->details.refresh_revealed_coins.coin_ev_size,
|
|
|
|
&h_coin_ev);
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_refresh_revealed_coins",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with refresh_transfer_keys records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
2021-01-10 21:42:25 +01:00
|
|
|
irbt_cb_table_refresh_transfer_keys (
|
|
|
|
struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
2021-01-10 13:27:33 +01:00
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.refresh_transfer_keys.tp),
|
|
|
|
GNUNET_PQ_query_param_fixed_size (
|
|
|
|
&td->details.refresh_transfer_keys.tprivs[0],
|
|
|
|
(TALER_CNC_KAPPA - 1)
|
|
|
|
* sizeof (struct TALER_TransferPrivateKeyP)),
|
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.refresh_transfer_keys.melt_serial_id),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_refresh_transfer_keys",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with deposits records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_deposits (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-10-30 21:26:40 +02:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.deposits.shard),
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.deposits.known_coin_id),
|
2022-03-18 01:57:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.deposits.coin_pub),
|
2021-01-10 21:42:25 +01:00
|
|
|
TALER_PQ_query_param_amount (&td->details.deposits.amount_with_fee),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.deposits.wallet_timestamp),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
2021-01-10 21:42:25 +01:00
|
|
|
&td->details.deposits.exchange_timestamp),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.deposits.refund_deadline),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.deposits.wire_deadline),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.deposits.merchant_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.deposits.h_contract_terms),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.deposits.coin_sig),
|
2021-10-30 21:26:40 +02:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.deposits.wire_salt),
|
2022-03-03 23:52:08 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.deposits.wire_target_h_payto),
|
2022-02-28 22:41:21 +01:00
|
|
|
GNUNET_PQ_query_param_bool (td->details.deposits.extension_blocked),
|
2022-02-28 22:46:24 +01:00
|
|
|
0 == td->details.deposits.extension_details_serial_id
|
|
|
|
? GNUNET_PQ_query_param_null ()
|
|
|
|
: GNUNET_PQ_query_param_uint64 (
|
2021-11-06 19:04:54 +01:00
|
|
|
&td->details.deposits.extension_details_serial_id),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_deposits",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with refunds records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_refunds (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2022-03-26 10:46:37 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.refunds.coin_pub),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.refunds.merchant_sig),
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.refunds.rtransaction_id),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.refunds.amount_with_fee),
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.refunds.deposit_serial_id),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_refunds",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wire_out records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wire_out (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.wire_out.execution_date),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.wire_out.wtid_raw),
|
2022-03-03 23:52:08 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wire_out.wire_target_h_payto),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_string (
|
|
|
|
td->details.wire_out.exchange_account_section),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.wire_out.amount),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_wire_out",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with aggregation_tracking records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_aggregation_tracking (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->details.aggregation_tracking.deposit_serial_id),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.aggregation_tracking.wtid_raw),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_aggregation_tracking",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wire_fee records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wire_fee (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_string (td->details.wire_fee.wire_method),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.wire_fee.start_date),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.wire_fee.end_date),
|
2022-03-05 14:36:49 +01:00
|
|
|
TALER_PQ_query_param_amount (&td->details.wire_fee.fees.wire),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.wire_fee.fees.closing),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.wire_fee.fees.wad),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.wire_fee.master_sig),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_wire_fee",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-03-05 14:36:49 +01:00
|
|
|
/**
|
|
|
|
* Function called with wire_fee records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_global_fee (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
2022-03-05 16:16:38 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (
|
|
|
|
&td->serial),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.global_fee.start_date),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.global_fee.end_date),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.global_fee.fees.history),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.global_fee.fees.kyc),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.global_fee.fees.account),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.global_fee.fees.purse),
|
|
|
|
GNUNET_PQ_query_param_relative_time (
|
|
|
|
&td->details.global_fee.purse_timeout),
|
|
|
|
GNUNET_PQ_query_param_relative_time (
|
|
|
|
&td->details.global_fee.kyc_timeout),
|
|
|
|
GNUNET_PQ_query_param_relative_time (
|
|
|
|
&td->details.global_fee.history_expiration),
|
|
|
|
GNUNET_PQ_query_param_uint32 (
|
|
|
|
&td->details.global_fee.purse_account_limit),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.global_fee.master_sig),
|
2022-03-05 14:36:49 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_global_fee",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-10 13:27:33 +01:00
|
|
|
/**
|
|
|
|
* Function called with recoup records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_recoup (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.recoup.coin_sig),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.recoup.coin_blind),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.recoup.amount),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.recoup.timestamp),
|
2022-03-18 01:57:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.recoup.coin_pub),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.recoup.reserve_out_serial_id),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_recoup",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with recoup_refresh records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_recoup_refresh (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
2021-01-10 17:07:09 +01:00
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.recoup_refresh.coin_sig),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.recoup_refresh.coin_blind),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.recoup_refresh.amount),
|
2021-12-14 16:04:32 +01:00
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.recoup_refresh.timestamp),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.recoup_refresh.known_coin_id),
|
2022-03-18 01:57:39 +01:00
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.recoup.coin_pub),
|
2021-01-10 21:42:25 +01:00
|
|
|
GNUNET_PQ_query_param_uint64 (&td->details.recoup_refresh.rrc_serial),
|
2021-01-10 17:07:09 +01:00
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
2021-08-23 00:00:32 +02:00
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
2021-01-10 17:27:46 +01:00
|
|
|
"insert_into_table_recoup_refresh",
|
2021-01-10 17:07:09 +01:00
|
|
|
params);
|
2021-01-10 13:27:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-03-05 13:36:50 +01:00
|
|
|
/**
|
|
|
|
* Function called with extensions records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_extensions (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_string (td->details.extensions.name),
|
|
|
|
NULL == td->details.extensions.config ?
|
|
|
|
GNUNET_PQ_query_param_null () :
|
|
|
|
GNUNET_PQ_query_param_string (td->details.extensions.config),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_extensions",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with extension_details records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_extension_details (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
NULL ==
|
|
|
|
td->details.extension_details.extension_options ?
|
|
|
|
GNUNET_PQ_query_param_null () :
|
|
|
|
GNUNET_PQ_query_param_string (
|
|
|
|
td->details.extension_details.extension_options),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_extension_details",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-05-30 23:55:55 +02:00
|
|
|
/**
|
|
|
|
* Function called with purse_requests records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_purse_requests (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.purse_requests.merge_pub),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.purse_requests.purse_creation),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.purse_requests.purse_expiration),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.purse_requests.h_contract_terms),
|
|
|
|
GNUNET_PQ_query_param_uint32 (&td->details.purse_requests.age_limit),
|
|
|
|
GNUNET_PQ_query_param_uint32 (&td->details.purse_requests.flags),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.purse_requests.amount_with_fee),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.purse_requests.purse_fee),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.purse_requests.purse_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_purse_requests",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with purse_merges records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_purse_merges (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.purse_merges.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.purse_merges.purse_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.purse_merges.merge_sig),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.purse_merges.merge_timestamp),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_purse_merges",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with purse_deposits records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_purse_deposits (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.purse_deposits.purse_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.purse_deposits.coin_pub),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.purse_deposits.amount_with_fee),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.purse_deposits.coin_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_purse_deposits",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with account_mergers records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_account_mergers (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.account_merges.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.account_merges.reserve_sig),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.account_merges.purse_pub),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_account_mergers",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with history_requests records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_history_requests (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.history_requests.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.history_requests.request_timestamp),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.history_requests.reserve_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_history_requests",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with close_requests records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_close_requests (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.close_requests.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.close_requests.close_timestamp),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.close_requests.reserve_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_close_requests",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wads_out records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wads_out (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.wads_out.wad_id),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.wads_out.amount),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.wads_out.execution_time),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_wads_out",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wads_out_entries records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wads_out_entries (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_out_entries.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_out_entries.purse_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_out_entries.h_contract),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.wads_out_entries.purse_expiration),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.wads_out_entries.merge_timestamp),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.wads_out_entries.amount_with_fee),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.wads_out_entries.deposit_fees),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_out_entries.reserve_sig),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_out_entries.purse_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_wads_out_entries",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wads_in records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wads_in (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (&td->details.wads_in.wad_id),
|
|
|
|
GNUNET_PQ_query_param_string (td->details.wads_in.origin_exchange_url),
|
|
|
|
TALER_PQ_query_param_amount (&td->details.wads_in.amount),
|
|
|
|
GNUNET_PQ_query_param_timestamp (&td->details.wads_in.arrival_time),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_wads_in",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function called with wads_in_entries records to insert into table.
|
|
|
|
*
|
|
|
|
* @param pg plugin context
|
|
|
|
* @param td record to insert
|
|
|
|
*/
|
|
|
|
static enum GNUNET_DB_QueryStatus
|
|
|
|
irbt_cb_table_wads_in_entries (struct PostgresClosure *pg,
|
|
|
|
const struct TALER_EXCHANGEDB_TableData *td)
|
|
|
|
{
|
|
|
|
struct GNUNET_PQ_QueryParam params[] = {
|
|
|
|
GNUNET_PQ_query_param_uint64 (&td->serial),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_in_entries.reserve_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_in_entries.purse_pub),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_in_entries.h_contract),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.wads_in_entries.purse_expiration),
|
|
|
|
GNUNET_PQ_query_param_timestamp (
|
|
|
|
&td->details.wads_in_entries.merge_timestamp),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.wads_in_entries.amount_with_fee),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.wads_in_entries.wad_fee),
|
|
|
|
TALER_PQ_query_param_amount (
|
|
|
|
&td->details.wads_in_entries.deposit_fees),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_in_entries.reserve_sig),
|
|
|
|
GNUNET_PQ_query_param_auto_from_type (
|
|
|
|
&td->details.wads_in_entries.purse_sig),
|
|
|
|
GNUNET_PQ_query_param_end
|
|
|
|
};
|
|
|
|
|
|
|
|
return GNUNET_PQ_eval_prepared_non_select (pg->conn,
|
|
|
|
"insert_into_table_wads_in_entries",
|
|
|
|
params);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-01-10 13:27:33 +01:00
|
|
|
/* end of irbt_callbacks.c */
|