diff options
Diffstat (limited to 'src/exchange')
| -rw-r--r-- | src/exchange/taler-exchange-httpd_config.h | 2 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-httpd_management_wire_disable.c | 5 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-httpd_management_wire_enable.c | 46 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-httpd_wire.c | 17 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-wirewatch.c | 4 | 
5 files changed, 67 insertions, 7 deletions
| diff --git a/src/exchange/taler-exchange-httpd_config.h b/src/exchange/taler-exchange-httpd_config.h index 7763cdeb..95380e0a 100644 --- a/src/exchange/taler-exchange-httpd_config.h +++ b/src/exchange/taler-exchange-httpd_config.h @@ -41,7 +41,7 @@   *   * Returned via both /config and /keys endpoints.   */ -#define EXCHANGE_PROTOCOL_VERSION "14:0:2" +#define EXCHANGE_PROTOCOL_VERSION "15:0:0"  /** diff --git a/src/exchange/taler-exchange-httpd_management_wire_disable.c b/src/exchange/taler-exchange-httpd_management_wire_disable.c index 34825eda..077a56b2 100644 --- a/src/exchange/taler-exchange-httpd_management_wire_disable.c +++ b/src/exchange/taler-exchange-httpd_management_wire_disable.c @@ -1,6 +1,6 @@  /*    This file is part of TALER -  Copyright (C) 2020 Taler Systems SA +  Copyright (C) 2020-2023 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 @@ -114,6 +114,9 @@ del_wire (void *cls,    }    qs = TEH_plugin->update_wire (TEH_plugin->cls,                                  awc->payto_uri, +                                NULL, +                                NULL, +                                NULL,                                  awc->validity_end,                                  false);    if (qs < 0) diff --git a/src/exchange/taler-exchange-httpd_management_wire_enable.c b/src/exchange/taler-exchange-httpd_management_wire_enable.c index 25ee0eea..6743b485 100644 --- a/src/exchange/taler-exchange-httpd_management_wire_enable.c +++ b/src/exchange/taler-exchange-httpd_management_wire_enable.c @@ -1,6 +1,6 @@  /*    This file is part of TALER -  Copyright (C) 2020 Taler Systems SA +  Copyright (C) 2020-2023 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 @@ -55,6 +55,21 @@ struct AddWireContext    const char *payto_uri;    /** +   * (optional) address of a conversion service for this account. +   */ +  const char *conversion_url; + +  /** +   * Restrictions imposed when crediting this account. +   */ +  json_t *credit_restrictions; + +  /** +   * Restrictions imposed when debiting this account. +   */ +  json_t *debit_restrictions; + +  /**     * Timestamp for checking against replay attacks.     */    struct GNUNET_TIME_Timestamp validity_start; @@ -114,11 +129,17 @@ add_wire (void *cls,    if (0 == qs)      qs = TEH_plugin->insert_wire (TEH_plugin->cls,                                    awc->payto_uri, +                                  awc->conversion_url, +                                  awc->debit_restrictions, +                                  awc->credit_restrictions,                                    awc->validity_start,                                    &awc->master_sig_wire);    else      qs = TEH_plugin->update_wire (TEH_plugin->cls,                                    awc->payto_uri, +                                  awc->conversion_url, +                                  awc->debit_restrictions, +                                  awc->credit_restrictions,                                    awc->validity_start,                                    true);    if (qs < 0) @@ -141,7 +162,9 @@ TEH_handler_management_post_wire (    struct MHD_Connection *connection,    const json_t *root)  { -  struct AddWireContext awc; +  struct AddWireContext awc = { +    .conversion_url = NULL +  };    struct GNUNET_JSON_Specification spec[] = {      GNUNET_JSON_spec_fixed_auto ("master_sig_wire",                                   &awc.master_sig_wire), @@ -149,6 +172,14 @@ TEH_handler_management_post_wire (                                   &awc.master_sig_add),      GNUNET_JSON_spec_string ("payto_uri",                               &awc.payto_uri), +    GNUNET_JSON_spec_mark_optional ( +      GNUNET_JSON_spec_string ("conversion_url", +                               &awc.conversion_url), +      NULL), +    GNUNET_JSON_spec_json ("credit_restrictions", +                           &awc.credit_restrictions), +    GNUNET_JSON_spec_json ("debit_restrictions", +                           &awc.debit_restrictions),      GNUNET_JSON_spec_timestamp ("validity_start",                                  &awc.validity_start),      GNUNET_JSON_spec_end () @@ -179,17 +210,22 @@ TEH_handler_management_post_wire (          MHD_HTTP_BAD_REQUEST,          TALER_EC_GENERIC_PAYTO_URI_MALFORMED,          msg); +      GNUNET_JSON_parse_free (spec);        GNUNET_free (msg);        return ret;      }    }    if (GNUNET_OK !=        TALER_exchange_offline_wire_add_verify (awc.payto_uri, +                                              awc.conversion_url, +                                              awc.debit_restrictions, +                                              awc.credit_restrictions,                                                awc.validity_start,                                                &TEH_master_public_key,                                                &awc.master_sig_add))    {      GNUNET_break_op (0); +    GNUNET_JSON_parse_free (spec);      return TALER_MHD_reply_with_error (        connection,        MHD_HTTP_FORBIDDEN, @@ -199,10 +235,14 @@ TEH_handler_management_post_wire (    TEH_METRICS_num_verifications[TEH_MT_SIGNATURE_EDDSA]++;    if (GNUNET_OK !=        TALER_exchange_wire_signature_check (awc.payto_uri, +                                           awc.conversion_url, +                                           awc.debit_restrictions, +                                           awc.credit_restrictions,                                             &TEH_master_public_key,                                             &awc.master_sig_wire))    {      GNUNET_break_op (0); +    GNUNET_JSON_parse_free (spec);      return TALER_MHD_reply_with_error (        connection,        MHD_HTTP_FORBIDDEN, @@ -218,6 +258,7 @@ TEH_handler_management_post_wire (        GNUNET_log (GNUNET_ERROR_TYPE_ERROR,                    "payto:// URI `%s' is malformed\n",                    awc.payto_uri); +      GNUNET_JSON_parse_free (spec);        return TALER_MHD_reply_with_error (          connection,          MHD_HTTP_BAD_REQUEST, @@ -237,6 +278,7 @@ TEH_handler_management_post_wire (                                    &ret,                                    &add_wire,                                    &awc); +    GNUNET_JSON_parse_free (spec);      if (GNUNET_SYSERR == res)        return ret;    } diff --git a/src/exchange/taler-exchange-httpd_wire.c b/src/exchange/taler-exchange-httpd_wire.c index 34010462..17875a72 100644 --- a/src/exchange/taler-exchange-httpd_wire.c +++ b/src/exchange/taler-exchange-httpd_wire.c @@ -1,6 +1,6 @@  /*    This file is part of TALER -  Copyright (C) 2015-2022 Taler Systems SA +  Copyright (C) 2015-2023 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 @@ -224,12 +224,18 @@ TEH_wire_done ()   *   * @param cls a `json_t *` object to expand with wire account details   * @param payto_uri the exchange bank account URI to add + * @param conversion_url URL of a conversion service, NULL if there is no conversion + * @param debit_restrictions JSON array with debit restrictions on the account + * @param credit_restrictions JSON array with credit restrictions on the account   * @param master_sig master key signature affirming that this is a bank   *                   account of the exchange (of purpose #TALER_SIGNATURE_MASTER_WIRE_DETAILS)   */  static void  add_wire_account (void *cls,                    const char *payto_uri, +                  const char *conversion_url, +                  const json_t *debit_restrictions, +                  const json_t *credit_restrictions,                    const struct TALER_MasterSignatureP *master_sig)  {    json_t *a = cls; @@ -240,6 +246,13 @@ add_wire_account (void *cls,          GNUNET_JSON_PACK (            GNUNET_JSON_pack_string ("payto_uri",                                     payto_uri), +          GNUNET_JSON_pack_allow_null ( +            GNUNET_JSON_pack_string ("conversion_url", +                                     conversion_url)), +          GNUNET_JSON_pack_array_incref ("debit_restrictions", +                                         (json_t *) debit_restrictions), +          GNUNET_JSON_pack_array_incref ("credit_restrictions", +                                         (json_t *) credit_restrictions),            GNUNET_JSON_pack_data_auto ("master_sig",                                        master_sig))))    { @@ -462,6 +475,8 @@ build_wire_state (void)    wsh->wire_reply = TALER_MHD_MAKE_JSON_PACK (      GNUNET_JSON_pack_array_steal ("accounts",                                    wire_accounts_array), +    GNUNET_JSON_pack_array_steal ("wads", /* #7271 */ +                                  json_array ()),      GNUNET_JSON_pack_object_steal ("fees",                                     wire_fee_object),      GNUNET_JSON_pack_data_auto ("master_public_key", diff --git a/src/exchange/taler-exchange-wirewatch.c b/src/exchange/taler-exchange-wirewatch.c index 235c0153..04704242 100644 --- a/src/exchange/taler-exchange-wirewatch.c +++ b/src/exchange/taler-exchange-wirewatch.c @@ -731,8 +731,8 @@ history_cb (void *cls,    {    case MHD_HTTP_OK:      process_reply (wrap_size, -                   reply->details.success.details, -                   reply->details.success.details_length); +                   reply->details.ok.details, +                   reply->details.ok.details_length);      return;    case MHD_HTTP_NO_CONTENT:      transaction_completed (); | 
