diff options
Diffstat (limited to 'src/exchange')
| -rw-r--r-- | src/exchange/taler-exchange-httpd_link.c | 6 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-httpd_refreshes_reveal.c | 19 | 
2 files changed, 17 insertions, 8 deletions
| diff --git a/src/exchange/taler-exchange-httpd_link.c b/src/exchange/taler-exchange-httpd_link.c index d3c0d6a5..de10f8b8 100644 --- a/src/exchange/taler-exchange-httpd_link.c +++ b/src/exchange/taler-exchange-httpd_link.c @@ -1,6 +1,6 @@  /*    This file is part of TALER -  Copyright (C) 2014-2019 Taler Systems SA +  Copyright (C) 2014-2019, 2022 Taler Systems SA    TALER 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 @@ -86,6 +86,10 @@ handle_link_data (void *cls,                                   &pos->denom_pub),        TALER_JSON_pack_blinded_denom_sig ("ev_sig",                                           &pos->ev_sig), +      GNUNET_JSON_pack_uint64 ("coin_idx", +                               pos->coin_refresh_offset), +      TALER_JSON_pack_exchange_withdraw_values ("ewv", +                                                &pos->alg_values),        GNUNET_JSON_pack_data_auto ("link_sig",                                    &pos->orig_coin_link_sig));      if ( (NULL == obj) || diff --git a/src/exchange/taler-exchange-httpd_refreshes_reveal.c b/src/exchange/taler-exchange-httpd_refreshes_reveal.c index 56827814..e0d97bb3 100644 --- a/src/exchange/taler-exchange-httpd_refreshes_reveal.c +++ b/src/exchange/taler-exchange-httpd_refreshes_reveal.c @@ -105,7 +105,10 @@ struct RevealContext    /**     * Array of information about fresh coins being revealed.     */ -  const struct TALER_EXCHANGEDB_RefreshRevealedCoin *rrcs; +  /* FIXME: const would be nicer here, but we initalize +     the 'alg_values' in the verification +     routine; suboptimal to be fixed... */ +  struct TALER_EXCHANGEDB_RefreshRevealedCoin *rrcs;    /**     * Envelopes to be signed. @@ -141,7 +144,6 @@ check_commitment (struct RevealContext *rctx,                    struct MHD_Connection *connection,                    MHD_RESULT *mhd_ret)  { -  struct TALER_ExchangeWithdrawValues alg_values[rctx->num_fresh_coins];    struct TALER_CsNonce nonces[rctx->num_fresh_coins];    unsigned int aoff = 0; @@ -184,8 +186,10 @@ check_commitment (struct RevealContext *rctx,    for (unsigned int j = 0; j<rctx->num_fresh_coins; j++)    {      const struct TALER_DenominationPublicKey *dk = &rctx->dks[j]->denom_pub; +    struct TALER_ExchangeWithdrawValues *alg_values +      = &rctx->rrcs[j].exchange_vals; -    alg_values[j].cipher = dk->cipher; +    alg_values->cipher = dk->cipher;      switch (dk->cipher)      {      case TALER_DENOMINATION_INVALID: @@ -200,7 +204,7 @@ check_commitment (struct RevealContext *rctx,          ec = TEH_keys_denomination_cs_r_pub (            &rctx->rrcs[j].h_denom_pub,            &nonces[aoff], -          &alg_values[j].details.cs_values.r_pub_pair); +          &alg_values->details.cs_values.r_pub_pair);          if (TALER_EC_NONE != ec)          {            *mhd_ret = TALER_MHD_reply_with_error (connection, @@ -251,12 +255,13 @@ check_commitment (struct RevealContext *rctx,          aoff = 0;          for (unsigned int j = 0; j<rctx->num_fresh_coins; j++)          { -          const struct TALER_DenominationPublicKey *dk = -            &rctx->dks[j]->denom_pub; +          const struct TALER_DenominationPublicKey *dk +            = &rctx->dks[j]->denom_pub;            struct TALER_RefreshCoinData *rcd = &rce->new_coins[j];            struct TALER_CoinSpendPrivateKeyP coin_priv;            union TALER_DenominationBlindingKeyP bks; -          const struct TALER_ExchangeWithdrawValues *alg_value = &alg_values[j]; +          const struct TALER_ExchangeWithdrawValues *alg_value +            = &rctx->rrcs[j].exchange_vals;            struct TALER_PlanchetDetail pd;            struct TALER_CoinPubHash c_hash;            struct TALER_PlanchetSecretsP ps; | 
