diff options
author | Christian Grothoff <christian@grothoff.org> | 2018-05-09 17:33:04 +0200 |
---|---|---|
committer | Christian Grothoff <christian@grothoff.org> | 2018-05-09 17:33:04 +0200 |
commit | 8bb475af99260f1d107dbc8908268ae93960aa83 (patch) | |
tree | 1a7a1fc03424df841a6f977b137482439b09bc9f /src/sq | |
parent | 1f80a11e90ee982bffaae4685e281f75ee1c225d (diff) |
implement new functions in libgnunetsq, clean up sqlite namestore plugin, implement flow control in namestore API and tests
Diffstat (limited to 'src/sq')
-rw-r--r-- | src/sq/Makefile.am | 4 | ||||
-rw-r--r-- | src/sq/sq_exec.c | 109 | ||||
-rw-r--r-- | src/sq/sq_prepare.c | 81 |
3 files changed, 193 insertions, 1 deletions
diff --git a/src/sq/Makefile.am b/src/sq/Makefile.am index 119a947349..fb93640054 100644 --- a/src/sq/Makefile.am +++ b/src/sq/Makefile.am @@ -1,5 +1,5 @@ # This Makefile.am is in the public domain -AM_CPPFLAGS = -I$(top_srcdir)/src/include +AM_CPPFLAGS = -I$(top_srcdir)/src/include if MINGW WINFLAGS = -Wl,--no-undefined -Wl,--export-all-symbols @@ -15,6 +15,8 @@ endif libgnunetsq_la_SOURCES = \ sq.c \ + sq_exec.c \ + sq_prepare.c \ sq_query_helper.c \ sq_result_helper.c libgnunetsq_la_LIBADD = -lsqlite3 \ diff --git a/src/sq/sq_exec.c b/src/sq/sq_exec.c new file mode 100644 index 0000000000..c40b1fb75b --- /dev/null +++ b/src/sq/sq_exec.c @@ -0,0 +1,109 @@ +/* + This file is part of GNUnet + Copyright (C) 2018 GNUnet e.V. + + GNUnet 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. + + GNUnet 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 + GNUnet; see the file COPYING. If not, If not, see <http://www.gnu.org/licenses/> +*/ +/** + * @file sq/sq_exec.c + * @brief helper functions for executing SQL statements + * @author Christian Grothoff + */ +#include "platform.h" +#include "gnunet_sq_lib.h" + + +/** + * Create a `struct GNUNET_SQ_ExecuteStatement` where errors are fatal. + * + * @param sql actual SQL statement + * @return initialized struct + */ +struct GNUNET_SQ_ExecuteStatement +GNUNET_SQ_make_execute (const char *sql) + { + struct GNUNET_SQ_ExecuteStatement es = { + .sql = sql, + .ignore_errors = GNUNET_NO + }; + + return es; +} + + + +/** + * Create a `struct GNUNET_SQ_ExecuteStatement` where errors should + * be tolerated. + * + * @param sql actual SQL statement + * @return initialized struct + */ +struct GNUNET_SQ_ExecuteStatement +GNUNET_SQ_make_try_execute (const char *sql) +{ + struct GNUNET_SQ_ExecuteStatement es = { + .sql = sql, + .ignore_errors = GNUNET_YES + }; + + return es; +} + + +/** + * Request execution of an array of statements @a es from Postgres. + * + * @param dbh database to execute the statements over + * @param es #GNUNET_PQ_PREPARED_STATEMENT_END-terminated array of prepared + * statements. + * @return #GNUNET_OK on success (modulo statements where errors can be ignored) + * #GNUNET_SYSERR on error + */ +int +GNUNET_SQ_exec_statements (sqlite3 *dbh, + const struct GNUNET_SQ_ExecuteStatement *es) +{ + for (unsigned int i=0;NULL != es[i].sql;i++) + { + char *emsg = NULL; + + if (SQLITE_OK != + sqlite3_exec (dbh, + es[i].sql, + NULL, + NULL, + &emsg)) + { + if (es[i].ignore_errors) + { + GNUNET_log (GNUNET_ERROR_TYPE_DEBUG, + "Failed to run SQL `%s': %s\n", + es[i].sql, + emsg); + } + else + { + GNUNET_log (GNUNET_ERROR_TYPE_ERROR, + "Failed to run SQL `%s': %s\n", + es[i].sql, + emsg); + sqlite3_free (emsg); + return GNUNET_SYSERR; + } + sqlite3_free (emsg); + } + } + return GNUNET_OK; +} + +/* end of sq_exec */ diff --git a/src/sq/sq_prepare.c b/src/sq/sq_prepare.c new file mode 100644 index 0000000000..db1047c756 --- /dev/null +++ b/src/sq/sq_prepare.c @@ -0,0 +1,81 @@ +/* + This file is part of GNUnet + Copyright (C) 2018 GNUnet e.V. + + GNUnet 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. + + GNUnet 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 + GNUnet; see the file COPYING. If not, If not, see <http://www.gnu.org/licenses/> +*/ +/** + * @file sq/sq_prepare.c + * @brief helper functions for executing SQL statements + * @author Christian Grothoff + */ +#include "platform.h" +#include "gnunet_sq_lib.h" + + +/** + * Create a `struct GNUNET_SQ_PrepareStatement` + * + * @param sql actual SQL statement + * @param pstmt where to store the handle + * @return initialized struct + */ +struct GNUNET_SQ_PrepareStatement +GNUNET_SQ_make_prepare (const char *sql, + sqlite3_stmt **pstmt) +{ + struct GNUNET_SQ_PrepareStatement ps = { + .sql = sql, + .pstmt = pstmt + }; + + return ps; +} + + + +/** + * Prepare all statements given in the (NULL,NULL)-terminated + * array at @a ps + * + * @param dbh database to use + * @param ps array of statements to prepare + * @return #GNUNET_OK on success + */ +int +GNUNET_SQ_prepare (sqlite3 *dbh, + const struct GNUNET_SQ_PrepareStatement *ps) +{ + for (unsigned int i=0;NULL != ps[i].sql;i++) + { + const char *epos = NULL; + int ret; + + if (SQLITE_OK != + (ret = sqlite3_prepare_v2 (dbh, + ps[i].sql, + strlen (ps[i].sql), + ps[i].pstmt, + &epos))) + { + GNUNET_log (GNUNET_ERROR_TYPE_ERROR, + "Failed to prepare SQL `%s': error %d at %s\n", + ps[i].sql, + ret, + epos); + return GNUNET_SYSERR; + } + } + return GNUNET_OK; +} + +/* end of sq_prepare.c */ |