2003-03-26 20:03:37 +08:00
|
|
|
//
|
|
|
|
// ZoneMinder Core Interfaces, $Date$, $Revision$
|
2008-07-25 17:33:23 +08:00
|
|
|
// Copyright (C) 2001-2008 Philip Coombes
|
2003-03-26 20:03:37 +08:00
|
|
|
//
|
|
|
|
// This program 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 2
|
|
|
|
// of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program 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 this program; if not, write to the Free Software
|
2016-12-26 23:23:16 +08:00
|
|
|
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
2003-03-26 20:03:37 +08:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef ZM_DB_H
|
|
|
|
#define ZM_DB_H
|
|
|
|
|
2018-03-02 11:20:29 +08:00
|
|
|
#include "zm_thread.h"
|
2021-02-26 06:08:43 +08:00
|
|
|
#include <condition_variable>
|
|
|
|
#include <mutex>
|
2021-02-04 11:47:28 +08:00
|
|
|
#include <mysql/mysql.h>
|
2021-02-11 02:49:07 +08:00
|
|
|
#include <mysql/mysqld_error.h>
|
2021-02-26 06:08:43 +08:00
|
|
|
#include <queue>
|
2021-02-25 08:59:55 +08:00
|
|
|
#include <string>
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
class zmDbQueue {
|
|
|
|
private:
|
|
|
|
std::queue<std::string> mQueue;
|
|
|
|
std::thread mThread;
|
|
|
|
std::mutex mMutex;
|
|
|
|
std::condition_variable mCondition;
|
|
|
|
bool mTerminate;
|
|
|
|
public:
|
|
|
|
zmDbQueue();
|
|
|
|
~zmDbQueue();
|
|
|
|
void push(const char *sql) { return push(std::string(sql)); };
|
2021-02-26 06:08:43 +08:00
|
|
|
void push(std::string &&sql);
|
2021-02-25 08:59:55 +08:00
|
|
|
void process();
|
|
|
|
};
|
2003-03-26 20:03:37 +08:00
|
|
|
|
2016-04-20 23:56:58 +08:00
|
|
|
class zmDbRow {
|
2018-03-02 11:20:29 +08:00
|
|
|
private:
|
|
|
|
MYSQL_RES *result_set;
|
|
|
|
MYSQL_ROW row;
|
|
|
|
public:
|
2020-11-02 05:11:19 +08:00
|
|
|
zmDbRow() : result_set(nullptr), row(nullptr) { };
|
2020-11-19 02:15:52 +08:00
|
|
|
MYSQL_RES *fetch(const char *query);
|
|
|
|
zmDbRow(MYSQL_RES *, MYSQL_ROW *row);
|
2018-03-02 11:20:29 +08:00
|
|
|
~zmDbRow();
|
|
|
|
|
2018-03-09 20:23:14 +08:00
|
|
|
MYSQL_ROW mysql_row() const { return row; };
|
|
|
|
|
2018-03-02 11:20:29 +08:00
|
|
|
char *operator[](unsigned int index) const {
|
|
|
|
return row[index];
|
|
|
|
}
|
2016-04-20 23:56:58 +08:00
|
|
|
};
|
|
|
|
|
2003-03-26 20:03:37 +08:00
|
|
|
extern MYSQL dbconn;
|
2021-02-26 01:26:26 +08:00
|
|
|
extern std::mutex db_mutex;
|
2021-02-25 08:59:55 +08:00
|
|
|
extern zmDbQueue dbQueue;
|
2003-03-26 20:03:37 +08:00
|
|
|
|
2021-02-07 20:44:41 +08:00
|
|
|
extern bool zmDbConnected;
|
|
|
|
|
2018-03-02 11:20:29 +08:00
|
|
|
bool zmDbConnect();
|
2014-11-15 05:17:44 +08:00
|
|
|
void zmDbClose();
|
2021-02-19 05:01:30 +08:00
|
|
|
int zmDbDo(const char *query);
|
|
|
|
int zmDbDoInsert(const char *query);
|
2014-11-15 05:17:44 +08:00
|
|
|
|
2021-02-25 08:59:55 +08:00
|
|
|
MYSQL_RES * zmDbFetch(const char *query);
|
|
|
|
zmDbRow *zmDbFetchOne(const char *query);
|
2015-07-17 01:04:28 +08:00
|
|
|
|
2003-03-26 20:03:37 +08:00
|
|
|
#endif // ZM_DB_H
|