2178 lines
62 KiB
C
2178 lines
62 KiB
C
/*
|
|
This file is part of GNUnet
|
|
Copyright (C) 2020, 2021, 2022 Taler Systems SA
|
|
|
|
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/lrbt_callbacks.c
|
|
* @brief callbacks used by postgres_lookup_records_by_table, to be
|
|
* inlined into the plugin
|
|
* @author Christian Grothoff
|
|
*/
|
|
|
|
|
|
/**
|
|
* Function called with denominations table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_denominations (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_DENOMINATIONS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"denom_type",
|
|
&td.details.denominations.denom_type),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"age_mask",
|
|
&td.details.denominations.age_mask),
|
|
TALER_PQ_result_spec_denom_pub (
|
|
"denom_pub",
|
|
&td.details.denominations.denom_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"master_sig",
|
|
&td.details.denominations.master_sig),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"valid_from",
|
|
&td.details.denominations.valid_from),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"expire_withdraw",
|
|
&td.details.denominations.
|
|
expire_withdraw),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"expire_deposit",
|
|
&td.details.denominations.
|
|
expire_deposit),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"expire_legal",
|
|
&td.details.denominations.expire_legal),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"coin",
|
|
&td.details.denominations.coin),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"fee_withdraw",
|
|
&td.details.denominations.fees.withdraw),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"fee_deposit",
|
|
&td.details.denominations.fees.deposit),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"fee_refresh",
|
|
&td.details.denominations.fees.refresh),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"fee_refund",
|
|
&td.details.denominations.fees.refund),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with denomination_revocations table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_denomination_revocations (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_DENOMINATION_REVOCATIONS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"denominations_serial",
|
|
&td.details.denomination_revocations.denominations_serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"master_sig",
|
|
&td.details.denomination_revocations.master_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wire_targets table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wire_targets (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WIRE_TARGETS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_string ("payto_uri",
|
|
&td.details.wire_targets.payto_uri),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with reserves table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_reserves (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RESERVES
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("reserve_pub",
|
|
&td.details.reserves.reserve_pub),
|
|
GNUNET_PQ_result_spec_timestamp ("expiration_date",
|
|
&td.details.reserves.expiration_date),
|
|
GNUNET_PQ_result_spec_timestamp ("gc_date",
|
|
&td.details.reserves.gc_date),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with reserves_in table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_reserves_in (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RESERVES_IN
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.reserves_in.reserve_pub),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"wire_reference",
|
|
&td.details.reserves_in.wire_reference),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"credit",
|
|
&td.details.reserves_in.credit),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wire_source_h_payto",
|
|
&td.details.reserves_in.sender_account_h_payto),
|
|
GNUNET_PQ_result_spec_string (
|
|
"exchange_account_section",
|
|
&td.details.reserves_in.exchange_account_section),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"execution_date",
|
|
&td.details.reserves_in.execution_date),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with reserves_close table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_reserves_close (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RESERVES_CLOSE
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.reserves_close.reserve_pub),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"execution_date",
|
|
&td.details.reserves_close.execution_date),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wtid",
|
|
&td.details.reserves_close.wtid),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wire_target_h_payto",
|
|
&td.details.reserves_close.sender_account_h_payto),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount",
|
|
&td.details.reserves_close.amount),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"closing_fee",
|
|
&td.details.reserves_close.closing_fee),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with reserves_out table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_reserves_out (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RESERVES_OUT
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"h_blind_ev",
|
|
&td.details.reserves_out.h_blind_ev),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"denominations_serial",
|
|
&td.details.reserves_out.denominations_serial),
|
|
TALER_PQ_result_spec_blinded_denom_sig (
|
|
"denom_sig",
|
|
&td.details.reserves_out.denom_sig),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"reserve_uuid",
|
|
&td.details.reserves_out.reserve_uuid),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.reserves_out.reserve_sig),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"execution_date",
|
|
&td.details.reserves_out.execution_date),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.reserves_out.amount_with_fee),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with auditors table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_auditors (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_AUDITORS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("auditor_pub",
|
|
&td.details.auditors.auditor_pub),
|
|
GNUNET_PQ_result_spec_string ("auditor_url",
|
|
&td.details.auditors.auditor_url),
|
|
GNUNET_PQ_result_spec_string ("auditor_name",
|
|
&td.details.auditors.auditor_name),
|
|
GNUNET_PQ_result_spec_bool ("is_active",
|
|
&td.details.auditors.is_active),
|
|
GNUNET_PQ_result_spec_timestamp ("last_change",
|
|
&td.details.auditors.last_change),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with auditor_denom_sigs table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_auditor_denom_sigs (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_AUDITOR_DENOM_SIGS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"auditor_uuid",
|
|
&td.details.auditor_denom_sigs.auditor_uuid),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"denominations_serial",
|
|
&td.details.auditor_denom_sigs.denominations_serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"auditor_sig",
|
|
&td.details.auditor_denom_sigs.auditor_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with exchange_sign_keys table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_exchange_sign_keys (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_EXCHANGE_SIGN_KEYS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("exchange_pub",
|
|
&td.details.exchange_sign_keys.
|
|
exchange_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type ("master_sig",
|
|
&td.details.exchange_sign_keys.
|
|
master_sig),
|
|
GNUNET_PQ_result_spec_timestamp ("valid_from",
|
|
&td.details.exchange_sign_keys.meta.
|
|
start),
|
|
GNUNET_PQ_result_spec_timestamp ("expire_sign",
|
|
&td.details.exchange_sign_keys.meta.
|
|
expire_sign),
|
|
GNUNET_PQ_result_spec_timestamp ("expire_legal",
|
|
&td.details.exchange_sign_keys.meta.
|
|
expire_legal),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with signkey_revocations table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_signkey_revocations (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_SIGNKEY_REVOCATIONS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 ("esk_serial",
|
|
&td.details.signkey_revocations.esk_serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("master_sig",
|
|
&td.details.signkey_revocations.
|
|
master_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with known_coins table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_known_coins (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_KNOWN_COINS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.known_coins.coin_pub),
|
|
TALER_PQ_result_spec_denom_sig (
|
|
"denom_sig",
|
|
&td.details.known_coins.denom_sig),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"denominations_serial",
|
|
&td.details.known_coins.denominations_serial),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with refresh_commitments table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_refresh_commitments (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_REFRESH_COMMITMENTS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"rc",
|
|
&td.details.refresh_commitments.rc),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"old_coin_sig",
|
|
&td.details.refresh_commitments.old_coin_sig),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.refresh_commitments.amount_with_fee),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"noreveal_index",
|
|
&td.details.refresh_commitments.noreveal_index),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"old_coin_pub",
|
|
&td.details.refresh_commitments.old_coin_pub),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with refresh_revealed_coins table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_refresh_revealed_coins (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_REFRESH_REVEALED_COINS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"freshcoin_index",
|
|
&td.details.refresh_revealed_coins.freshcoin_index),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"link_sig",
|
|
&td.details.refresh_revealed_coins.link_sig),
|
|
GNUNET_PQ_result_spec_variable_size (
|
|
"coin_ev",
|
|
(void **) &td.details.refresh_revealed_coins.coin_ev,
|
|
&td.details.refresh_revealed_coins.coin_ev_size),
|
|
TALER_PQ_result_spec_blinded_denom_sig (
|
|
"ev_sig",
|
|
&td.details.refresh_revealed_coins.ev_sig),
|
|
TALER_PQ_result_spec_exchange_withdraw_values (
|
|
"ewv",
|
|
&td.details.refresh_revealed_coins.ewv),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"denominations_serial",
|
|
&td.details.refresh_revealed_coins.denominations_serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"melt_serial_id",
|
|
&td.details.refresh_revealed_coins.melt_serial_id),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with refresh_transfer_keys table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_refresh_transfer_keys (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_REFRESH_TRANSFER_KEYS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
void *tpriv;
|
|
size_t tpriv_size;
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("transfer_pub",
|
|
&td.details.refresh_transfer_keys.tp),
|
|
GNUNET_PQ_result_spec_variable_size ("transfer_privs",
|
|
&tpriv,
|
|
&tpriv_size),
|
|
GNUNET_PQ_result_spec_uint64 ("melt_serial_id",
|
|
&td.details.refresh_transfer_keys.
|
|
melt_serial_id),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
/* Both conditions should be identical, but we conservatively also guard against
|
|
unwarranted changes to the structure here. */
|
|
if ( (tpriv_size !=
|
|
sizeof (td.details.refresh_transfer_keys.tprivs)) ||
|
|
(tpriv_size !=
|
|
(TALER_CNC_KAPPA - 1) * sizeof (struct TALER_TransferPrivateKeyP)) )
|
|
{
|
|
GNUNET_break (0);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
memcpy (&td.details.refresh_transfer_keys.tprivs[0],
|
|
tpriv,
|
|
tpriv_size);
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with deposits table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_deposits (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_DEPOSITS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
bool no_extension;
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"shard",
|
|
&td.details.deposits.shard),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"known_coin_id",
|
|
&td.details.deposits.known_coin_id),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.deposits.coin_pub),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.deposits.amount_with_fee),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"wallet_timestamp",
|
|
&td.details.deposits.wallet_timestamp),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"exchange_timestamp",
|
|
&td.details.deposits.exchange_timestamp),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"refund_deadline",
|
|
&td.details.deposits.refund_deadline),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"wire_deadline",
|
|
&td.details.deposits.wire_deadline),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"merchant_pub",
|
|
&td.details.deposits.merchant_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"h_contract_terms",
|
|
&td.details.deposits.h_contract_terms),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_sig",
|
|
&td.details.deposits.coin_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wire_salt",
|
|
&td.details.deposits.wire_salt),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wire_target_h_payto",
|
|
&td.details.deposits.wire_target_h_payto),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"extension_blocked",
|
|
&td.details.deposits.extension_blocked),
|
|
GNUNET_PQ_result_spec_allow_null (
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"extension_details_serial_id",
|
|
&td.details.deposits.extension_details_serial_id),
|
|
&no_extension),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with refunds table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_refunds (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_REFUNDS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.refunds.coin_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"merchant_sig",
|
|
&td.details.refunds.merchant_sig),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"rtransaction_id",
|
|
&td.details.refunds.rtransaction_id),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.refunds.amount_with_fee),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"deposit_serial_id",
|
|
&td.details.refunds.deposit_serial_id),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wire_out table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wire_out (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WIRE_OUT
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"execution_date",
|
|
&td.details.wire_out.execution_date),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wtid_raw",
|
|
&td.details.wire_out.wtid_raw),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wire_target_h_payto",
|
|
&td.details.wire_out.wire_target_h_payto),
|
|
GNUNET_PQ_result_spec_string (
|
|
"exchange_account_section",
|
|
&td.details.wire_out.exchange_account_section),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount",
|
|
&td.details.wire_out.amount),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with aggregation_tracking table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_aggregation_tracking (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_AGGREGATION_TRACKING
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"deposit_serial_id",
|
|
&td.details.aggregation_tracking.deposit_serial_id),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wtid_raw",
|
|
&td.details.aggregation_tracking.wtid_raw),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wire_fee table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wire_fee (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WIRE_FEE
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_string ("wire_method",
|
|
&td.details.wire_fee.wire_method),
|
|
GNUNET_PQ_result_spec_timestamp ("start_date",
|
|
&td.details.wire_fee.start_date),
|
|
GNUNET_PQ_result_spec_timestamp ("end_date",
|
|
&td.details.wire_fee.end_date),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT ("wire_fee",
|
|
&td.details.wire_fee.fees.wire),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT ("closing_fee",
|
|
&td.details.wire_fee.fees.closing),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT ("wad_fee",
|
|
&td.details.wire_fee.fees.wad),
|
|
GNUNET_PQ_result_spec_auto_from_type ("master_sig",
|
|
&td.details.wire_fee.master_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wire_fee table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_global_fee (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_GLOBAL_FEE
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"start_date",
|
|
&td.details.global_fee.start_date),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"end_date",
|
|
&td.details.global_fee.end_date),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"history_fee",
|
|
&td.details.global_fee.fees.history),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"kyc_fee",
|
|
&td.details.global_fee.fees.kyc),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"account_fee",
|
|
&td.details.global_fee.fees.account),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"purse_fee",
|
|
&td.details.global_fee.fees.purse),
|
|
GNUNET_PQ_result_spec_relative_time (
|
|
"purse_timeout",
|
|
&td.details.global_fee.purse_timeout),
|
|
GNUNET_PQ_result_spec_relative_time (
|
|
"kyc_timeout",
|
|
&td.details.global_fee.kyc_timeout),
|
|
GNUNET_PQ_result_spec_relative_time (
|
|
"history_expiration",
|
|
&td.details.global_fee.history_expiration),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"purse_account_limit",
|
|
&td.details.global_fee.purse_account_limit),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"master_sig",
|
|
&td.details.global_fee.master_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with recoup table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_recoup (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RECOUP
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("coin_sig",
|
|
&td.details.recoup.coin_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type ("coin_blind",
|
|
&td.details.recoup.coin_blind),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT ("amount",
|
|
&td.details.recoup.amount),
|
|
GNUNET_PQ_result_spec_timestamp ("recoup_timestamp",
|
|
&td.details.recoup.timestamp),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.recoup.coin_pub),
|
|
GNUNET_PQ_result_spec_uint64 ("reserve_out_serial_id",
|
|
&td.details.recoup.reserve_out_serial_id),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with recoup_refresh table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_recoup_refresh (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_RECOUP_REFRESH
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("serial",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type ("coin_sig",
|
|
&td.details.recoup_refresh.coin_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_blind",
|
|
&td.details.recoup_refresh.coin_blind),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT ("amount",
|
|
&td.details.recoup_refresh.amount),
|
|
GNUNET_PQ_result_spec_timestamp ("recoup_timestamp",
|
|
&td.details.recoup_refresh.timestamp),
|
|
GNUNET_PQ_result_spec_uint64 ("known_coin_id",
|
|
&td.details.recoup_refresh.known_coin_id),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.recoup_refresh.coin_pub),
|
|
GNUNET_PQ_result_spec_uint64 ("rrc_serial",
|
|
&td.details.recoup_refresh.rrc_serial),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with extensions table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_extensions (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_EXTENSIONS
|
|
};
|
|
bool no_config = false;
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("extension_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_string ("name",
|
|
&td.details.extensions.name),
|
|
GNUNET_PQ_result_spec_allow_null (
|
|
GNUNET_PQ_result_spec_string ("config",
|
|
&td.details.extensions.config),
|
|
&no_config),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with extension_details table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_extension_details (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_EXTENSION_DETAILS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
bool no_config = false;
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 ("extension_details_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_allow_null (
|
|
GNUNET_PQ_result_spec_string ("extension_options",
|
|
&td.details.extension_details.
|
|
extension_options),
|
|
&no_config),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with purse_requests table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_purse_requests (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_PURSE_REQUESTS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"purse_requests_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.purse_requests.purse_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"merge_pub",
|
|
&td.details.purse_requests.merge_pub),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"purse_creation",
|
|
&td.details.purse_requests.purse_creation),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"purse_expiration",
|
|
&td.details.purse_requests.purse_expiration),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"h_contract_terms",
|
|
&td.details.purse_requests.h_contract_terms),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"age_limit",
|
|
&td.details.purse_requests.age_limit),
|
|
GNUNET_PQ_result_spec_uint32 (
|
|
"flags",
|
|
&td.details.purse_requests.flags),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.purse_requests.amount_with_fee),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"purse_fee",
|
|
&td.details.purse_requests.purse_fee),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_sig",
|
|
&td.details.purse_requests.purse_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with purse_refunds table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_purse_refunds (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_PURSE_REFUNDS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"purse_refunds_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.purse_refunds.purse_pub),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with purse_merges table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_purse_merges (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_PURSE_MERGES
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"purse_merge_request_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"partner_serial_id",
|
|
&td.details.purse_merges.partner_serial_id),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.purse_merges.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.purse_merges.purse_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"merge_sig",
|
|
&td.details.purse_merges.merge_sig),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"merge_timestamp",
|
|
&td.details.purse_merges.merge_timestamp),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with purse_deposits table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_purse_deposits (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_PURSE_DEPOSITS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"purse_deposit_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"partner_serial_id",
|
|
&td.details.purse_deposits.partner_serial_id),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.purse_deposits.purse_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_pub",
|
|
&td.details.purse_deposits.coin_pub),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.purse_deposits.amount_with_fee),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"coin_sig",
|
|
&td.details.purse_deposits.coin_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with account_merges table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_account_merges (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_ACCOUNT_MERGES
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"account_merge_request_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.account_merges.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.account_merges.reserve_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.account_merges.purse_pub),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with history_requests table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_history_requests (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_HISTORY_REQUESTS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"history_request_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.history_requests.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.history_requests.reserve_sig),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"history_fee",
|
|
&td.details.history_requests.history_fee),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with close_requests table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_close_requests (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_CLOSE_REQUESTS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"close_request_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.close_requests.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.close_requests.reserve_sig),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"close",
|
|
&td.details.close_requests.close),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wads_out table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wads_out (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WADS_OUT
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"wad_out_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wad_id",
|
|
&td.details.wads_out.wad_id),
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"partner_serial_id",
|
|
&td.details.wads_out.partner_serial_id),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount",
|
|
&td.details.wads_out.amount),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"execution_time",
|
|
&td.details.wads_out.execution_time),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wads_out_entries table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wads_out_entries (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WADS_OUT_ENTRIES
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"wad_out_entry_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.wads_out_entries.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.wads_out_entries.purse_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"h_contract",
|
|
&td.details.wads_out_entries.h_contract),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"purse_expiration",
|
|
&td.details.wads_out_entries.purse_expiration),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"merge_timestamp",
|
|
&td.details.wads_out_entries.merge_timestamp),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.wads_out_entries.amount_with_fee),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"wad_fee",
|
|
&td.details.wads_out_entries.wad_fee),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"deposit_fees",
|
|
&td.details.wads_out_entries.deposit_fees),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.wads_out_entries.reserve_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_sig",
|
|
&td.details.wads_out_entries.purse_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wads_in table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wads_in (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WADS_IN
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"wad_in_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wad_id",
|
|
&td.details.wads_in.wad_id),
|
|
GNUNET_PQ_result_spec_string (
|
|
"origin_exchange_url",
|
|
&td.details.wads_in.origin_exchange_url),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount",
|
|
&td.details.wads_in.amount),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"arrival_time",
|
|
&td.details.wads_in.arrival_time),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with wads_in_entries table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_wads_in_entries (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_WADS_IN_ENTRIES
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"wad_in_entry_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_pub",
|
|
&td.details.wads_in_entries.reserve_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_pub",
|
|
&td.details.wads_in_entries.purse_pub),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"h_contract",
|
|
&td.details.wads_in_entries.h_contract),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"purse_expiration",
|
|
&td.details.wads_in_entries.purse_expiration),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"merge_timestamp",
|
|
&td.details.wads_in_entries.merge_timestamp),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount_with_fee",
|
|
&td.details.wads_in_entries.amount_with_fee),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"wad_fee",
|
|
&td.details.wads_in_entries.wad_fee),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"deposit_fees",
|
|
&td.details.wads_in_entries.deposit_fees),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"reserve_sig",
|
|
&td.details.wads_in_entries.reserve_sig),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"purse_sig",
|
|
&td.details.wads_in_entries.purse_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* Function called with profit_drains table entries.
|
|
*
|
|
* @param cls closure
|
|
* @param result the postgres result
|
|
* @param num_results the number of results in @a result
|
|
*/
|
|
static void
|
|
lrbt_cb_table_profit_drains (void *cls,
|
|
PGresult *result,
|
|
unsigned int num_results)
|
|
{
|
|
struct LookupRecordsByTableContext *ctx = cls;
|
|
struct PostgresClosure *pg = ctx->pg;
|
|
struct TALER_EXCHANGEDB_TableData td = {
|
|
.table = TALER_EXCHANGEDB_RT_PROFIT_DRAINS
|
|
};
|
|
|
|
for (unsigned int i = 0; i<num_results; i++)
|
|
{
|
|
struct GNUNET_PQ_ResultSpec rs[] = {
|
|
GNUNET_PQ_result_spec_uint64 (
|
|
"profit_drain_serial_id",
|
|
&td.serial),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"wtid",
|
|
&td.details.profit_drains.wtid),
|
|
GNUNET_PQ_result_spec_string (
|
|
"account_section",
|
|
&td.details.profit_drains.account_section),
|
|
GNUNET_PQ_result_spec_string (
|
|
"payto_uri",
|
|
&td.details.profit_drains.payto_uri),
|
|
GNUNET_PQ_result_spec_timestamp (
|
|
"trigger_date",
|
|
&td.details.profit_drains.trigger_date),
|
|
TALER_PQ_RESULT_SPEC_AMOUNT (
|
|
"amount",
|
|
&td.details.profit_drains.amount),
|
|
GNUNET_PQ_result_spec_auto_from_type (
|
|
"master_sig",
|
|
&td.details.profit_drains.master_sig),
|
|
GNUNET_PQ_result_spec_end
|
|
};
|
|
|
|
if (GNUNET_OK !=
|
|
GNUNET_PQ_extract_result (result,
|
|
rs,
|
|
i))
|
|
{
|
|
GNUNET_break (0);
|
|
ctx->error = true;
|
|
return;
|
|
}
|
|
ctx->cb (ctx->cb_cls,
|
|
&td);
|
|
GNUNET_PQ_cleanup_result (rs);
|
|
}
|
|
}
|
|
|
|
|
|
/* end of lrbt_callbacks.c */
|