rename function that is for the merchant signature to have merchant in the name
This commit is contained in:
parent
8c9d5d6135
commit
4199e4438d
@ -329,7 +329,7 @@ TEH_handler_deposits_get (struct TEH_RequestContext *rc,
|
|||||||
TEH_METRICS_num_verifications[TEH_MT_SIGNATURE_EDDSA]++;
|
TEH_METRICS_num_verifications[TEH_MT_SIGNATURE_EDDSA]++;
|
||||||
{
|
{
|
||||||
if (GNUNET_OK !=
|
if (GNUNET_OK !=
|
||||||
TALER_exchange_deposit_verify (&ctx.merchant,
|
TALER_merchant_deposit_verify (&ctx.merchant,
|
||||||
&ctx.coin_pub,
|
&ctx.coin_pub,
|
||||||
&ctx.h_contract_terms,
|
&ctx.h_contract_terms,
|
||||||
&ctx.h_wire,
|
&ctx.h_wire,
|
||||||
|
@ -3383,7 +3383,7 @@ TALER_merchant_refund_verify (
|
|||||||
* @param[out] merchant_sig where to write the signature
|
* @param[out] merchant_sig where to write the signature
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
TALER_exchange_deposit_sign (
|
TALER_merchant_deposit_sign (
|
||||||
const struct TALER_PrivateContractHashP *h_contract_terms,
|
const struct TALER_PrivateContractHashP *h_contract_terms,
|
||||||
const struct TALER_MerchantWireHashP *h_wire,
|
const struct TALER_MerchantWireHashP *h_wire,
|
||||||
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
||||||
@ -3402,7 +3402,7 @@ TALER_exchange_deposit_sign (
|
|||||||
* @return #GNUNET_OK if the signature is valid
|
* @return #GNUNET_OK if the signature is valid
|
||||||
*/
|
*/
|
||||||
enum GNUNET_GenericReturnValue
|
enum GNUNET_GenericReturnValue
|
||||||
TALER_exchange_deposit_verify (
|
TALER_merchant_deposit_verify (
|
||||||
const struct TALER_MerchantPublicKeyP *merchant,
|
const struct TALER_MerchantPublicKeyP *merchant,
|
||||||
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
||||||
const struct TALER_PrivateContractHashP *h_contract_terms,
|
const struct TALER_PrivateContractHashP *h_contract_terms,
|
||||||
|
@ -320,7 +320,7 @@ TALER_EXCHANGE_deposits_get (
|
|||||||
}
|
}
|
||||||
GNUNET_CRYPTO_eddsa_key_get_public (&merchant_priv->eddsa_priv,
|
GNUNET_CRYPTO_eddsa_key_get_public (&merchant_priv->eddsa_priv,
|
||||||
&merchant.eddsa_pub);
|
&merchant.eddsa_pub);
|
||||||
TALER_exchange_deposit_sign (h_contract_terms,
|
TALER_merchant_deposit_sign (h_contract_terms,
|
||||||
h_wire,
|
h_wire,
|
||||||
coin_pub,
|
coin_pub,
|
||||||
&merchant,
|
&merchant,
|
||||||
|
@ -23,94 +23,6 @@
|
|||||||
#include "taler_signatures.h"
|
#include "taler_signatures.h"
|
||||||
|
|
||||||
|
|
||||||
GNUNET_NETWORK_STRUCT_BEGIN
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Format used to generate the signature on a request to obtain
|
|
||||||
* the wire transfer identifier associated with a deposit.
|
|
||||||
*/
|
|
||||||
struct TALER_DepositTrackPS
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Purpose must be #TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION.
|
|
||||||
*/
|
|
||||||
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Hash over the proposal data of the contract for which this deposit is made.
|
|
||||||
*/
|
|
||||||
struct TALER_PrivateContractHashP h_contract_terms GNUNET_PACKED;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Hash over the wiring information of the merchant.
|
|
||||||
*/
|
|
||||||
struct TALER_MerchantWireHashP h_wire GNUNET_PACKED;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The Merchant's public key. The deposit inquiry request is to be
|
|
||||||
* signed by the corresponding private key (using EdDSA).
|
|
||||||
*/
|
|
||||||
struct TALER_MerchantPublicKeyP merchant;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The coin's public key. This is the value that must have been
|
|
||||||
* signed (blindly) by the Exchange.
|
|
||||||
*/
|
|
||||||
struct TALER_CoinSpendPublicKeyP coin_pub;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
GNUNET_NETWORK_STRUCT_END
|
|
||||||
|
|
||||||
|
|
||||||
void
|
|
||||||
TALER_exchange_deposit_sign (
|
|
||||||
const struct TALER_PrivateContractHashP *h_contract_terms,
|
|
||||||
const struct TALER_MerchantWireHashP *h_wire,
|
|
||||||
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
|
||||||
const struct TALER_MerchantPublicKeyP *merchant_pub,
|
|
||||||
const struct TALER_MerchantPrivateKeyP *merchant_priv,
|
|
||||||
struct TALER_MerchantSignatureP *merchant_sig)
|
|
||||||
{
|
|
||||||
struct TALER_DepositTrackPS dtp = {
|
|
||||||
.purpose.purpose = htonl (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION),
|
|
||||||
.purpose.size = htonl (sizeof (dtp)),
|
|
||||||
.h_contract_terms = *h_contract_terms,
|
|
||||||
.h_wire = *h_wire,
|
|
||||||
.merchant = *merchant_pub,
|
|
||||||
.coin_pub = *coin_pub
|
|
||||||
};
|
|
||||||
GNUNET_CRYPTO_eddsa_sign (&merchant_priv->eddsa_priv,
|
|
||||||
&dtp,
|
|
||||||
&merchant_sig->eddsa_sig);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
enum GNUNET_GenericReturnValue
|
|
||||||
TALER_exchange_deposit_verify (
|
|
||||||
const struct TALER_MerchantPublicKeyP *merchant,
|
|
||||||
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
|
||||||
const struct TALER_PrivateContractHashP *h_contract_terms,
|
|
||||||
const struct TALER_MerchantWireHashP *h_wire,
|
|
||||||
const struct TALER_MerchantSignatureP *merchant_sig)
|
|
||||||
{
|
|
||||||
struct TALER_DepositTrackPS tps = {
|
|
||||||
.purpose.size = htonl (sizeof (tps)),
|
|
||||||
.purpose.purpose = htonl (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION),
|
|
||||||
.merchant = *merchant,
|
|
||||||
.coin_pub = *coin_pub,
|
|
||||||
.h_contract_terms = *h_contract_terms,
|
|
||||||
.h_wire = *h_wire
|
|
||||||
};
|
|
||||||
|
|
||||||
return
|
|
||||||
GNUNET_CRYPTO_eddsa_verify (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION,
|
|
||||||
&tps,
|
|
||||||
&merchant_sig->eddsa_sig,
|
|
||||||
&tps.merchant.eddsa_pub);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
GNUNET_NETWORK_STRUCT_BEGIN
|
GNUNET_NETWORK_STRUCT_BEGIN
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -23,6 +23,94 @@
|
|||||||
#include "taler_signatures.h"
|
#include "taler_signatures.h"
|
||||||
|
|
||||||
|
|
||||||
|
GNUNET_NETWORK_STRUCT_BEGIN
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Format used to generate the signature on a request to obtain
|
||||||
|
* the wire transfer identifier associated with a deposit.
|
||||||
|
*/
|
||||||
|
struct TALER_DepositTrackPS
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Purpose must be #TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION.
|
||||||
|
*/
|
||||||
|
struct GNUNET_CRYPTO_EccSignaturePurpose purpose;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hash over the proposal data of the contract for which this deposit is made.
|
||||||
|
*/
|
||||||
|
struct TALER_PrivateContractHashP h_contract_terms GNUNET_PACKED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Hash over the wiring information of the merchant.
|
||||||
|
*/
|
||||||
|
struct TALER_MerchantWireHashP h_wire GNUNET_PACKED;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Merchant's public key. The deposit inquiry request is to be
|
||||||
|
* signed by the corresponding private key (using EdDSA).
|
||||||
|
*/
|
||||||
|
struct TALER_MerchantPublicKeyP merchant;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The coin's public key. This is the value that must have been
|
||||||
|
* signed (blindly) by the Exchange.
|
||||||
|
*/
|
||||||
|
struct TALER_CoinSpendPublicKeyP coin_pub;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
GNUNET_NETWORK_STRUCT_END
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
TALER_merchant_deposit_sign (
|
||||||
|
const struct TALER_PrivateContractHashP *h_contract_terms,
|
||||||
|
const struct TALER_MerchantWireHashP *h_wire,
|
||||||
|
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
||||||
|
const struct TALER_MerchantPublicKeyP *merchant_pub,
|
||||||
|
const struct TALER_MerchantPrivateKeyP *merchant_priv,
|
||||||
|
struct TALER_MerchantSignatureP *merchant_sig)
|
||||||
|
{
|
||||||
|
struct TALER_DepositTrackPS dtp = {
|
||||||
|
.purpose.purpose = htonl (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION),
|
||||||
|
.purpose.size = htonl (sizeof (dtp)),
|
||||||
|
.h_contract_terms = *h_contract_terms,
|
||||||
|
.h_wire = *h_wire,
|
||||||
|
.merchant = *merchant_pub,
|
||||||
|
.coin_pub = *coin_pub
|
||||||
|
};
|
||||||
|
GNUNET_CRYPTO_eddsa_sign (&merchant_priv->eddsa_priv,
|
||||||
|
&dtp,
|
||||||
|
&merchant_sig->eddsa_sig);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
enum GNUNET_GenericReturnValue
|
||||||
|
TALER_merchant_deposit_verify (
|
||||||
|
const struct TALER_MerchantPublicKeyP *merchant,
|
||||||
|
const struct TALER_CoinSpendPublicKeyP *coin_pub,
|
||||||
|
const struct TALER_PrivateContractHashP *h_contract_terms,
|
||||||
|
const struct TALER_MerchantWireHashP *h_wire,
|
||||||
|
const struct TALER_MerchantSignatureP *merchant_sig)
|
||||||
|
{
|
||||||
|
struct TALER_DepositTrackPS tps = {
|
||||||
|
.purpose.size = htonl (sizeof (tps)),
|
||||||
|
.purpose.purpose = htonl (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION),
|
||||||
|
.merchant = *merchant,
|
||||||
|
.coin_pub = *coin_pub,
|
||||||
|
.h_contract_terms = *h_contract_terms,
|
||||||
|
.h_wire = *h_wire
|
||||||
|
};
|
||||||
|
|
||||||
|
return
|
||||||
|
GNUNET_CRYPTO_eddsa_verify (TALER_SIGNATURE_MERCHANT_TRACK_TRANSACTION,
|
||||||
|
&tps,
|
||||||
|
&merchant_sig->eddsa_sig,
|
||||||
|
&tps.merchant.eddsa_pub);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Format used to generate the signature on a request to refund
|
* @brief Format used to generate the signature on a request to refund
|
||||||
* a coin into the account of the customer.
|
* a coin into the account of the customer.
|
||||||
|
Loading…
Reference in New Issue
Block a user