diff options
| author | Christian Grothoff <christian@grothoff.org> | 2023-04-16 10:05:38 +0200 | 
|---|---|---|
| committer | Christian Grothoff <christian@grothoff.org> | 2023-04-16 10:05:38 +0200 | 
| commit | 5121c6b1cfd71db641d0de8974091e295c22668a (patch) | |
| tree | bf78f4add9827e32f0cacecf61e52c5acef8ba60 | |
| parent | 2906ded1a6a407344a1d2eef3e58b06e65bc7576 (diff) | |
work on lookup_records_by_table
| -rw-r--r-- | src/exchangedb/pg_lookup_records_by_table.c | 276 | 
1 files changed, 276 insertions, 0 deletions
| diff --git a/src/exchangedb/pg_lookup_records_by_table.c b/src/exchangedb/pg_lookup_records_by_table.c index a23c034c..51894f23 100644 --- a/src/exchangedb/pg_lookup_records_by_table.c +++ b/src/exchangedb/pg_lookup_records_by_table.c @@ -232,6 +232,109 @@ lrbt_cb_table_wire_targets (void *cls,  /** + * Function called with legitimization_processes table entries. + * + * @param cls closure + * @param result the postgres result + * @param num_results the number of results in @a result + */ +static void +lrbt_cb_table_legitimization_processes (void *cls, +                                        PGresult *result, +                                        unsigned int num_results) +{ +  struct LookupRecordsByTableContext *ctx = cls; +  struct TALER_EXCHANGEDB_TableData td = { +    .table = TALER_EXCHANGEDB_RT_LEGITIMIZATION_PROCESSES +  }; + +  for (unsigned int i = 0; i<num_results; i++) +  { +    struct GNUNET_PQ_ResultSpec rs[] = { +      GNUNET_PQ_result_spec_uint64 ("serial", +                                    &td.serial), +      GNUNET_PQ_result_spec_auto_from_type ( +        "h_payto", +        &td.details.legitimization_processes.h_payto), +      GNUNET_PQ_result_spec_timestamp ( +        "expiration_time", +        &td.details.legitimization_processes.expiration_time), +      GNUNET_PQ_result_spec_string ( +        "provider_section", +        &td.details.legitimization_processes.provider_section), +      GNUNET_PQ_result_spec_string ( +        "provider_user_id", +        &td.details.legitimization_processes.provider_user_id), +      GNUNET_PQ_result_spec_string ( +        "provider_legitimization_id", +        &td.details.legitimization_processes.provider_legitimization_id), +      GNUNET_PQ_result_spec_end +    }; + +    if (GNUNET_OK != +        GNUNET_PQ_extract_result (result, +                                  rs, +                                  i)) +    { +      GNUNET_break (0); +      ctx->error = true; +      return; +    } +    ctx->cb (ctx->cb_cls, +             &td); +    GNUNET_PQ_cleanup_result (rs); +  } +} + + +/** + * Function called with legitimization_requirements table entries. + * + * @param cls closure + * @param result the postgres result + * @param num_results the number of results in @a result + */ +static void +lrbt_cb_table_legitimization_requirements (void *cls, +                                           PGresult *result, +                                           unsigned int num_results) +{ +  struct LookupRecordsByTableContext *ctx = cls; +  struct TALER_EXCHANGEDB_TableData td = { +    .table = TALER_EXCHANGEDB_RT_LEGITIMIZATION_REQUIREMENTS +  }; + +  for (unsigned int i = 0; i<num_results; i++) +  { +    struct GNUNET_PQ_ResultSpec rs[] = { +      GNUNET_PQ_result_spec_uint64 ("serial", +                                    &td.serial), +      GNUNET_PQ_result_spec_auto_from_type ( +        "h_payto", +        &td.details.legitimization_requirements.h_payto), +      GNUNET_PQ_result_spec_string ( +        "required_checks", +        &td.details.legitimization_requirements.required_checks), +      GNUNET_PQ_result_spec_end +    }; + +    if (GNUNET_OK != +        GNUNET_PQ_extract_result (result, +                                  rs, +                                  i)) +    { +      GNUNET_break (0); +      ctx->error = true; +      return; +    } +    ctx->cb (ctx->cb_cls, +             &td); +    GNUNET_PQ_cleanup_result (rs); +  } +} + + +/**   * Function called with reserves table entries.   *   * @param cls closure @@ -401,6 +504,123 @@ lrbt_cb_table_reserves_close (void *cls,  /** + * Function called with reserves_open_requests table entries. + * + * @param cls closure + * @param result the postgres result + * @param num_results the number of results in @a result + */ +static void +lrbt_cb_table_reserves_open_requests (void *cls, +                                      PGresult *result, +                                      unsigned int num_results) +{ +  struct LookupRecordsByTableContext *ctx = cls; +  struct PostgresClosure *pg = ctx->pg; +  struct TALER_EXCHANGEDB_TableData td = { +    .table = TALER_EXCHANGEDB_RT_RESERVES_OPEN_REQUESTS +  }; + +  for (unsigned int i = 0; i<num_results; i++) +  { +    struct GNUNET_PQ_ResultSpec rs[] = { +      GNUNET_PQ_result_spec_uint64 ("serial", +                                    &td.serial), +      GNUNET_PQ_result_spec_auto_from_type ( +        "reserve_pub", +        &td.details.reserves_open_requests.reserve_pub), +      GNUNET_PQ_result_spec_timestamp ( +        "request_timestamp", +        &td.details.reserves_open_requests.request_timestamp), +      GNUNET_PQ_result_spec_timestamp ( +        "expiration_date", +        &td.details.reserves_open_requests.expiration_date), +      GNUNET_PQ_result_spec_auto_from_type ( +        "reserve_sig", +        &td.details.reserves_open_requests.reserve_sig), +      TALER_PQ_RESULT_SPEC_AMOUNT ( +        "reserve_payment", +        &td.details.reserves_open_requests.reserve_payment), +      GNUNET_PQ_result_spec_uint32 ( +        "requested_purse_limit", +        &td.details.reserves_open_requests.requested_purse_limit), +      GNUNET_PQ_result_spec_end +    }; + +    if (GNUNET_OK != +        GNUNET_PQ_extract_result (result, +                                  rs, +                                  i)) +    { +      GNUNET_break (0); +      ctx->error = true; +      return; +    } +    ctx->cb (ctx->cb_cls, +             &td); +    GNUNET_PQ_cleanup_result (rs); +  } +} + + +/** + * Function called with reserves_open_deposits table entries. + * + * @param cls closure + * @param result the postgres result + * @param num_results the number of results in @a result + */ +static void +lrbt_cb_table_reserves_open_deposits (void *cls, +                                      PGresult *result, +                                      unsigned int num_results) +{ +  struct LookupRecordsByTableContext *ctx = cls; +  struct PostgresClosure *pg = ctx->pg; +  struct TALER_EXCHANGEDB_TableData td = { +    .table = TALER_EXCHANGEDB_RT_RESERVES_OPEN_DEPOSITS +  }; + +  for (unsigned int i = 0; i<num_results; i++) +  { +    struct GNUNET_PQ_ResultSpec rs[] = { +      GNUNET_PQ_result_spec_uint64 ("serial", +                                    &td.serial), +      GNUNET_PQ_result_spec_auto_from_type ( +        "reserve_sig", +        &td.details.reserves_open_deposits.reserve_sig), +      GNUNET_PQ_result_spec_auto_from_type ( +        "reserve_pub", +        &td.details.reserves_open_deposits.reserve_pub), +      GNUNET_PQ_result_spec_auto_from_type ( +        "coin_pub", +        &td.details.reserves_open_deposits.coin_pub), +      GNUNET_PQ_result_spec_auto_from_type ( +        "coin_sig", +        &td.details.reserves_open_deposits.coin_sig), +      TALER_PQ_RESULT_SPEC_AMOUNT ( +        "contribution", +        &td.details.reserves_open_deposits.contribution), +      GNUNET_PQ_result_spec_end +    }; + +    if (GNUNET_OK != +        GNUNET_PQ_extract_result (result, +                                  rs, +                                  i)) +    { +      GNUNET_break (0); +      ctx->error = true; +      return; +    } +    ctx->cb (ctx->cb_cls, +             &td); +    GNUNET_PQ_cleanup_result (rs); +  } +} + + +/**   * Function called with reserves_out table entries.   *   * @param cls closure @@ -2743,6 +2963,31 @@ TEH_PG_lookup_records_by_table (void *cls,                " ORDER BY wire_target_serial_id ASC;");      rh = &lrbt_cb_table_wire_targets;      break; +  case TALER_EXCHANGEDB_RT_LEGITIMIZATION_PROCESSES: +    XPREPARE ("select_above_serial_by_table_legitimization_processes", +              "SELECT" +              " legitimization_process_serial_id AS serial" +              ",h_payto" +              ",expiration_time" +              ",provider_section" +              ",provider_user_id" +              ",provider_legitimization_id" +              " FROM legitimization_processes" +              " WHERE legitimization_process_serial_id > $1" +              " ORDER BY legitimization_process_serial_id ASC;"); +    rh = &lrbt_cb_table_legitimization_processes; +    break; +  case TALER_EXCHANGEDB_RT_LEGITIMIZATION_REQUIREMENTS: +    XPREPARE ("select_above_serial_by_table_legitimization_requirements", +              "SELECT" +              " legitimization_requirement_serial_id AS serial" +              ",h_payto" +              ",required_checks" +              " FROM legitimization_requirements" +              " WHERE legitimization_requirement_serial_id > $1" +              " ORDER BY legitimization_requirement_serial_id ASC;"); +    rh = &lrbt_cb_table_legitimization_requirements; +    break;    case TALER_EXCHANGEDB_RT_RESERVES:      XPREPARE ("select_above_serial_by_table_reserves",                "SELECT" @@ -2788,6 +3033,37 @@ TEH_PG_lookup_records_by_table (void *cls,                " ORDER BY close_uuid ASC;");      rh = &lrbt_cb_table_reserves_close;      break; +  case TALER_EXCHANGEDB_RT_RESERVES_OPEN_REQUESTS: +    XPREPARE ("select_above_serial_by_table_reserves_open_requests", +              "SELECT" +              " open_request_uuid AS serial" +              ",reserve_pub" +              ",request_timestamp" +              ",expiration_date" +              ",reserve_sig" +              ",reserve_payment_val" +              ",reserve_payment_frac" +              ",requested_purse_limit" +              " FROM reserves_open_requests" +              " WHERE open_request_uuid > $1" +              " ORDER BY open_request_uuid ASC;"); +    rh = &lrbt_cb_table_reserves_open_requests; +    break; +  case TALER_EXCHANGEDB_RT_RESERVES_OPEN_DEPOSITS: +    XPREPARE ("select_above_serial_by_table_reserves_open_deposits", +              "SELECT" +              " reserves_open_deposit_uuid AS serial" +              ",reserve_sig" +              ",reserve_pub" +              ",coin_pub" +              ",coin_sig" +              ",contribution_val" +              ",contribution_frac" +              " FROM reserves_open_deposits" +              " WHERE reserves_open_deposit_uuid > $1" +              " ORDER BY reserves_open_deposit_uuid ASC;"); +    rh = &lrbt_cb_table_reserves_open_deposits; +    break;    case TALER_EXCHANGEDB_RT_RESERVES_OUT:      XPREPARE ("select_above_serial_by_table_reserves_out",                "SELECT" | 
