diff options
| author | Özgür Kesim <oec-taler@kesim.org> | 2022-10-04 20:06:49 +0200 | 
|---|---|---|
| committer | Özgür Kesim <oec-taler@kesim.org> | 2022-10-04 20:06:49 +0200 | 
| commit | 0ad6a8cbfb4e6181a8db3547c0af42b9e914f5fc (patch) | |
| tree | 412390c110679a5b3042efd930268c521a695746 /src/exchangedb | |
| parent | 77266e6c93f3368171a8b17288f279195f1931dc (diff) | |
| parent | 1cf6fbe8dc69172b9db30a7b07f3a7ce81d6f75e (diff) | |
Merge branch 'master' into auction_brandt
Diffstat (limited to 'src/exchangedb')
| -rw-r--r-- | src/exchangedb/pg_do_reserve_open.c | 18 | ||||
| -rw-r--r-- | src/exchangedb/pg_do_reserve_open.h | 19 | ||||
| -rw-r--r-- | src/exchangedb/pg_iterate_reserve_close_info.h | 1 | ||||
| -rw-r--r-- | src/exchangedb/plugin_exchangedb_postgres.c | 2 | ||||
| -rw-r--r-- | src/exchangedb/procedures.sql | 26 | 
5 files changed, 53 insertions, 13 deletions
| diff --git a/src/exchangedb/pg_do_reserve_open.c b/src/exchangedb/pg_do_reserve_open.c index bd4f7240..f7a3a5f7 100644 --- a/src/exchangedb/pg_do_reserve_open.c +++ b/src/exchangedb/pg_do_reserve_open.c @@ -31,11 +31,13 @@ TEH_PG_do_reserve_open (    void *cls,    const struct TALER_ReservePublicKeyP *reserve_pub,    const struct TALER_Amount *total_paid, +  const struct TALER_Amount *reserve_payment,    uint32_t min_purse_limit,    const struct TALER_ReserveSignatureP *reserve_sig,    struct GNUNET_TIME_Timestamp desired_expiration,    struct GNUNET_TIME_Timestamp now,    const struct TALER_Amount *open_fee, +  bool *no_funds,    struct TALER_Amount *open_cost,    struct GNUNET_TIME_Timestamp *final_expiration)  { @@ -43,6 +45,7 @@ TEH_PG_do_reserve_open (    struct GNUNET_PQ_QueryParam params[] = {      GNUNET_PQ_query_param_auto_from_type (reserve_pub),      TALER_PQ_query_param_amount (total_paid), +    TALER_PQ_query_param_amount (reserve_payment),      GNUNET_PQ_query_param_uint32 (&min_purse_limit),      GNUNET_PQ_query_param_auto_from_type (reserve_sig),      GNUNET_PQ_query_param_timestamp (&desired_expiration), @@ -51,9 +54,11 @@ TEH_PG_do_reserve_open (      GNUNET_PQ_query_param_end    };    struct GNUNET_PQ_ResultSpec rs[] = { -    TALER_PQ_RESULT_SPEC_AMOUNT ("open_cost", +    GNUNET_PQ_result_spec_bool ("out_no_funds", +                                no_funds), +    TALER_PQ_RESULT_SPEC_AMOUNT ("out_open_cost",                                   open_cost), -    GNUNET_PQ_result_spec_timestamp ("final_expiration", +    GNUNET_PQ_result_spec_timestamp ("out_final_expiration",                                       final_expiration),      GNUNET_PQ_result_spec_end    }; @@ -61,11 +66,12 @@ TEH_PG_do_reserve_open (    PREPARE (pg,             "do_reserve_open",             "SELECT " -           " open_cost_val" -           ",open_cost_frac" -           ",final_expiration" +           " out_open_cost_val" +           ",out_open_cost_frac" +           ",out_final_expiration" +           ",out_no_funds"             " FROM exchange_do_reserve_open" -           " ($1,$2,$3,$4,$5,$6,$7,$8,$9);"); +           " ($1,$2,$3,$4,$5,$6,$7,$8,$9,$10,$11);");    return GNUNET_PQ_eval_prepared_singleton_select (pg->conn,                                                     "do_reserve_open",                                                     params, diff --git a/src/exchangedb/pg_do_reserve_open.h b/src/exchangedb/pg_do_reserve_open.h index aeef59eb..acf2d67e 100644 --- a/src/exchangedb/pg_do_reserve_open.h +++ b/src/exchangedb/pg_do_reserve_open.h @@ -27,15 +27,20 @@  /** - * Insert reserve close operation into database. + * Perform reserve open operation on database.   *   * @param cls closure   * @param reserve_pub which reserve is this about? - * @param execution_date when did we perform the transfer? - * @param receiver_account to which account do we transfer, in payto://-format - * @param wtid identifier for the wire transfer - * @param amount_with_fee amount we charged to the reserve - * @param closing_fee how high is the closing fee + * @param total_paid total amount paid (coins and reserve) + * @param reserve_payment amount to be paid from the reserve + * @param min_purse_limit minimum number of purses we should be able to open + * @param reserve_sig signature by the reserve for the operation + * @param desired_expiration when should the reserve expire (earliest time) + * @param now when did we the client initiate the action + * @param open_fee annual fee to be charged for the open operation by the exchange + * @param[out] no_funds set to true if reserve balance is insufficient + * @param[out] open_cost set to the actual cost + * @param[out] final_expiration when will the reserve expire now   * @return transaction status code   */  enum GNUNET_DB_QueryStatus @@ -43,11 +48,13 @@ TEH_PG_do_reserve_open (    void *cls,    const struct TALER_ReservePublicKeyP *reserve_pub,    const struct TALER_Amount *total_paid, +  const struct TALER_Amount *reserve_payment,    uint32_t min_purse_limit,    const struct TALER_ReserveSignatureP *reserve_sig,    struct GNUNET_TIME_Timestamp desired_expiration,    struct GNUNET_TIME_Timestamp now,    const struct TALER_Amount *open_fee, +  bool *no_funds,    struct TALER_Amount *open_cost,    struct GNUNET_TIME_Timestamp *final_expiration); diff --git a/src/exchangedb/pg_iterate_reserve_close_info.h b/src/exchangedb/pg_iterate_reserve_close_info.h index a7e7c8d4..34692e65 100644 --- a/src/exchangedb/pg_iterate_reserve_close_info.h +++ b/src/exchangedb/pg_iterate_reserve_close_info.h @@ -32,7 +32,6 @@   *   * @param cls closure   * @param h_payto which target account is this about? - * @param h_payto account identifier   * @param time_limit oldest transaction that could be relevant   * @param kac function to call for each applicable amount, in reverse chronological order (or until @a kac aborts by returning anything except #GNUNET_OK).   * @param kac_cls closure for @a kac diff --git a/src/exchangedb/plugin_exchangedb_postgres.c b/src/exchangedb/plugin_exchangedb_postgres.c index d2e2eb5d..04455808 100644 --- a/src/exchangedb/plugin_exchangedb_postgres.c +++ b/src/exchangedb/plugin_exchangedb_postgres.c @@ -17296,6 +17296,8 @@ libtaler_plugin_exchangedb_postgres_init (void *cls)    plugin->select_merge_amounts_for_kyc_check      = &postgres_select_merge_amounts_for_kyc_check;    /* NEW style, sort alphabetically! */ +  plugin->insert_reserve_open_deposit +    = &TEH_PG_insert_reserve_open_deposit;    plugin->insert_close_request      = &TEH_PG_insert_close_request;    plugin->iterate_reserve_close_info diff --git a/src/exchangedb/procedures.sql b/src/exchangedb/procedures.sql index 8407f20c..f39e359c 100644 --- a/src/exchangedb/procedures.sql +++ b/src/exchangedb/procedures.sql @@ -2175,4 +2175,30 @@ out_insufficient_funds=FALSE;  END $$; + +CREATE OR REPLACE FUNCTION exchange_do_reserve_open( +  IN in_reserve_pub BYTEA, +  IN in_total_paid_val INT8, +  IN in_total_paid_frac INT4, +  IN in_reserve_payment_val INT8, +  IN in_reserve_payment_frac INT4, +  IN in_min_purse_limit INT4, +  IN in_reserve_sig BYTEA, +  IN in_desired_expiration INT8, +  IN in_now INT8, +  IN in_open_fee_val INT8, +  IN in_open_fee_frac INT4, +  OUT out_open_cost_val INT8, +  OUT out_open_cost_frac INT4, +  OUT out_final_expiration INT8, +  OUT out_no_funds BOOLEAN) +LANGUAGE plpgsql +AS $$ +BEGIN + +-- FIXME: implement! + +END $$ + +  COMMIT; | 
