commit e93a9431facf52909c79f61b978db339a8c9ac11
parent 741f7127849d8e5c8e5feacc34fc16d415fc2944
Author: Christian Grothoff <christian@grothoff.org>
Date: Sat, 18 Apr 2020 17:59:57 +0200
implement GET /instances/
Diffstat:
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