diff options
author | Christian Grothoff <christian@grothoff.org> | 2020-04-12 15:41:35 +0200 |
---|---|---|
committer | Christian Grothoff <christian@grothoff.org> | 2020-04-12 15:41:35 +0200 |
commit | 4f02377b85e748b2c6e73834cda554e92f95e993 (patch) | |
tree | d2bed2c71cb016ae3c96a08a12335600593788b5 /src/backend/taler-merchant-httpd_tip-pickup.c | |
parent | 3b341f888c23f34018faec54b4768fbefef509d3 (diff) | |
download | merchant-4f02377b85e748b2c6e73834cda554e92f95e993.tar.gz merchant-4f02377b85e748b2c6e73834cda554e92f95e993.tar.bz2 merchant-4f02377b85e748b2c6e73834cda554e92f95e993.zip |
split file
Diffstat (limited to 'src/backend/taler-merchant-httpd_tip-pickup.c')
-rw-r--r-- | src/backend/taler-merchant-httpd_tip-pickup.c | 119 |
1 files changed, 1 insertions, 118 deletions
diff --git a/src/backend/taler-merchant-httpd_tip-pickup.c b/src/backend/taler-merchant-httpd_tip-pickup.c index 096af605..cfcbd052 100644 --- a/src/backend/taler-merchant-httpd_tip-pickup.c +++ b/src/backend/taler-merchant-httpd_tip-pickup.c @@ -577,7 +577,7 @@ MH_handler_tip_pickup (struct TMH_RequestHandler *rh, return TALER_MHD_reply_with_error (connection, MHD_HTTP_BAD_REQUEST, TALER_EC_TIP_PICKUP_EXCHANGE_TOO_MANY_PLANCHETS, - "limit of 1024 planchets exceeded by request"); + "per request limit of 1024 planchets exceeded"); } if (0 == pc->planchets_len) { @@ -614,120 +614,3 @@ MH_handler_tip_pickup (struct TMH_RequestHandler *rh, return ret; } } - - -/** - * Manages a GET /tip-pickup call, checking that the tip is authorized, - * and if so, returning the withdrawal permissions. - * - * @param rh context of the handler - * @param connection the MHD connection to handle - * @param[in,out] connection_cls the connection's closure (can be updated) - * @param upload_data upload data - * @param[in,out] upload_data_size number of bytes (left) in @a upload_data - * @param mi merchant backend instance, never NULL - * @return MHD result code - */ -MHD_RESULT -MH_handler_tip_pickup_get (struct TMH_RequestHandler *rh, - struct MHD_Connection *connection, - void **connection_cls, - const char *upload_data, - size_t *upload_data_size, - struct MerchantInstance *mi) -{ - const char *tip_id_str; - char *exchange_url; - json_t *extra; - struct GNUNET_HashCode tip_id; - struct TALER_Amount tip_amount; - struct TALER_Amount tip_amount_left; - struct GNUNET_TIME_Absolute timestamp; - struct GNUNET_TIME_Absolute timestamp_expire; - MHD_RESULT ret; - enum GNUNET_DB_QueryStatus qs; - - tip_id_str = MHD_lookup_connection_value (connection, - MHD_GET_ARGUMENT_KIND, - "tip_id"); - - if (NULL == tip_id_str) - { - /* tip_id is required but missing */ - GNUNET_break_op (0); - return TALER_MHD_reply_with_error (connection, - MHD_HTTP_BAD_REQUEST, - TALER_EC_PARAMETER_MISSING, - "tip_id required"); - } - - if (GNUNET_OK != - GNUNET_CRYPTO_hash_from_string (tip_id_str, - &tip_id)) - { - /* tip_id has wrong encoding */ - GNUNET_break_op (0); - return TALER_MHD_reply_with_error (connection, - MHD_HTTP_BAD_REQUEST, - TALER_EC_PARAMETER_MALFORMED, - "tip_id malformed"); - } - - db->preflight (db->cls); - qs = db->lookup_tip_by_id (db->cls, - &tip_id, - &exchange_url, - &extra, - &tip_amount, - &tip_amount_left, - ×tamp); - - if (GNUNET_DB_STATUS_SUCCESS_ONE_RESULT != qs) - { - unsigned int response_code; - enum TALER_ErrorCode ec; - - switch (qs) - { - case GNUNET_DB_STATUS_SUCCESS_NO_RESULTS: - ec = TALER_EC_TIP_PICKUP_TIP_ID_UNKNOWN; - response_code = MHD_HTTP_NOT_FOUND; - break; - case GNUNET_DB_STATUS_SOFT_ERROR: - ec = TALER_EC_TIP_PICKUP_DB_ERROR_SOFT; - response_code = MHD_HTTP_INTERNAL_SERVER_ERROR; - break; - case GNUNET_DB_STATUS_HARD_ERROR: - ec = TALER_EC_TIP_PICKUP_DB_ERROR_HARD; - response_code = MHD_HTTP_INTERNAL_SERVER_ERROR; - break; - default: - GNUNET_break (0); - ec = TALER_EC_INTERNAL_LOGIC_ERROR; - response_code = MHD_HTTP_INTERNAL_SERVER_ERROR; - break; - } - return TALER_MHD_reply_with_error (connection, - response_code, - ec, - "Could not determine exchange URL for the given tip id"); - } - - timestamp_expire = GNUNET_TIME_absolute_add (timestamp, - GNUNET_TIME_UNIT_DAYS); - - ret = TALER_MHD_reply_json_pack ( - connection, - MHD_HTTP_OK, - "{s:s, s:o, s:o, s:o, s:o, s:o}", - "exchange_url", exchange_url, - "amount", TALER_JSON_from_amount (&tip_amount), - "amount_left", TALER_JSON_from_amount (&tip_amount_left), - "stamp_created", GNUNET_JSON_from_time_abs (timestamp), - "stamp_expire", GNUNET_JSON_from_time_abs (timestamp_expire), - "extra", extra); - - GNUNET_free (exchange_url); - json_decref (extra); - return ret; -} |