diff options
| author | Marcello Stanisci <stanisci.m@gmail.com> | 2019-04-17 14:54:46 +0200 | 
|---|---|---|
| committer | Marcello Stanisci <stanisci.m@gmail.com> | 2019-04-18 13:33:59 +0200 | 
| commit | 5d3ae9655eb4275a28c9484bde9ca9aa4a14b139 (patch) | |
| tree | d87544e6e2f01a387894d176fb8af3a170912492 /src | |
| parent | 1fdec6b1bff1475eaee6246442d303e3c52251ce (diff) | |
Wire plugin.
Put logic to use the history-range API.
Diffstat (limited to 'src')
| -rw-r--r-- | src/wire-plugins/plugin_wire_taler-bank.c | 102 | 
1 files changed, 85 insertions, 17 deletions
| diff --git a/src/wire-plugins/plugin_wire_taler-bank.c b/src/wire-plugins/plugin_wire_taler-bank.c index e4dd1c06..d100dec5 100644 --- a/src/wire-plugins/plugin_wire_taler-bank.c +++ b/src/wire-plugins/plugin_wire_taler-bank.c @@ -1014,10 +1014,11 @@ bhist_cb (void *cls,   * transfers.  The @a start_off value must thus match the value of   * a `row_off` argument previously given to the @a hres_cb.  Use   * NULL to query transfers from the beginning of time (with - * positive @a num_results) or from the lataler_bank committed transfers - * (with negative @a num_results). + * positive @a num_results) or from the lataler_bank committed + * transfers (with negative @a num_results).   * - * @param cls the @e cls of this struct with the plugin-specific state + * @param cls the @e cls of this struct with the plugin-specific + *        state   * @param account_section specifies the configuration section which   *        identifies the account for which we should get the history   * @param direction what kinds of wire transfers should be returned @@ -1059,13 +1060,18 @@ taler_bank_get_history (void *cls,         (sizeof (uint64_t) != start_off_len) )    {      GNUNET_log (GNUNET_ERROR_TYPE_ERROR, -                "Wire plugin 'taler_bank' got start offset of wrong size (%llu instead of %llu)\n", +                "Wire plugin 'taler_bank' got" +                " start offset of wrong size (%llu" +                " instead of %llu)\n",                  (unsigned long long) start_off_len,                  (unsigned long long) sizeof (uint64_t));      GNUNET_break (0); -    /* Probably something is wrong with the DB, some other component -     * wrote a wrong value to it.  Instead of completely stopping to work, -     * we just scan from the beginning. */ + +    /** +     * Probably something is wrong with the DB, some +     * other component wrote a wrong value to it.  Instead +     * of completely stopping to work, we just scan from the +     * beginning. */      start_off = NULL;    }    if (NULL == start_off) @@ -1109,7 +1115,7 @@ taler_bank_get_history (void *cls,                                  &whh->auth,                                  (uint64_t) account.no,                                  direction, -                                /* Defaults to descending ordering always. */ +               /* Defaults to descending ordering always. */                                  GNUNET_NO,                                  start_row,                                  num_results, @@ -1136,9 +1142,11 @@ taler_bank_get_history (void *cls,   * Query transfer history of an account.  The query is based on   * the dates where the wire transfers got settled at the bank.   * - * @param cls the @e cls of this struct with the plugin-specific state + * @param cls the @e cls of this struct with the plugin-specific + *        state   * @param account_section specifies the configuration section which - *        identifies the account for which we should get the history + *        identifies the account for which we should get the + *        history   * @param direction what kinds of wire transfers should be returned   * @param start_date each history entry in the result will be time   *        stamped after, or at this date. @@ -1149,16 +1157,76 @@ taler_bank_get_history (void *cls,   * @param return the operation handle, or NULL on errors.   */  static struct TALER_WIRE_HistoryHandle * -taler_bank_get_history_range (void *cls, -                              const char *account_section, -                              enum TALER_BANK_Direction direction, -                              struct GNUNET_TIME_Absolute start_date, -                              struct GNUNET_TIME_Absolute end_date, -                              TALER_WIRE_HistoryResultCallback hres_cb, -                              void *hres_cb_cls) +taler_bank_get_history_range +  (void *cls, +   const char *account_section, +   enum TALER_BANK_Direction direction, +   struct GNUNET_TIME_Absolute start_date, +   struct GNUNET_TIME_Absolute end_date, +   TALER_WIRE_HistoryResultCallback hres_cb, +   void *hres_cb_cls)  {    GNUNET_break (0);    return NULL; + +  struct Account account; +  struct TalerBankClosure *tc = cls; +  struct TALER_WIRE_HistoryHandle *whh; + +  if (GNUNET_OK != +      parse_account_cfg (tc->cfg, +                         account_section, +                         &account)) +  { +    GNUNET_log (GNUNET_ERROR_TYPE_ERROR, +                "Could not parse the config section '%s'\n", +                account_section); +    return NULL; +  } + +  whh = GNUNET_new (struct TALER_WIRE_HistoryHandle); +  whh->hres_cb = hres_cb; +  whh->hres_cb_cls = hres_cb_cls; + +  if (GNUNET_OK != +      TALER_BANK_auth_parse_cfg (tc->cfg, +                                 account_section, +                                 &whh->auth)) +  { +    GNUNET_log (GNUNET_ERROR_TYPE_ERROR, +                "Could not parse the auth values from '%s'\n", +                account_section); +    GNUNET_free (whh); +    return NULL; +  } + + +  whh->hh = TALER_BANK_history_range (tc->ctx, +                                      account.bank_base_url, +                                      &whh->auth, +                                      account.no, +                                      direction, +                            /* Just always descending.  */ +                                      GNUNET_NO, +                                      start_date, +                                      end_date, +                                      &bhist_cb, +                                      whh); +  if (NULL == whh->hh) +  { +    GNUNET_break (0); +    taler_bank_get_history_cancel (NULL, +                                   whh); +    GNUNET_free (account.hostname); +    GNUNET_free (account.bank_base_url); +    return NULL; +  } + +  GNUNET_free (account.hostname); +  GNUNET_free (account.bank_base_url); +  GNUNET_assert (NULL != whh); + +  return whh;  } | 
