diff options
Diffstat (limited to 'src/bank-lib')
| -rw-r--r-- | src/bank-lib/bank_api_credit.c | 120 | ||||
| -rw-r--r-- | src/bank-lib/bank_api_debit.c | 124 | ||||
| -rw-r--r-- | src/bank-lib/taler-exchange-wire-gateway-client.c | 232 | 
3 files changed, 222 insertions, 254 deletions
| diff --git a/src/bank-lib/bank_api_credit.c b/src/bank-lib/bank_api_credit.c index 36cab3d5..127ae057 100644 --- a/src/bank-lib/bank_api_credit.c +++ b/src/bank-lib/bank_api_credit.c @@ -77,6 +77,11 @@ static enum GNUNET_GenericReturnValue  parse_account_history (struct TALER_BANK_CreditHistoryHandle *hh,                         const json_t *history)  { +  struct TALER_BANK_CreditHistoryResponse chr = { +    .http_status = MHD_HTTP_OK, +    .ec = TALER_EC_NONE, +    .response = history +  };    json_t *history_array;    if (NULL == (history_array = json_object_get (history, @@ -90,49 +95,45 @@ parse_account_history (struct TALER_BANK_CreditHistoryHandle *hh,      GNUNET_break_op (0);      return GNUNET_SYSERR;    } -  for (unsigned int i = 0; i<json_array_size (history_array); i++)    { -    struct TALER_BANK_CreditDetails td; -    uint64_t row_id; -    struct GNUNET_JSON_Specification hist_spec[] = { -      TALER_JSON_spec_amount_any ("amount", -                                  &td.amount), -      GNUNET_JSON_spec_timestamp ("date", -                                  &td.execution_date), -      GNUNET_JSON_spec_uint64 ("row_id", -                               &row_id), -      GNUNET_JSON_spec_fixed_auto ("reserve_pub", -                                   &td.reserve_pub), -      GNUNET_JSON_spec_string ("debit_account", -                               &td.debit_account_uri), -      GNUNET_JSON_spec_string ("credit_account", -                               &td.credit_account_uri), -      GNUNET_JSON_spec_end () -    }; -    json_t *transaction = json_array_get (history_array, -                                          i); +    size_t len = json_array_size (history_array); +    struct TALER_BANK_CreditDetails cd[len]; -    if (GNUNET_OK != -        GNUNET_JSON_parse (transaction, -                           hist_spec, -                           NULL, NULL)) -    { -      GNUNET_break_op (0); -      return GNUNET_SYSERR; -    } -    if (GNUNET_OK != -        hh->hcb (hh->hcb_cls, -                 MHD_HTTP_OK, -                 TALER_EC_NONE, -                 row_id, -                 &td, -                 transaction)) +    for (unsigned int i = 0; i<json_array_size (history_array); i++)      { -      hh->hcb = NULL; -      GNUNET_JSON_parse_free (hist_spec); -      return GNUNET_OK; +      struct TALER_BANK_CreditDetails *td = &cd[i]; +      struct GNUNET_JSON_Specification hist_spec[] = { +        TALER_JSON_spec_amount_any ("amount", +                                    &td->amount), +        GNUNET_JSON_spec_timestamp ("date", +                                    &td->execution_date), +        GNUNET_JSON_spec_uint64 ("row_id", +                                 &td->serial_id), +        GNUNET_JSON_spec_fixed_auto ("reserve_pub", +                                     &td->reserve_pub), +        GNUNET_JSON_spec_string ("debit_account", +                                 &td->debit_account_uri), +        GNUNET_JSON_spec_string ("credit_account", +                                 &td->credit_account_uri), +        GNUNET_JSON_spec_end () +      }; +      json_t *transaction = json_array_get (history_array, +                                            i); + +      if (GNUNET_OK != +          GNUNET_JSON_parse (transaction, +                             hist_spec, +                             NULL, +                             NULL)) +      { +        GNUNET_break_op (0); +        return GNUNET_SYSERR; +      }      } -    GNUNET_JSON_parse_free (hist_spec); +    chr.details.success.details_length = len; +    chr.details.success.details = cd; +    hh->hcb (hh->hcb_cls, +             &chr);    }    return GNUNET_OK;  } @@ -152,72 +153,67 @@ handle_credit_history_finished (void *cls,                                  const void *response)  {    struct TALER_BANK_CreditHistoryHandle *hh = cls; -  const json_t *j = response; -  enum TALER_ErrorCode ec; +  struct TALER_BANK_CreditHistoryResponse chr = { +    .http_status = MHD_HTTP_OK, +    .response = response +  };    hh->job = NULL;    switch (response_code)    {    case 0: -    ec = TALER_EC_GENERIC_INVALID_RESPONSE; +    chr.ec = TALER_EC_GENERIC_INVALID_RESPONSE;      break;    case MHD_HTTP_OK:      if (GNUNET_OK !=          parse_account_history (hh, -                               j)) +                               chr.response))      {        GNUNET_break_op (0); -      json_dumpf (j, +      json_dumpf (chr.response,                    stderr,                    JSON_INDENT (2)); -      response_code = 0; -      ec = TALER_EC_GENERIC_INVALID_RESPONSE; +      chr.http_status = 0; +      chr.ec = TALER_EC_GENERIC_INVALID_RESPONSE;        break;      } -    response_code = MHD_HTTP_NO_CONTENT; /* signal end of list */ -    ec = TALER_EC_NONE; -    break; +    TALER_BANK_credit_history_cancel (hh); +    return;    case MHD_HTTP_NO_CONTENT: -    ec = TALER_EC_NONE;      break;    case MHD_HTTP_BAD_REQUEST:      /* This should never happen, either us or the bank is buggy         (or API version conflict); just pass JSON reply to the application */      GNUNET_break_op (0); -    ec = TALER_JSON_get_error_code (j); +    chr.ec = TALER_JSON_get_error_code (chr.response);      break;    case MHD_HTTP_UNAUTHORIZED:      /* Nothing really to verify, bank says the HTTP Authentication         failed. May happen if HTTP authentication is used and the         user supplied a wrong username/password combination. */ -    ec = TALER_JSON_get_error_code (j); +    chr.ec = TALER_JSON_get_error_code (chr.response);      break;    case MHD_HTTP_NOT_FOUND:      /* Nothing really to verify: the bank is either unaware         of the endpoint (not a bank), or of the account.         We should pass the JSON (?) reply to the application */ -    ec = TALER_JSON_get_error_code (j); +    chr.ec = TALER_JSON_get_error_code (chr.response);      break;    case MHD_HTTP_INTERNAL_SERVER_ERROR:      /* Server had an internal issue; we should retry, but this API         leaves this to the application */ -    ec = TALER_JSON_get_error_code (j); +    chr.ec = TALER_JSON_get_error_code (chr.response);      break;    default:      /* unexpected response code */      GNUNET_log (GNUNET_ERROR_TYPE_ERROR,                  "Unexpected response code %u\n",                  (unsigned int) response_code); -    ec = TALER_JSON_get_error_code (j); +    chr.ec = TALER_JSON_get_error_code (chr.response);      break;    } -  if (NULL != hh->hcb) -    hh->hcb (hh->hcb_cls, -             response_code, -             ec, -             0LLU, -             NULL, -             j); +  hh->hcb (hh->hcb_cls, +           &chr);    TALER_BANK_credit_history_cancel (hh);  } diff --git a/src/bank-lib/bank_api_debit.c b/src/bank-lib/bank_api_debit.c index 2a76495b..6642dda8 100644 --- a/src/bank-lib/bank_api_debit.c +++ b/src/bank-lib/bank_api_debit.c @@ -1,6 +1,6 @@  /*    This file is part of TALER -  Copyright (C) 2017--2021 Taler Systems SA +  Copyright (C) 2017--2022 Taler Systems SA    TALER is free software; you can redistribute it and/or    modify it under the terms of the GNU General Public License @@ -77,6 +77,11 @@ static enum GNUNET_GenericReturnValue  parse_account_history (struct TALER_BANK_DebitHistoryHandle *hh,                         const json_t *history)  { +  struct TALER_BANK_DebitHistoryResponse dhr = { +    .http_status = MHD_HTTP_OK, +    .ec = TALER_EC_NONE, +    .response = history +  };    json_t *history_array;    if (NULL == (history_array = json_object_get (history, @@ -90,51 +95,47 @@ parse_account_history (struct TALER_BANK_DebitHistoryHandle *hh,      GNUNET_break_op (0);      return GNUNET_SYSERR;    } -  for (unsigned int i = 0; i<json_array_size (history_array); i++)    { -    struct TALER_BANK_DebitDetails td; -    uint64_t row_id; -    struct GNUNET_JSON_Specification hist_spec[] = { -      TALER_JSON_spec_amount_any ("amount", -                                  &td.amount), -      GNUNET_JSON_spec_timestamp ("date", -                                  &td.execution_date), -      GNUNET_JSON_spec_uint64 ("row_id", -                               &row_id), -      GNUNET_JSON_spec_fixed_auto ("wtid", -                                   &td.wtid), -      GNUNET_JSON_spec_string ("credit_account", -                               &td.credit_account_uri), -      GNUNET_JSON_spec_string ("debit_account", -                               &td.debit_account_uri), -      GNUNET_JSON_spec_string ("exchange_base_url", -                               &td.exchange_base_url), -      GNUNET_JSON_spec_end () -    }; -    json_t *transaction = json_array_get (history_array, -                                          i); +    size_t len = json_array_size (history_array); +    struct TALER_BANK_DebitDetails dd[len]; -    if (GNUNET_OK != -        GNUNET_JSON_parse (transaction, -                           hist_spec, -                           NULL, NULL)) -    { -      GNUNET_break_op (0); -      return GNUNET_SYSERR; -    } -    if (GNUNET_OK != -        hh->hcb (hh->hcb_cls, -                 MHD_HTTP_OK, -                 TALER_EC_NONE, -                 row_id, -                 &td, -                 transaction)) +    for (unsigned int i = 0; i<len; i++)      { -      hh->hcb = NULL; -      GNUNET_JSON_parse_free (hist_spec); -      return GNUNET_OK; +      struct TALER_BANK_DebitDetails *td = &dd[i]; +      struct GNUNET_JSON_Specification hist_spec[] = { +        TALER_JSON_spec_amount_any ("amount", +                                    &td->amount), +        GNUNET_JSON_spec_timestamp ("date", +                                    &td->execution_date), +        GNUNET_JSON_spec_uint64 ("row_id", +                                 &td->serial_id), +        GNUNET_JSON_spec_fixed_auto ("wtid", +                                     &td->wtid), +        GNUNET_JSON_spec_string ("credit_account", +                                 &td->credit_account_uri), +        GNUNET_JSON_spec_string ("debit_account", +                                 &td->debit_account_uri), +        GNUNET_JSON_spec_string ("exchange_base_url", +                                 &td->exchange_base_url), +        GNUNET_JSON_spec_end () +      }; +      json_t *transaction = json_array_get (history_array, +                                            i); + +      if (GNUNET_OK != +          GNUNET_JSON_parse (transaction, +                             hist_spec, +                             NULL, +                             NULL)) +      { +        GNUNET_break_op (0); +        return GNUNET_SYSERR; +      }      } -    GNUNET_JSON_parse_free (hist_spec); +    dhr.details.success.details_length = len; +    dhr.details.success.details = dd; +    hh->hcb (hh->hcb_cls, +             &dhr);    }    return GNUNET_OK;  } @@ -154,69 +155,64 @@ handle_debit_history_finished (void *cls,                                 const void *response)  {    struct TALER_BANK_DebitHistoryHandle *hh = cls; -  const json_t *j = response; -  enum TALER_ErrorCode ec; +  struct TALER_BANK_DebitHistoryResponse dhr = { +    .http_status = MHD_HTTP_OK, +    .response = response +  };    hh->job = NULL;    switch (response_code)    {    case 0: -    ec = TALER_EC_GENERIC_INVALID_RESPONSE; +    dhr.ec = TALER_EC_GENERIC_INVALID_RESPONSE;      break;    case MHD_HTTP_OK:      if (GNUNET_OK !=          parse_account_history (hh, -                               j)) +                               dhr.response))      {        GNUNET_break_op (0); -      response_code = 0; -      ec = TALER_EC_GENERIC_INVALID_RESPONSE; +      dhr.http_status = 0; +      dhr.ec = TALER_EC_GENERIC_INVALID_RESPONSE;        break;      } -    response_code = MHD_HTTP_NO_CONTENT; /* signal end of list */ -    ec = TALER_EC_NONE; -    break; +    TALER_BANK_debit_history_cancel (hh); +    return;    case MHD_HTTP_NO_CONTENT: -    ec = TALER_EC_NONE;      break;    case MHD_HTTP_BAD_REQUEST:      /* This should never happen, either us or the bank is buggy         (or API version conflict); just pass JSON reply to the application */      GNUNET_break_op (0); -    ec = TALER_JSON_get_error_code (j); +    dhr.ec = TALER_JSON_get_error_code (dhr.response);      break;    case MHD_HTTP_UNAUTHORIZED:      /* Nothing really to verify, bank says the HTTP Authentication         failed. May happen if HTTP authentication is used and the         user supplied a wrong username/password combination. */ -    ec = TALER_JSON_get_error_code (j); +    dhr.ec = TALER_JSON_get_error_code (dhr.response);      break;    case MHD_HTTP_NOT_FOUND:      /* Nothing really to verify: the bank is either unaware         of the endpoint (not a bank), or of the account.         We should pass the JSON (?) reply to the application */ -    ec = TALER_JSON_get_error_code (j); +    dhr.ec = TALER_JSON_get_error_code (dhr.response);      break;    case MHD_HTTP_INTERNAL_SERVER_ERROR:      /* Server had an internal issue; we should retry, but this API         leaves this to the application */ -    ec = TALER_JSON_get_error_code (j); +    dhr.ec = TALER_JSON_get_error_code (dhr.response);      break;    default:      /* unexpected response code */      GNUNET_log (GNUNET_ERROR_TYPE_ERROR,                  "Unexpected response code %u\n",                  (unsigned int) response_code); -    ec = TALER_JSON_get_error_code (j); +    dhr.ec = TALER_JSON_get_error_code (dhr.response);      break;    } -  if (NULL != hh->hcb) -    hh->hcb (hh->hcb_cls, -             response_code, -             ec, -             0LLU, -             NULL, -             j); +  hh->hcb (hh->hcb_cls, +           &dhr);    TALER_BANK_debit_history_cancel (hh);  } diff --git a/src/bank-lib/taler-exchange-wire-gateway-client.c b/src/bank-lib/taler-exchange-wire-gateway-client.c index ab16573a..5bfd9311 100644 --- a/src/bank-lib/taler-exchange-wire-gateway-client.c +++ b/src/bank-lib/taler-exchange-wire-gateway-client.c @@ -152,83 +152,72 @@ do_shutdown (void *cls)  /** - * Callback used to process ONE entry in the transaction + * Callback used to process the transaction   * history returned by the bank.   *   * @param cls closure - * @param http_status HTTP status code from server - * @param ec taler error code - * @param serial_id identification of the position at - *        which we are returning data - * @param details details about the wire transfer - * @param json original full response from server - * @return #GNUNET_OK to continue, #GNUNET_SYSERR to - *         abort iteration + * @param reply response we got from the bank   */ -static enum GNUNET_GenericReturnValue +static void  credit_history_cb (void *cls, -                   unsigned int http_status, -                   enum TALER_ErrorCode ec, -                   uint64_t serial_id, -                   const struct TALER_BANK_CreditDetails *details, -                   const json_t *json) +                   const struct TALER_BANK_CreditHistoryResponse *reply)  {    (void) cls;    chh = NULL; -  if (MHD_HTTP_OK != http_status) +  switch (reply->http_status)    { -    if ( (MHD_HTTP_NO_CONTENT != http_status) || -         (TALER_EC_NONE != ec) ) +  case 0: +    fprintf (stderr, +             "Failed to obtain HTTP reply from `%s'\n", +             auth.wire_gateway_url); +    global_ret = 2; +    break; +  case MHD_HTTP_NO_CONTENT: +    fprintf (stdout, +             "No transactions.\n"); +    global_ret = 0; +    break; +  case MHD_HTTP_OK: +    for (unsigned int i = 0; i<reply->details.success.details_length; i++)      { -      if (0 == http_status) -      { -        fprintf (stderr, -                 "Failed to obtain HTTP reply from `%s'\n", -                 auth.wire_gateway_url); -      } -      else -      { -        fprintf (stderr, -                 "Failed to obtain credit history from `%s': HTTP status %u (%s)\n", -                 auth.wire_gateway_url, -                 http_status, -                 TALER_ErrorCode_get_hint (ec)); -      } -      if (NULL != json) -        json_dumpf (json, -                    stderr, -                    JSON_INDENT (2)); -      global_ret = 2; -      GNUNET_SCHEDULER_shutdown (); -      return GNUNET_NO; +      const struct TALER_BANK_CreditDetails *cd = +        &reply->details.success.details[i]; + +      /* If credit/debit accounts were specified, use as a filter */ +      if ( (NULL != credit_account) && +           (0 != strcasecmp (credit_account, +                             cd->credit_account_uri) ) ) +        continue; +      if ( (NULL != debit_account) && +           (0 != strcasecmp (debit_account, +                             cd->debit_account_uri) ) ) +        continue; +      fprintf (stdout, +               "%llu: %s->%s (%s) over %s at %s\n", +               (unsigned long long) cd->serial_id, +               cd->debit_account_uri, +               cd->credit_account_uri, +               TALER_B2S (&cd->reserve_pub), +               TALER_amount2s (&cd->amount), +               GNUNET_TIME_timestamp2s (cd->execution_date));      } -    fprintf (stdout, -             "End of transactions list.\n");      global_ret = 0; -    GNUNET_SCHEDULER_shutdown (); -    return GNUNET_NO; +    break; +  default: +    fprintf (stderr, +             "Failed to obtain credit history from `%s': HTTP status %u (%s)\n", +             auth.wire_gateway_url, +             reply->http_status, +             TALER_ErrorCode_get_hint (reply->ec)); +    if (NULL != reply->response) +      json_dumpf (reply->response, +                  stderr, +                  JSON_INDENT (2)); +    global_ret = 2; +    break;    } - -  /* If credit/debit accounts were specified, use as a filter */ -  if ( (NULL != credit_account) && -       (0 != strcasecmp (credit_account, -                         details->credit_account_uri) ) ) -    return GNUNET_OK; -  if ( (NULL != debit_account) && -       (0 != strcasecmp (debit_account, -                         details->debit_account_uri) ) ) -    return GNUNET_OK; - -  fprintf (stdout, -           "%llu: %s->%s (%s) over %s at %s\n", -           (unsigned long long) serial_id, -           details->debit_account_uri, -           details->credit_account_uri, -           TALER_B2S (&details->reserve_pub), -           TALER_amount2s (&details->amount), -           GNUNET_TIME_timestamp2s (details->execution_date)); -  return GNUNET_OK; +  GNUNET_SCHEDULER_shutdown ();  } @@ -264,84 +253,71 @@ execute_credit_history (void)  /** - * Function with the debit debit transaction history. + * Function with the debit transaction history.   *   * @param cls closure - * @param http_status HTTP response code, #MHD_HTTP_OK (200) for successful status request - *                    0 if the bank's reply is bogus (fails to follow the protocol), - *                    #MHD_HTTP_NO_CONTENT if there are no more results; on success the - *                    last callback is always of this status (even if `abs(num_results)` were - *                    already returned). - * @param ec detailed error code - * @param serial_id monotonically increasing counter corresponding to the transaction - * @param details details about the wire transfer - * @param json detailed response from the HTTPD, or NULL if reply was not in JSON - * @return #GNUNET_OK to continue, #GNUNET_SYSERR to abort iteration + * @param reply response details   */ -static enum GNUNET_GenericReturnValue +static void  debit_history_cb (void *cls, -                  unsigned int http_status, -                  enum TALER_ErrorCode ec, -                  uint64_t serial_id, -                  const struct TALER_BANK_DebitDetails *details, -                  const json_t *json) +                  const struct TALER_BANK_DebitHistoryResponse *reply)  {    (void) cls;    dhh = NULL; -  if (MHD_HTTP_OK != http_status) +  switch (reply->http_status)    { -    if ( (MHD_HTTP_NO_CONTENT != http_status) || -         (TALER_EC_NONE != ec) ) +  case 0: +    fprintf (stderr, +             "Failed to obtain HTTP reply from `%s'\n", +             auth.wire_gateway_url); +    global_ret = 2; +    break; +  case MHD_HTTP_NO_CONTENT: +    fprintf (stdout, +             "No transactions.\n"); +    global_ret = 0; +    break; +  case MHD_HTTP_OK: +    for (unsigned int i = 0; i<reply->details.success.details_length; i++)      { -      if (0 == http_status) -      { -        fprintf (stderr, -                 "Failed to obtain HTTP reply from `%s'\n", -                 auth.wire_gateway_url); -      } -      else -      { -        fprintf (stderr, -                 "Failed to obtain debit history from `%s': HTTP status %u (%s)\n", -                 auth.wire_gateway_url, -                 http_status, -                 TALER_ErrorCode_get_hint (ec)); -      } -      if (NULL != json) -        json_dumpf (json, -                    stderr, -                    JSON_INDENT (2)); -      global_ret = 2; -      GNUNET_SCHEDULER_shutdown (); -      return GNUNET_NO; +      const struct TALER_BANK_DebitDetails *dd = +        &reply->details.success.details[i]; + +      /* If credit/debit accounts were specified, use as a filter */ +      if ( (NULL != credit_account) && +           (0 != strcasecmp (credit_account, +                             dd->credit_account_uri) ) ) +        continue; +      if ( (NULL != debit_account) && +           (0 != strcasecmp (debit_account, +                             dd->debit_account_uri) ) ) +        continue; +      fprintf (stdout, +               "%llu: %s->%s (%s) over %s at %s\n", +               (unsigned long long) dd->serial_id, +               dd->debit_account_uri, +               dd->credit_account_uri, +               TALER_B2S (&dd->wtid), +               TALER_amount2s (&dd->amount), +               GNUNET_TIME_timestamp2s (dd->execution_date));      } -    fprintf (stdout, -             "End of transactions list.\n");      global_ret = 0; -    GNUNET_SCHEDULER_shutdown (); -    return GNUNET_NO; +    break; +  default: +    fprintf (stderr, +             "Failed to obtain debit history from `%s': HTTP status %u (%s)\n", +             auth.wire_gateway_url, +             reply->http_status, +             TALER_ErrorCode_get_hint (reply->ec)); +    if (NULL != reply->response) +      json_dumpf (reply->response, +                  stderr, +                  JSON_INDENT (2)); +    global_ret = 2; +    break;    } - -  /* If credit/debit accounts were specified, use as a filter */ -  if ( (NULL != credit_account) && -       (0 != strcasecmp (credit_account, -                         details->credit_account_uri) ) ) -    return GNUNET_OK; -  if ( (NULL != debit_account) && -       (0 != strcasecmp (debit_account, -                         details->debit_account_uri) ) ) -    return GNUNET_OK; - -  fprintf (stdout, -           "%llu: %s->%s (%s) over %s at %s\n", -           (unsigned long long) serial_id, -           details->debit_account_uri, -           details->credit_account_uri, -           TALER_B2S (&details->wtid), -           TALER_amount2s (&details->amount), -           GNUNET_TIME_timestamp2s (details->execution_date)); -  return GNUNET_OK; +  GNUNET_SCHEDULER_shutdown ();  } | 
