/* This file is part of TALER Copyright (C) 2024 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 */ #include "platform.h" #include #include #include #include #include #include "taler_json_lib.h" #include "taler_mhd_lib.h" #include "taler-auditor-httpd.h" #include "taler-auditor-httpd_purse-not-closed-inconsistencies-put.h" /** * We have parsed the JSON information about the purse-not-closed-inconsistencies, do some * basic sanity checks and then execute the * transaction. * * @param connection the MHD connection to handle * @param dc information about the purse-not-closed-inconsistencies * @return MHD result code */ static MHD_RESULT process_inconsistency ( struct MHD_Connection *connection, const struct TALER_AUDITORDB_PurseNotClosedInconsistencies *dc) { enum GNUNET_DB_QueryStatus qs; if (GNUNET_SYSERR == TAH_plugin->preflight (TAH_plugin->cls)) { GNUNET_break (0); return TALER_MHD_reply_with_error (connection, MHD_HTTP_INTERNAL_SERVER_ERROR, TALER_EC_GENERIC_DB_SETUP_FAILED, NULL); } /* execute transaction */ qs = TAH_plugin->insert_purse_not_closed_inconsistencies (TAH_plugin->cls, dc); if (0 > qs) { GNUNET_break (GNUNET_DB_STATUS_HARD_ERROR == qs); TALER_LOG_WARNING ( "Failed to store /purse-not-closed-inconsistencies in database\n"); return TALER_MHD_reply_with_error (connection, MHD_HTTP_INTERNAL_SERVER_ERROR, TALER_EC_GENERIC_DB_STORE_FAILED, "purse-not-closed-inconsistencies"); } return TALER_MHD_REPLY_JSON_PACK (connection, MHD_HTTP_OK, GNUNET_JSON_pack_string ("status", "PURSE_NOT_CLOSED_INCONSISTENCIES_OK")); } MHD_RESULT TAH_PURSE_NOT_CLOSED_INCONSISTENCIES_PUT_handler ( struct TAH_RequestHandler *rh, struct MHD_Connection *connection, void **connection_cls, const char *upload_data, size_t *upload_data_size, const char *const args[]) { struct TALER_AUDITORDB_PurseNotClosedInconsistencies dc; struct GNUNET_JSON_Specification spec[] = { // TODO: fill in // GNUNET_JSON_spec_... ("", &dc.), // TALER_JSON_spec_... ("", TAH_currency, &dc.), GNUNET_JSON_spec_fixed_auto ("purse_pub", &dc.purse_pub), TALER_JSON_spec_amount ("amount", TAH_currency, &dc.amount), GNUNET_JSON_spec_int64 ("progress_offset", &dc.expiration_date), GNUNET_JSON_spec_end () }; json_t *json; (void) rh; (void) connection_cls; (void) upload_data; (void) upload_data_size; { enum GNUNET_GenericReturnValue res; res = TALER_MHD_parse_post_json (connection, connection_cls, upload_data, upload_data_size, &json); if (GNUNET_SYSERR == res) return MHD_NO; if ((GNUNET_NO == res) || (NULL == json)) return MHD_YES; res = TALER_MHD_parse_json_data (connection, json, spec); if (GNUNET_SYSERR == res) { json_decref (json); return MHD_NO; /* hard failure */ } if (GNUNET_NO == res) { json_decref (json); return MHD_YES; /* failure */ } } MHD_RESULT res; res = process_inconsistency (connection, &dc); GNUNET_JSON_parse_free (spec); json_decref (json); return res; } void TEAH_PURSE_NOT_CLOSED_INCONSISTENCIES_PUT_init (void) { } void TEAH_PURSE_NOT_CLOSED_INCONSISTENCIES_PUT_done (void) { }