2013-01-31 22:20:23 +01:00
|
|
|
/*
|
|
|
|
* mysql.c, SJ
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <syslog.h>
|
|
|
|
#include <piler.h>
|
|
|
|
|
|
|
|
|
2017-08-08 15:34:45 +02:00
|
|
|
int open_database(struct session_data *sdata, struct config *cfg){
|
2013-04-28 14:18:09 +02:00
|
|
|
int rc=1;
|
2017-06-24 06:07:38 +00:00
|
|
|
char buf[BUFLEN];
|
2013-04-28 14:18:09 +02:00
|
|
|
|
|
|
|
mysql_init(&(sdata->mysql));
|
|
|
|
|
|
|
|
mysql_options(&(sdata->mysql), MYSQL_OPT_CONNECT_TIMEOUT, (const char*)&cfg->mysql_connect_timeout);
|
|
|
|
mysql_options(&(sdata->mysql), MYSQL_OPT_RECONNECT, (const char*)&rc);
|
|
|
|
|
|
|
|
if(mysql_real_connect(&(sdata->mysql), cfg->mysqlhost, cfg->mysqluser, cfg->mysqlpwd, cfg->mysqldb, cfg->mysqlport, cfg->mysqlsocket, 0) == 0){
|
2019-01-13 15:12:14 +00:00
|
|
|
syslog(LOG_PRIORITY, "cant connect to mysql server");
|
2013-04-28 14:18:09 +02:00
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
2017-06-24 06:07:38 +00:00
|
|
|
snprintf(buf, sizeof(buf)-2, "SET NAMES %s", cfg->mysqlcharset);
|
|
|
|
mysql_real_query(&(sdata->mysql), buf, strlen(buf));
|
|
|
|
|
|
|
|
snprintf(buf, sizeof(buf)-2, "SET CHARACTER SET %s", cfg->mysqlcharset);
|
|
|
|
mysql_real_query(&(sdata->mysql), buf, strlen(buf));
|
2013-04-28 14:18:09 +02:00
|
|
|
|
|
|
|
return OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void close_database(struct session_data *sdata){
|
|
|
|
mysql_close(&(sdata->mysql));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
void p_bind_init(struct sql *sql){
|
2013-05-05 11:57:14 +02:00
|
|
|
int i;
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
sql->pos = 0;
|
2013-05-05 11:57:14 +02:00
|
|
|
|
|
|
|
for(i=0; i<MAX_SQL_VARS; i++){
|
2017-08-11 18:18:45 +02:00
|
|
|
sql->sql[i] = NULL;
|
|
|
|
sql->type[i] = TYPE_UNDEF;
|
|
|
|
sql->len[i] = 0;
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-01-02 08:16:38 +01:00
|
|
|
void p_query(struct session_data *sdata, char *s){
|
2013-05-05 11:57:14 +02:00
|
|
|
mysql_real_query(&(sdata->mysql), s, strlen(s));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
int p_exec_stmt(struct session_data *sdata, struct sql *sql){
|
2013-05-05 11:57:14 +02:00
|
|
|
MYSQL_BIND bind[MAX_SQL_VARS];
|
|
|
|
unsigned long length[MAX_SQL_VARS];
|
|
|
|
int i, ret=ERR;
|
|
|
|
|
2014-07-10 11:54:37 +02:00
|
|
|
sdata->sql_errno = 0;
|
2013-05-05 11:57:14 +02:00
|
|
|
memset(bind, 0, sizeof(bind));
|
|
|
|
|
|
|
|
for(i=0; i<MAX_SQL_VARS; i++){
|
2017-08-11 18:18:45 +02:00
|
|
|
if(sql->type[i] > TYPE_UNDEF){
|
2013-05-05 11:57:14 +02:00
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
switch(sql->type[i]) {
|
2013-05-15 11:52:41 +02:00
|
|
|
case TYPE_SHORT:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_SHORT;
|
2013-05-05 11:57:14 +02:00
|
|
|
bind[i].length = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case TYPE_LONG:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_LONG;
|
|
|
|
bind[i].length = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case TYPE_LONGLONG:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_LONGLONG;
|
|
|
|
bind[i].length = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case TYPE_STRING:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_STRING;
|
2017-08-11 18:18:45 +02:00
|
|
|
length[i] = strlen(sql->sql[i]);
|
2013-05-05 11:57:14 +02:00
|
|
|
bind[i].length = &length[i];
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
bind[i].buffer_type = 0;
|
|
|
|
bind[i].length = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
bind[i].buffer = sql->sql[i];
|
2013-05-05 11:57:14 +02:00
|
|
|
bind[i].is_null = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
else { break; }
|
|
|
|
}
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_bind_param(sql->stmt, bind)){
|
|
|
|
sdata->sql_errno = mysql_stmt_errno(sql->stmt);
|
2018-01-23 20:00:40 +01:00
|
|
|
syslog(LOG_PRIORITY, "ERROR: %s: mysql_stmt_bind_param() '%s' (errno: %d)", sdata->ttmpfile, mysql_stmt_error(sql->stmt), sdata->sql_errno);
|
2015-12-18 22:38:52 +01:00
|
|
|
return ret;
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_execute(sql->stmt)){
|
|
|
|
sdata->sql_errno = mysql_stmt_errno(sql->stmt);
|
2018-01-23 20:00:40 +01:00
|
|
|
syslog(LOG_PRIORITY, "ERROR: %s: mysql_stmt_execute() '%s' (errno: %d)", sdata->ttmpfile, mysql_error(&(sdata->mysql)), sdata->sql_errno);
|
2015-12-18 22:38:52 +01:00
|
|
|
return ret;
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ret = OK;
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
int p_store_results(struct sql *sql){
|
2013-05-05 11:57:14 +02:00
|
|
|
MYSQL_BIND bind[MAX_SQL_VARS];
|
|
|
|
int i, ret=ERR;
|
|
|
|
|
|
|
|
memset(bind, 0, sizeof(bind));
|
|
|
|
|
|
|
|
for(i=0; i<MAX_SQL_VARS; i++){
|
2017-08-11 18:18:45 +02:00
|
|
|
if(sql->type[i] > TYPE_UNDEF){
|
2013-05-05 11:57:14 +02:00
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
switch(sql->type[i]) {
|
2013-05-15 11:52:41 +02:00
|
|
|
case TYPE_SHORT: bind[i].buffer_type = MYSQL_TYPE_SHORT;
|
2013-05-05 11:57:14 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case TYPE_LONG: bind[i].buffer_type = MYSQL_TYPE_LONG;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case TYPE_LONGLONG:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_LONGLONG;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case TYPE_STRING:
|
|
|
|
bind[i].buffer_type = MYSQL_TYPE_STRING;
|
2017-08-11 18:18:45 +02:00
|
|
|
bind[i].buffer_length = sql->len[i];
|
2013-05-05 11:57:14 +02:00
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
bind[i].buffer_type = 0;
|
|
|
|
break;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
bind[i].buffer = (char *)sql->sql[i];
|
|
|
|
bind[i].is_null = &(sql->is_null[i]);
|
|
|
|
bind[i].length = &(sql->length[i]);
|
|
|
|
bind[i].error = &(sql->error[i]);
|
2013-05-05 11:57:14 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
else { break; }
|
|
|
|
}
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_bind_result(sql->stmt, bind)){
|
2015-12-18 22:38:52 +01:00
|
|
|
return ret;
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_store_result(sql->stmt)){
|
2015-12-18 22:38:52 +01:00
|
|
|
return ret;
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
ret = OK;
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
int p_fetch_results(struct sql *sql){
|
2013-05-05 11:57:14 +02:00
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_fetch(sql->stmt) == 0) return OK;
|
2013-05-05 11:57:14 +02:00
|
|
|
|
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
void p_free_results(struct sql *sql){
|
|
|
|
mysql_stmt_free_result(sql->stmt);
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
uint64 p_get_insert_id(struct sql *sql){
|
|
|
|
return mysql_stmt_insert_id(sql->stmt);
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
int p_get_affected_rows(struct sql *sql){
|
|
|
|
return mysql_stmt_affected_rows(sql->stmt);
|
2013-05-05 11:57:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
int prepare_sql_statement(struct session_data *sdata, struct sql *sql, char *s){
|
2015-07-24 14:28:31 +02:00
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
sql->stmt = mysql_stmt_init(&(sdata->mysql));
|
|
|
|
if(!(sql->stmt)){
|
|
|
|
syslog(LOG_PRIORITY, "%s: error: mysql_stmt_init()", sdata->ttmpfile);
|
2013-01-31 22:20:23 +01:00
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
if(mysql_stmt_prepare(sql->stmt, s, strlen(s))){
|
|
|
|
syslog(LOG_PRIORITY, "%s: error: mysql_stmt_prepare() %s => sql: %s", sdata->ttmpfile, mysql_stmt_error(sql->stmt), s);
|
2013-01-31 22:20:23 +01:00
|
|
|
return ERR;
|
|
|
|
}
|
|
|
|
|
2020-03-03 15:47:02 +01:00
|
|
|
return OK;
|
2013-01-31 22:20:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-08-11 18:18:45 +02:00
|
|
|
void close_prepared_statement(struct sql *sql){
|
|
|
|
if(sql->stmt) mysql_stmt_close(sql->stmt);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-01-31 22:20:23 +01:00
|
|
|
void insert_offset(struct session_data *sdata, int server_id){
|
|
|
|
char s[SMALLBUFSIZE];
|
|
|
|
uint64 id = server_id * 1000000000000ULL;
|
|
|
|
|
|
|
|
snprintf(s, sizeof(s)-1, "INSERT INTO %s (`id`) VALUES (%llu)", SQL_METADATA_TABLE, id);
|
|
|
|
|
|
|
|
mysql_real_query(&(sdata->mysql), s, strlen(s));
|
|
|
|
}
|