You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
proxysql/include/MySQL_Logger.hpp

95 lines
2.4 KiB

#ifndef __CLASS_MYSQL_LOGGER_H
#define __CLASS_MYSQL_LOGGER_H
#include "proxysql.h"
#include "cpp.h"
#define PROXYSQL_LOGGER_PTHREAD_MUTEX
class MySQL_Event {
private:
uint32_t thread_id;
char *username;
char *schemaname;
size_t username_len;
size_t schemaname_len;
uint64_t start_time;
uint64_t end_time;
uint64_t query_digest;
char *query_ptr;
size_t query_len;
char *server;
char *client;
size_t server_len;
size_t client_len;
//uint64_t total_length;
unsigned char buf[10];
enum log_event_type et;
uint64_t hid;
char *extra_info;
bool have_affected_rows;
bool have_rows_sent;
uint64_t affected_rows;
uint64_t rows_sent;
public:
MySQL_Event(log_event_type _et, uint32_t _thread_id, char * _username, char * _schemaname , uint64_t _start_time , uint64_t _end_time , uint64_t _query_digest, char *_client, size_t _client_len);
uint64_t write(std::fstream *f, MySQL_Session *sess);
uint64_t write_query_format_1(std::fstream *f);
uint64_t write_query_format_2_json(std::fstream *f);
void write_auth(std::fstream *f, MySQL_Session *sess);
void set_query(const char *ptr, int len);
void set_server(int _hid, const char *ptr, int len);
void set_extra_info(char *);
void set_affected_rows(uint64_t ar);
void set_rows_sent(uint64_t rs);
};
class MySQL_Logger {
private:
struct {
bool enabled;
char *base_filename;
char *datadir;
unsigned int log_file_id;
unsigned int max_log_file_size;
std::fstream *logfile;
} events;
struct {
bool enabled;
char *base_filename;
char *datadir;
unsigned int log_file_id;
unsigned int max_log_file_size;
std::fstream *logfile;
} audit;
#ifdef PROXYSQL_LOGGER_PTHREAD_MUTEX
pthread_mutex_t wmutex;
#else
rwlock_t rwlock;
#endif
void events_close_log_unlocked();
void events_open_log_unlocked();
void audit_close_log_unlocked();
void audit_open_log_unlocked();
unsigned int events_find_next_id();
unsigned int audit_find_next_id();
public:
MySQL_Logger();
~MySQL_Logger();
void print_version();
void flush_log();
void events_flush_log_unlocked();
void audit_flush_log_unlocked();
void events_set_datadir(char *);
void events_set_base_filename();
void audit_set_datadir(char *);
void audit_set_base_filename();
void log_request(MySQL_Session *, MySQL_Data_Stream *);
void log_audit_entry(log_event_type, MySQL_Session *, MySQL_Data_Stream *, char *e = NULL);
void flush();
void wrlock();
void wrunlock();
};
#endif /* __CLASS_MYSQL_LOGGER_H */