[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[taler-merchant] 11/277: implement GET /instances/
From: |
gnunet |
Subject: |
[taler-merchant] 11/277: implement GET /instances/ |
Date: |
Sun, 05 Jul 2020 20:48:44 +0200 |
This is an automated email from the git hooks/post-receive script.
grothoff pushed a commit to branch master
in repository merchant.
commit e93a9431facf52909c79f61b978db339a8c9ac11
Author: Christian Grothoff <christian@grothoff.org>
AuthorDate: Sat Apr 18 17:59:57 2020 +0200
implement GET /instances/
---
src/backend/Makefile.am | 8 +-
src/backend/taler-merchant-httpd.c | 32 +++++--
src/backend/taler-merchant-httpd.h | 2 +-
...taler-merchant-httpd_private-get-instances-ID.c | 102 +++++++++++++++++++++
...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
index db8969d..025ac4c 100644
--- 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
index 7f5e32f..7f6d4dd 100644
--- 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
index 3a8b307..00d8df7 100644
--- 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
new file mode 100644
index 0000000..c379bfa
--- /dev/null
+++ 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
new file mode 100644
index 0000000..8532ad1
--- /dev/null
+++ 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
--
To stop receiving notification emails like this one, please contact
gnunet@gnunet.org.
- [taler-merchant] branch master updated (9782a22 -> f829235), gnunet, 2020/07/05
- [taler-merchant] 01/277: first draft of new SQL logic, gnunet, 2020/07/05
- [taler-merchant] 03/277: complete first draft of new SQL schema, gnunet, 2020/07/05
- [taler-merchant] 02/277: rework merchant schema, gnunet, 2020/07/05
- [taler-merchant] 04/277: starting v1 protocol dispatching logic, gnunet, 2020/07/05
- [taler-merchant] 06/277: complete bootstrap logic in new design, gnunet, 2020/07/05
- [taler-merchant] 05/277: sketch instance loading, gnunet, 2020/07/05
- [taler-merchant] 07/277: implement GET /instances, gnunet, 2020/07/05
- [taler-merchant] 09/277: implement instances_get in library, gnunet, 2020/07/05
- [taler-merchant] 11/277: implement GET /instances/,
gnunet <=
- [taler-merchant] 08/277: support PATCH as well, gnunet, 2020/07/05
- [taler-merchant] 12/277: start on DELETE instance, gnunet, 2020/07/05
- [taler-merchant] 10/277: implement POST /instances, gnunet, 2020/07/05
- [taler-merchant] 14/277: implement PATCH, gnunet, 2020/07/05
- [taler-merchant] 13/277: implement DELETE /instances/$ID, gnunet, 2020/07/05
- [taler-merchant] 18/277: implement POST products/lock, gnunet, 2020/07/05
- [taler-merchant] 15/277: implement GET /products, gnunet, 2020/07/05
- [taler-merchant] 17/277: implement PATCH handlers, gnunet, 2020/07/05
- [taler-merchant] 19/277: backenddb implementation work, gnunet, 2020/07/05
- [taler-merchant] 23/277: specify remaining /instance API, gnunet, 2020/07/05