diff options
| author | Sree Harsha Totakura <sreeharsha@totakura.in> | 2015-03-05 16:31:33 +0100 | 
|---|---|---|
| committer | Sree Harsha Totakura <sreeharsha@totakura.in> | 2015-03-06 10:31:57 +0100 | 
| commit | 39c538311dd13bf5691700e698528c8562e7d726 (patch) | |
| tree | a0ab7b0d1457bd32a54758b265cbab7f971bc1bf /src | |
| parent | 363773698ae164bcdbf822a75b692b15940d27b1 (diff) | |
db: Use a reserve structure
Diffstat (limited to 'src')
| -rw-r--r-- | src/mint/mint_db.c | 24 | ||||
| -rw-r--r-- | src/mint/mint_db.h | 32 | 
2 files changed, 39 insertions, 17 deletions
| diff --git a/src/mint/mint_db.c b/src/mint/mint_db.c index b9f30ac3..e029d056 100644 --- a/src/mint/mint_db.c +++ b/src/mint/mint_db.c @@ -852,25 +852,27 @@ TALER_MINT_DB_commit (PGconn *db_conn)   * Get the summary of a reserve.   *   * @param db the database connection handle - * @param reserve_pub the public key identifying the reserve - * @param balance the amount existing in the reserve (will be filled) - * @param expiry expiration of the reserve (will be filled) - * @return #GNUNET_OK upon success; #GNUNET_NO when the given reserve is not - *           found; #GNUNET_SYSERR upon failure + * @param reserve the reserve data.  The public key of the reserve should be set + *          in this structure; it is used to query the database.  The balance + *          and expiration are then filled accordingly. + * @return #GNUNET_OK upon success; #GNUNET_SYSERR upon failure   */  int  TALER_MINT_DB_reserve_get (PGconn *db, -                           struct GNUNET_CRYPTO_EddsaPublicKey *reserve_pub, -                           struct TALER_Amount *balance, -                           struct GNUNET_TIME_Absolute *expiry) +                           struct Reserve *reserve)  {    PGresult *result;    uint64_t expiration_date_nbo;    struct TALER_DB_QueryParam params[] = { -    TALER_DB_QUERY_PARAM_PTR(reserve_pub), +    TALER_DB_QUERY_PARAM_PTR(reserve->pub),      TALER_DB_QUERY_PARAM_END    }; +  if (NULL == reserve->pub) +  { +    GNUNET_break (0); +    return GNUNET_SYSERR; +  }    result = TALER_DB_exec_prepared (db,                                     "get_reserve",                                     params); @@ -897,8 +899,8 @@ TALER_MINT_DB_reserve_get (PGconn *db,                                     "current_balance_value",                                     "current_balance_fraction",                                     "current_balance_currency", -                                   balance)); -  expiry->abs_value_us = GNUNET_ntohll (expiration_date_nbo); +                                   &reserve->balance)); +  reserve->expiry.abs_value_us = GNUNET_ntohll (expiration_date_nbo);    PQclear (result);    return GNUNET_OK; diff --git a/src/mint/mint_db.h b/src/mint/mint_db.h index b80f750b..b26c70b2 100644 --- a/src/mint/mint_db.h +++ b/src/mint/mint_db.h @@ -137,6 +137,27 @@ struct BankTransfer  /* FIXME: add functions to add bank transfers to our DB     (and to test if we already did add one) (#3633) */ +/** + * A summary of a Reserve + */ +struct Reserve +{ +  /** +   * The reserve's public key.  This uniquely identifies the reserve +   */ +  struct GNUNET_CRYPTO_EddsaPublicKey *pub; + +  /** +   * The balance amount existing in the reserve +   */ +  struct TALER_Amount balance; + +  /** +   * The expiration date of this reserve +   */ +  struct GNUNET_TIME_Absolute expiry; +}; +  /**   * Information we keep for a withdrawn coin to reproduce @@ -173,16 +194,15 @@ struct CollectableBlindcoin   * Get the summary of a reserve.   *   * @param db the database connection handle - * @param reserve_pub the public key identifying the reserve - * @param balance the amount existing in the reserve (will be filled) - * @param expiry expiration of the reserve (will be filled) + * @param reserve the reserve data.  The public key of the reserve should be set + *          in this structure; it is used to query the database.  The balance + *          and expiration are then filled accordingly.   * @return #GNUNET_OK upon success; #GNUNET_SYSERR upon failure   */  int  TALER_MINT_DB_reserve_get (PGconn *db, -                           struct GNUNET_CRYPTO_EddsaPublicKey *reserve_pub, -                           struct TALER_Amount *balance, -                           struct GNUNET_TIME_Absolute *expiry); +                           struct Reserve *reserve); +  /* FIXME: need call to convert CollectableBlindcoin to JSON (#3527) */ | 
