/* This file is part of GNUnet Copyright (C) 2016 GNUnet e.V. GNUnet 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 of the License, 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 Affero General Public License for more details. You should have received a copy of the GNU Affero General Public License along with this program. If not, see . SPDX-License-Identifier: AGPL3.0-or-later */ /** * @file my/my_query_helper.c * @brief library to help with access to a MySQL database * @author Christian Grothoff * @author Christophe Genevey */ #include "platform.h" #include #include "gnunet_my_lib.h" /** * Function called to clean up memory allocated * by a #GNUNET_MY_QueryConverter. * * @param cls closure * @param qbind array of parameter to clean up */ static void my_clean_query (void *cls, MYSQL_BIND *qbind) { (void) cls; GNUNET_free (qbind[0].buffer); } /** * Function called to convert input argument into SQL parameters. * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_fixed_size (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { (void) cls; GNUNET_assert (1 == qp->num_params); qbind->buffer = (void *) qp->data; qbind->buffer_length = qp->data_len; qbind->buffer_type = MYSQL_TYPE_BLOB; return 1; } /** * Generate query parameter for a buffer @a ptr of * @a ptr_size bytes. * * @param ptr pointer to the query parameter to pass * @param ptr_size number of bytes in @a ptr */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_fixed_size (const void *ptr, size_t ptr_size) { struct GNUNET_MY_QueryParam qp = { .conv = &my_conv_fixed_size, .cleaner = NULL, .conv_cls = NULL, .num_params = 1, .data = ptr, .data_len = (unsigned long) ptr_size }; return qp; } /** * Function called to convert input argument into SQL parameters. * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_string (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { (void) cls; GNUNET_assert (1 == qp->num_params); qbind->buffer = (void *) qp->data; qbind->buffer_length = qp->data_len; qbind->buffer_type = MYSQL_TYPE_STRING; return 1; } /** * Generate query parameter for a string * * @param ptr pointer to the string query parameter to pass */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_string (const char *ptr) { struct GNUNET_MY_QueryParam qp = { .conv = &my_conv_string, .cleaner = NULL, .conv_cls = NULL, .num_params = 1, .data = ptr, .data_len = strlen (ptr) }; return qp; } /** * Function called to convert input argument into SQL parameters * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_uint16 (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { (void) cls; GNUNET_assert (1 == qp->num_params); qbind->buffer = (void *) qp->data; qbind->buffer_length = sizeof(uint16_t); qbind->buffer_type = MYSQL_TYPE_SHORT; qbind->is_unsigned = 1; return 1; } /** * Generate query parameter for an uint16_t in host byte order. * * @param x pointer to the query parameter to pass */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_uint16 (const uint16_t *x) { struct GNUNET_MY_QueryParam res = { .conv = &my_conv_uint16, .cleaner = NULL, .conv_cls = NULL, .num_params = 1, .data = x, .data_len = sizeof(*x) }; return res; } /** * Function called to convert input argument into SQL parameters * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_uint32 (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { (void) cls; GNUNET_assert (1 == qp->num_params); qbind->buffer = (void *) qp->data; qbind->buffer_length = sizeof(uint32_t); qbind->buffer_type = MYSQL_TYPE_LONG; qbind->is_unsigned = 1; return 1; } /** * Generate query parameter for an uint32_t in host byte order * * @param x pointer to the query parameter to pass */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_uint32 (const uint32_t *x) { struct GNUNET_MY_QueryParam res = { .conv = &my_conv_uint32, .cleaner = NULL, .conv_cls = NULL, .num_params = 1, .data = x, .data_len = sizeof(*x) }; return res; } /** * Function called to convert input argument into SQL parameters * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_uint64 (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { (void) cls; GNUNET_assert (1 == qp->num_params); qbind->buffer = (void *) qp->data; qbind->buffer_length = sizeof(uint64_t); qbind->buffer_type = MYSQL_TYPE_LONGLONG; qbind->is_unsigned = 1; return 1; } /** * Generate query parameter for an uint64_t in host byte order * * @param x pointer to the query parameter to pass */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_uint64 (const uint64_t *x) { struct GNUNET_MY_QueryParam res = { .conv = &my_conv_uint64, .cleaner = NULL, .conv_cls = NULL, .num_params = 1, .data = x, .data_len = sizeof(*x) }; return res; } /** * Function called to convert input argument into SQL parameters * * @param cls closure * @param pq data about the query * @param qbind array of parameters to initialize * @return -1 on error */ static int my_conv_rsa_public_key (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { const struct GNUNET_CRYPTO_RsaPublicKey *rsa = qp->data; char *buf; size_t buf_size; (void) cls; GNUNET_assert (1 == qp->num_params); buf_size = GNUNET_CRYPTO_rsa_public_key_encode (rsa, &buf); qbind->buffer = (void *) buf; qbind->buffer_length = buf_size; qbind->buffer_type = MYSQL_TYPE_BLOB; return 1; } /** * Generate query parameter for an RSA public key. The * database must contain a BLOB type in the respective position. * * @param x the query parameter to pass * @return array entry for the query parameters to use */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_rsa_public_key (const struct GNUNET_CRYPTO_RsaPublicKey *x) { struct GNUNET_MY_QueryParam res = { .conv = &my_conv_rsa_public_key, .cleaner = &my_clean_query, .conv_cls = NULL, .num_params = 1, .data = x, .data_len = 0 }; return res; } /** * Function called to convert input argument into SQL parameters * *@param cls closure *@param pq data about the query *@param qbind array of parameters to initialize *@return -1 on error */ static int my_conv_rsa_signature (void *cls, const struct GNUNET_MY_QueryParam *qp, MYSQL_BIND *qbind) { const struct GNUNET_CRYPTO_RsaSignature *sig = qp->data; char *buf; size_t buf_size; (void) cls; GNUNET_assert (1 == qp->num_params); buf_size = GNUNET_CRYPTO_rsa_signature_encode (sig, &buf); qbind->buffer = (void *) buf; qbind->buffer_length = buf_size; qbind->buffer_type = MYSQL_TYPE_BLOB; return 1; } /** * Generate query parameter for an RSA signature. The * database must contain a BLOB type in the respective position * * @param x the query parameter to pass * @return array entry for the query parameters to use */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_rsa_signature (const struct GNUNET_CRYPTO_RsaSignature *x) { struct GNUNET_MY_QueryParam res = { .conv = &my_conv_rsa_signature, .cleaner = &my_clean_query, .conv_cls = NULL, .num_params = 1, .data = (x), .data_len = 0 }; return res; } /** * Generate query parameter for an absolute time value. * The database must store a 64-bit integer. * * @param x pointer to the query parameter to pass * @return array entry for the query parameters to use */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_absolute_time (const struct GNUNET_TIME_Absolute *x) { return GNUNET_MY_query_param_uint64 (&x->abs_value_us); } /** * Generate query parameter for an absolute time value. * The database must store a 64-bit integer. * * @param x pointer to the query parameter to pass */ struct GNUNET_MY_QueryParam GNUNET_MY_query_param_absolute_time_nbo (const struct GNUNET_TIME_AbsoluteNBO *x) { return GNUNET_MY_query_param_auto_from_type (&x->abs_value_us__); } /* end of my_query_helper.c */