add API for /management/wire-fees
This commit is contained in:
parent
a3548f0efb
commit
a1af10a832
@ -2535,6 +2535,64 @@ TALER_EXCHANGE_management_disable_wire_cancel (
|
||||
struct TALER_EXCHANGE_ManagementWireDisableHandle *wh);
|
||||
|
||||
|
||||
/**
|
||||
* Function called with information about the wire enable operation result.
|
||||
*
|
||||
* @param cls closure
|
||||
* @param hr HTTP response data
|
||||
*/
|
||||
typedef void
|
||||
(*TALER_EXCHANGE_ManagementSetWireFeeCallback) (
|
||||
void *cls,
|
||||
const struct TALER_EXCHANGE_HttpResponse *hr);
|
||||
|
||||
|
||||
/**
|
||||
* @brief Handle for a POST /management/wire-fees request.
|
||||
*/
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle;
|
||||
|
||||
|
||||
/**
|
||||
* Inform the exchange about future wire fees.
|
||||
*
|
||||
* @param ctx the context
|
||||
* @param exchange_base_url HTTP base URL for the exchange
|
||||
* @param wire_method for which wire method are fees provided
|
||||
* @param validity_start start date for the provided wire fees
|
||||
* @param validity_end end date for the provided wire fees
|
||||
* @param wire_fee the wire fee for this time period
|
||||
* @param closing_fee the closing fee for this time period
|
||||
* @param master_sig signature affirming the wire fees;
|
||||
* of purpose #TALER_SIGNATURE_MASTER_WIRE_FEES
|
||||
* @param cb function to call with the exchange's result
|
||||
* @param cb_cls closure for @a cb
|
||||
* @return the request handle; NULL upon error
|
||||
*/
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *
|
||||
TALER_EXCHANGE_management_set_wire_fees (
|
||||
struct GNUNET_CURL_Context *ctx,
|
||||
const char *exchange_base_url,
|
||||
const char *wire_method,
|
||||
struct GNUNET_TIME_Absolute validity_start,
|
||||
struct GNUNET_TIME_Absolute validity_end,
|
||||
const struct TALER_Amount *wire_fee,
|
||||
const struct TALER_Amount *closing_fee,
|
||||
const struct TALER_MasterSignatureP *master_sig,
|
||||
TALER_EXCHANGE_ManagementWireEnableCallback cb,
|
||||
void *cb_cls);
|
||||
|
||||
|
||||
/**
|
||||
* Cancel #TALER_EXCHANGE_management_enable_wire() operation.
|
||||
*
|
||||
* @param wh handle of the operation to cancel
|
||||
*/
|
||||
void
|
||||
TALER_EXCHANGE_management_set_wire_fees_cancel (
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *swfh);
|
||||
|
||||
|
||||
/**
|
||||
* Function called with information about the POST
|
||||
* /auditor/$AUDITOR_PUB/$H_DENOM_PUB operation result.
|
||||
|
@ -34,6 +34,7 @@ libtalerexchange_la_SOURCES = \
|
||||
exchange_api_management_post_keys.c \
|
||||
exchange_api_management_revoke_denomination_key.c \
|
||||
exchange_api_management_revoke_signing_key.c \
|
||||
exchange_api_management_set_wire_fee.c \
|
||||
exchange_api_management_wire_disable.c \
|
||||
exchange_api_management_wire_enable.c \
|
||||
exchange_api_melt.c \
|
||||
|
220
src/lib/exchange_api_management_set_wire_fee.c
Normal file
220
src/lib/exchange_api_management_set_wire_fee.c
Normal file
@ -0,0 +1,220 @@
|
||||
/*
|
||||
This file is part of TALER
|
||||
Copyright (C) 2020 Taler Systems SA
|
||||
|
||||
TALER is free software; you can redistribute it and/or modify it under the
|
||||
terms of the GNU General Public License as published by the Free Software
|
||||
Foundation; either version 3, or (at your option) any later version.
|
||||
|
||||
TALER is distributed in the hope that it will be useful, but WITHOUT ANY
|
||||
WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
||||
A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License along with
|
||||
TALER; see the file COPYING. If not, see
|
||||
<http://www.gnu.org/licenses/>
|
||||
*/
|
||||
/**
|
||||
* @file lib/exchange_api_management_set_wire_fee.c
|
||||
* @brief functions to set wire fees at an exchange
|
||||
* @author Christian Grothoff
|
||||
*/
|
||||
#include "platform.h"
|
||||
#include "taler_json_lib.h"
|
||||
#include <gnunet/gnunet_curl_lib.h>
|
||||
#include "taler_exchange_service.h"
|
||||
#include "taler_signatures.h"
|
||||
#include "taler_curl_lib.h"
|
||||
#include "taler_json_lib.h"
|
||||
|
||||
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle
|
||||
{
|
||||
|
||||
/**
|
||||
* The url for this request.
|
||||
*/
|
||||
char *url;
|
||||
|
||||
/**
|
||||
* Minor context that holds body and headers.
|
||||
*/
|
||||
struct TALER_CURL_PostContext post_ctx;
|
||||
|
||||
/**
|
||||
* Handle for the request.
|
||||
*/
|
||||
struct GNUNET_CURL_Job *job;
|
||||
|
||||
/**
|
||||
* Function to call with the result.
|
||||
*/
|
||||
TALER_EXCHANGE_ManagementSetWireFeeCallback cb;
|
||||
|
||||
/**
|
||||
* Closure for @a cb.
|
||||
*/
|
||||
void *cb_cls;
|
||||
|
||||
/**
|
||||
* Reference to the execution context.
|
||||
*/
|
||||
struct GNUNET_CURL_Context *ctx;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Function called when we're done processing the
|
||||
* HTTP /management/wire request.
|
||||
*
|
||||
* @param cls the `struct TALER_EXCHANGE_ManagementAuditorEnableHandle *`
|
||||
* @param response_code HTTP response code, 0 on error
|
||||
* @param response response body, NULL if not in JSON
|
||||
*/
|
||||
static void
|
||||
handle_set_wire_fee_finished (void *cls,
|
||||
long response_code,
|
||||
const void *response)
|
||||
{
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *swfh = cls;
|
||||
const json_t *json = response;
|
||||
struct TALER_EXCHANGE_HttpResponse hr = {
|
||||
.http_status = (unsigned int) response_code,
|
||||
.reply = json
|
||||
};
|
||||
|
||||
swfh->job = NULL;
|
||||
switch (response_code)
|
||||
{
|
||||
case MHD_HTTP_NO_CONTENT:
|
||||
break;
|
||||
case MHD_HTTP_FORBIDDEN:
|
||||
hr.ec = TALER_JSON_get_error_code (json);
|
||||
hr.hint = TALER_JSON_get_error_hint (json);
|
||||
break;
|
||||
case MHD_HTTP_CONFLICT:
|
||||
hr.ec = TALER_JSON_get_error_code (json);
|
||||
hr.hint = TALER_JSON_get_error_hint (json);
|
||||
break;
|
||||
case MHD_HTTP_PRECONDITION_FAILED:
|
||||
hr.ec = TALER_JSON_get_error_code (json);
|
||||
hr.hint = TALER_JSON_get_error_hint (json);
|
||||
break;
|
||||
default:
|
||||
/* unexpected response code */
|
||||
GNUNET_break_op (0);
|
||||
hr.ec = TALER_JSON_get_error_code (json);
|
||||
hr.hint = TALER_JSON_get_error_hint (json);
|
||||
GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
|
||||
"Unexpected response code %u/%d\n",
|
||||
(unsigned int) response_code,
|
||||
(int) hr.ec);
|
||||
break;
|
||||
}
|
||||
if (NULL != swfh->cb)
|
||||
{
|
||||
swfh->cb (swfh->cb_cls,
|
||||
&hr);
|
||||
swfh->cb = NULL;
|
||||
}
|
||||
TALER_EXCHANGE_management_set_wire_fees_cancel (swfh);
|
||||
}
|
||||
|
||||
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *
|
||||
TALER_EXCHANGE_management_set_wire_fees (
|
||||
struct GNUNET_CURL_Context *ctx,
|
||||
const char *exchange_base_url,
|
||||
const char *wire_method,
|
||||
struct GNUNET_TIME_Absolute validity_start,
|
||||
struct GNUNET_TIME_Absolute validity_end,
|
||||
const struct TALER_Amount *wire_fee,
|
||||
const struct TALER_Amount *closing_fee,
|
||||
const struct TALER_MasterSignatureP *master_sig,
|
||||
TALER_EXCHANGE_ManagementWireEnableCallback cb,
|
||||
void *cb_cls)
|
||||
{
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *swfh;
|
||||
CURL *eh;
|
||||
json_t *body;
|
||||
|
||||
swfh = GNUNET_new (struct TALER_EXCHANGE_ManagementSetWireFeeHandle);
|
||||
swfh->cb = cb;
|
||||
swfh->cb_cls = cb_cls;
|
||||
swfh->ctx = ctx;
|
||||
swfh->url = TALER_url_join (exchange_base_url,
|
||||
"management/wire-fee",
|
||||
NULL);
|
||||
if (NULL == swfh->url)
|
||||
{
|
||||
GNUNET_log (GNUNET_ERROR_TYPE_ERROR,
|
||||
"Could not construct request URL.\n");
|
||||
GNUNET_free (swfh);
|
||||
return NULL;
|
||||
}
|
||||
body = json_pack ("{s:s, s:o, s:o, s:o, s:o}",
|
||||
"wire_method",
|
||||
wire_method,
|
||||
"master_sig",
|
||||
GNUNET_JSON_from_data_auto (master_sig),
|
||||
"fee_start",
|
||||
GNUNET_JSON_from_time_abs (validity_start),
|
||||
"fee_end",
|
||||
GNUNET_JSON_from_time_abs (validity_end),
|
||||
"closing_fee",
|
||||
TALER_JSON_from_amount (closing_fee),
|
||||
"wire_fee",
|
||||
TALER_JSON_from_amount (wire_fee));
|
||||
if (NULL == body)
|
||||
{
|
||||
GNUNET_break (0);
|
||||
GNUNET_free (swfh->url);
|
||||
GNUNET_free (swfh);
|
||||
return NULL;
|
||||
}
|
||||
eh = curl_easy_init ();
|
||||
if (GNUNET_OK !=
|
||||
TALER_curl_easy_post (&swfh->post_ctx,
|
||||
eh,
|
||||
body))
|
||||
{
|
||||
GNUNET_break (0);
|
||||
json_decref (body);
|
||||
GNUNET_free (swfh->url);
|
||||
GNUNET_free (eh);
|
||||
return NULL;
|
||||
}
|
||||
json_decref (body);
|
||||
GNUNET_log (GNUNET_ERROR_TYPE_DEBUG,
|
||||
"Requesting URL '%s'\n",
|
||||
swfh->url);
|
||||
GNUNET_assert (CURLE_OK == curl_easy_setopt (eh,
|
||||
CURLOPT_URL,
|
||||
swfh->url));
|
||||
swfh->job = GNUNET_CURL_job_add2 (ctx,
|
||||
eh,
|
||||
swfh->post_ctx.headers,
|
||||
&handle_set_wire_fee_finished,
|
||||
swfh);
|
||||
if (NULL == swfh->job)
|
||||
{
|
||||
TALER_EXCHANGE_management_set_wire_fees_cancel (swfh);
|
||||
return NULL;
|
||||
}
|
||||
return swfh;
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
TALER_EXCHANGE_management_set_wire_fees_cancel (
|
||||
struct TALER_EXCHANGE_ManagementSetWireFeeHandle *swfh)
|
||||
{
|
||||
if (NULL != swfh->job)
|
||||
{
|
||||
GNUNET_CURL_job_cancel (swfh->job);
|
||||
swfh->job = NULL;
|
||||
}
|
||||
TALER_curl_easy_post_finished (&swfh->post_ctx);
|
||||
GNUNET_free (swfh->url);
|
||||
GNUNET_free (swfh);
|
||||
}
|
@ -117,21 +117,6 @@ handle_auditor_enable_finished (void *cls,
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Inform the exchange that a wire account should be enabled.
|
||||
*
|
||||
* @param ctx the context
|
||||
* @param url HTTP base URL for the exchange
|
||||
* @param payto_uri RFC 8905 URI of the exchange's bank account
|
||||
* @param validity_start when was this decided?
|
||||
* @param master_sig1 signature affirming the wire addition
|
||||
* of purpose #TALER_SIGNATURE_MASTER_ADD_WIRE
|
||||
* @param master_sig2 signature affirming the validity of the account for clients;
|
||||
* of purpose #TALER_SIGNATURE_MASTER_WIRE_DETAILS.
|
||||
* @param cb function to call with the exchange's result
|
||||
* @param cb_cls closure for @a cb
|
||||
* @return the request handle; NULL upon error
|
||||
*/
|
||||
struct TALER_EXCHANGE_ManagementWireEnableHandle *
|
||||
TALER_EXCHANGE_management_enable_wire (
|
||||
struct GNUNET_CURL_Context *ctx,
|
||||
@ -210,11 +195,6 @@ TALER_EXCHANGE_management_enable_wire (
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Cancel #TALER_EXCHANGE_management_enable_wire() operation.
|
||||
*
|
||||
* @param wh handle of the operation to cancel
|
||||
*/
|
||||
void
|
||||
TALER_EXCHANGE_management_enable_wire_cancel (
|
||||
struct TALER_EXCHANGE_ManagementWireEnableHandle *wh)
|
||||
|
Loading…
Reference in New Issue
Block a user