merchant

Merchant backend to process payments, run by merchants
Log | Files | Refs | Submodules | README | LICENSE

commit e93a9431facf52909c79f61b978db339a8c9ac11
parent 741f7127849d8e5c8e5feacc34fc16d415fc2944
Author: Christian Grothoff <christian@grothoff.org>
Date:   Sat, 18 Apr 2020 17:59:57 +0200

implement GET /instances/

Diffstat:
Msrc/backend/Makefile.am | 8++++++--
Msrc/backend/taler-merchant-httpd.c | 32+++++++++++++++++++++++++-------
Msrc/backend/taler-merchant-httpd.h | 2+-
Asrc/backend/taler-merchant-httpd_private-get-instances-ID.c | 102+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Asrc/backend/taler-merchant-httpd_private-get-instances-ID.h | 41+++++++++++++++++++++++++++++++++++++++++
5 files changed, 175 insertions(+), 10 deletions(-)

diff --git a/src/backend/Makefile.am b/src/backend/Makefile.am @@ -23,8 +23,12 @@ taler_merchant_httpd_SOURCES = \ taler-merchant-httpd_config.c taler-merchant-httpd_config.h \ taler-merchant-httpd_exchanges.c taler-merchant-httpd_exchanges.h \ taler-merchant-httpd_mhd.c taler-merchant-httpd_mhd.h \ - taler-merchant-httpd_private-get-instances.c taler-merchant-httpd_private-get-instances.h \ - taler-merchant-httpd_private-post-instances.c taler-merchant-httpd_private-post-instances.h + taler-merchant-httpd_private-get-instances.c \ + taler-merchant-httpd_private-get-instances.h \ + taler-merchant-httpd_private-get-instances-ID.c \ + taler-merchant-httpd_private-get-instances-ID.h \ + taler-merchant-httpd_private-post-instances.c \ + taler-merchant-httpd_private-post-instances.h DEAD = \ taler-merchant-httpd_check-payment.c taler-merchant-httpd_check-payment.h \ diff --git a/src/backend/taler-merchant-httpd.c b/src/backend/taler-merchant-httpd.c @@ -29,6 +29,7 @@ #include "taler-merchant-httpd_exchanges.h" #include "taler-merchant-httpd_mhd.h" #include "taler-merchant-httpd_private-get-instances.h" +#include "taler-merchant-httpd_private-get-instances-ID.h" #include "taler-merchant-httpd_private-post-instances.h" /** @@ -728,6 +729,26 @@ url_handler (void *cls, .skip_instance = true, .handler = &TMH_private_get_instances }, + /* GET /instances/$ID/: */ + { + .url_prefix = "/", + .method = MHD_HTTP_METHOD_GET, + .handler = &TMH_private_get_instances_ID + }, +#if 0 + /* DELETE /instances/$ID/: */ + { + .url_prefix = "/", + .method = MHD_HTTP_METHOD_DELETE, + .handler = &TMH_private_delete_instances_ID + }, + /* PATCH /instances/$ID/: */ + { + .url_prefix = "/", + .method = MHD_HTTP_METHOD_PATCH, + .handler = &TMH_private_patch_instances_ID + }, +#endif { .url_prefix = "/instances", .method = MHD_HTTP_METHOD_POST, @@ -983,13 +1004,10 @@ url_handler (void *cls, GNUNET_assert (NULL != hc->rh); if ( (NULL == hc->instance) && (GNUNET_YES != hc->rh->skip_instance) ) - return TALER_MHD_reply_json_pack (connection, - MHD_HTTP_NOT_FOUND, - "{s:I, s:s}", - "code", - (json_int_t) TALER_EC_INSTANCE_UNKNOWN, - "error", - "merchant instance unknown"); + return TALER_MHD_reply_with_error (connection, + MHD_HTTP_NOT_FOUND, + TALER_EC_INSTANCE_UNKNOWN, + "merchant instance unknown"); hc->has_body = ( (0 == strcasecmp (method, MHD_HTTP_METHOD_POST)) || (0 == strcasecmp (method, diff --git a/src/backend/taler-merchant-httpd.h b/src/backend/taler-merchant-httpd.h @@ -158,7 +158,7 @@ struct TMH_RequestHandler bool have_id_segment; /** - * Does this request handler expect an instance? + * Does this request handler work without an instance? */ bool skip_instance; diff --git a/src/backend/taler-merchant-httpd_private-get-instances-ID.c b/src/backend/taler-merchant-httpd_private-get-instances-ID.c @@ -0,0 +1,102 @@ +/* + This file is part of TALER + (C) 2019, 2020 Taler Systems SA + + TALER is free software; you can redistribute it and/or modify it under the + terms of the GNU Affero 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 backend/taler-merchant-httpd_private-get-instances-ID.c + * @brief implement GET /instances/$ID + * @author Christian Grothoff + */ +#include "platform.h" +#include "taler-merchant-httpd_private-get-instances-ID.h" +#include <taler/taler_json_lib.h> + + +/** + * Handle a GET "/instances/$ID" request. + * + * @param rh context of the handler + * @param connection the MHD connection to handle + * @param[in,out] hc context with further information about the request + * @return MHD result code + */ +MHD_RESULT +TMH_private_get_instances_ID (const struct TMH_RequestHandler *rh, + struct MHD_Connection *connection, + struct TMH_HandlerContext *hc) +{ + struct TMH_MerchantInstance *mi = hc->instance; + json_t *ja; + + GNUNET_assert (NULL != mi); + ja = json_array (); + GNUNET_assert (NULL != ja); + for (struct TMH_WireMethod *wm = mi->wm_head; + NULL != wm; + wm = wm->next) + { + GNUNET_assert ( + 0 == + json_array_append_new ( + ja, + json_pack ( + "{s:O, s:o, s:O, s:o}", + "payto_uri", + json_object_get (wm->j_wire, + "payto_uri"), + "h_wire", + GNUNET_JSON_from_data_auto (&wm->h_wire), + "salt", + json_object_get (wm->j_wire, + "salt"), + "active", + (wm->active) ? json_true () : json_false ()))); + } + + return TALER_MHD_reply_json_pack ( + connection, + MHD_HTTP_OK, + "{s:o, s:s, s:o, s:O, s:O," + " s:o, s:o, s:I, s:o, s:o}", + "accounts", + ja, + "name", + mi->settings.name, + "merchant_pub", + GNUNET_JSON_from_data_auto ( + &mi->merchant_pub), + "address", + mi->settings.address, + "jurisdiction", + mi->settings.jurisdiction, + /* end of first group of 5 */ + "default_max_wire_fee", + TALER_JSON_from_amount ( + &mi->settings.default_max_wire_fee), + "default_max_deposit_fee", + TALER_JSON_from_amount ( + &mi->settings.default_max_wire_fee), + "default_wire_fee_amortization", + (json_int_t) + &mi->settings.default_wire_fee_amortization, + "default_wire_transfer_delay", + GNUNET_JSON_from_time_rel ( + mi->settings.default_wire_transfer_delay), + "default_pay_delay", + GNUNET_JSON_from_time_rel ( + mi->settings.default_pay_delay)); +} + + +/* end of taler-merchant-httpd_private-get-instances-ID.c */ diff --git a/src/backend/taler-merchant-httpd_private-get-instances-ID.h b/src/backend/taler-merchant-httpd_private-get-instances-ID.h @@ -0,0 +1,41 @@ +/* + This file is part of TALER + (C) 2019, 2020 Taler Systems SA + + TALER is free software; you can redistribute it and/or modify it under the + terms of the GNU Affero 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 backend/taler-merchant-httpd_private-get-instances-ID.h + * @brief implement GET /instances/$ID/ + * @author Christian Grothoff + */ +#ifndef TALER_MERCHANT_HTTPD_PRIVATE_GET_INSTANCES_ID_H +#define TALER_MERCHANT_HTTPD_PRIVATE_GET_INSTANCES_ID_H + +#include "taler-merchant-httpd.h" + + +/** + * Handle a GET "/instances/$ID" request. + * + * @param rh context of the handler + * @param connection the MHD connection to handle + * @param[in,out] hc context with further information about the request + * @return MHD result code + */ +MHD_RESULT +TMH_private_get_instances_ID (const struct TMH_RequestHandler *rh, + struct MHD_Connection *connection, + struct TMH_HandlerContext *hc); + +/* end of taler-merchant-httpd_private-get-instances-ID.h */ +#endif