Line data Source code
1 : /* 2 : This file is part of TALER 3 : Copyright (C) 2022 Taler Systems SA 4 : 5 : TALER is free software; you can redistribute it and/or modify it under the 6 : terms of the GNU General Public License as published by the Free Software 7 : Foundation; either version 3, or (at your option) any later version. 8 : 9 : TALER is distributed in the hope that it will be useful, but WITHOUT ANY 10 : WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR 11 : A PARTICULAR PURPOSE. See the GNU General Public License for more details. 12 : 13 : You should have received a copy of the GNU General Public License along with 14 : TALER; see the file COPYING. If not, see <http://www.gnu.org/licenses/> 15 : */ 16 : /** 17 : * @file exchangedb/pg_insert_auditor.c 18 : * @brief Implementation of the insert_auditor function for Postgres 19 : * @author Christian Grothoff 20 : */ 21 : #include "platform.h" 22 : #include "taler_error_codes.h" 23 : #include "taler_dbevents.h" 24 : #include "taler_pq_lib.h" 25 : #include "pg_insert_auditor.h" 26 : #include "pg_helper.h" 27 : 28 : enum GNUNET_DB_QueryStatus 29 6 : TEH_PG_insert_auditor (void *cls, 30 : const struct TALER_AuditorPublicKeyP *auditor_pub, 31 : const char *auditor_url, 32 : const char *auditor_name, 33 : struct GNUNET_TIME_Timestamp start_date) 34 : { 35 6 : struct PostgresClosure *pg = cls; 36 6 : struct GNUNET_PQ_QueryParam params[] = { 37 6 : GNUNET_PQ_query_param_auto_from_type (auditor_pub), 38 6 : GNUNET_PQ_query_param_string (auditor_name), 39 6 : GNUNET_PQ_query_param_string (auditor_url), 40 6 : GNUNET_PQ_query_param_timestamp (&start_date), 41 : GNUNET_PQ_query_param_end 42 : }; 43 : 44 : /* used in #postgres_insert_auditor() */ 45 6 : PREPARE (pg, 46 : "insert_auditor", 47 : "INSERT INTO auditors " 48 : "(auditor_pub" 49 : ",auditor_name" 50 : ",auditor_url" 51 : ",is_active" 52 : ",last_change" 53 : ") VALUES " 54 : "($1, $2, $3, true, $4);"); 55 6 : return GNUNET_PQ_eval_prepared_non_select (pg->conn, 56 : "insert_auditor", 57 : params); 58 : }