2008-06-17 20:27:32 +04:00
/* -------------------------------------------------------------------------- */
2020-04-30 16:00:02 +03:00
/* Copyright 2002-2020, OpenNebula Project, OpenNebula Systems */
2008-06-17 20:27:32 +04:00
/* */
/* Licensed under the Apache License, Version 2.0 (the "License"); you may */
/* not use this file except in compliance with the License. You may obtain */
/* a copy of the License at */
/* */
/* http://www.apache.org/licenses/LICENSE-2.0 */
/* */
/* Unless required by applicable law or agreed to in writing, software */
/* distributed under the License is distributed on an "AS IS" BASIS, */
/* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. */
/* See the License for the specific language governing permissions and */
/* limitations under the License. */
/* -------------------------------------------------------------------------- */
# ifndef SQLITE_DB_H_
# define SQLITE_DB_H_
# include <string>
# include <sstream>
# include <stdexcept>
2010-03-29 15:57:33 +04:00
# include "SqlDB.h"
2010-04-03 17:56:57 +04:00
# include "ObjectSQL.h"
2008-06-17 20:27:32 +04:00
2010-05-07 16:45:27 +04:00
# ifdef SQLITE_DB
2010-04-03 17:56:57 +04:00
2010-05-07 16:45:27 +04:00
# include <sqlite3.h>
2010-04-03 17:56:57 +04:00
2008-06-17 20:27:32 +04:00
/**
* SqliteDB class . Provides a wrapper to the sqlite3 database interface . It also
2010-03-29 15:57:33 +04:00
* provides " global " synchronization mechanism to use it in a multithread
2008-06-17 20:27:32 +04:00
* environment .
*/
2010-03-29 15:57:33 +04:00
class SqliteDB : public SqlDB
2008-06-17 20:27:32 +04:00
{
public :
2010-03-29 15:57:33 +04:00
2020-07-02 23:42:10 +03:00
SqliteDB ( const std : : string & db_name , int timeout ) ;
2010-03-29 15:57:33 +04:00
2010-05-07 16:45:27 +04:00
~ SqliteDB ( ) ;
2010-03-29 15:57:33 +04:00
/**
* This function returns a legal SQL string that can be used in an SQL
* statement .
* @ param str the string to be escaped
* @ return a valid SQL string or NULL in case of failure
*/
2020-07-05 23:01:32 +03:00
char * escape_str ( const std : : string & str ) const override ;
2010-03-29 15:57:33 +04:00
/**
* Frees a previously scaped string
* @ param str pointer to the str
*/
2020-07-05 23:01:32 +03:00
void free_str ( char * str ) const override ;
2010-03-29 15:57:33 +04:00
2017-04-18 17:32:23 +03:00
protected :
/**
* Wraps the sqlite3_exec function call , and locks the DB mutex .
* @ param sql_cmd the SQL command
* @ param callbak function to execute on each data returned , watch the
* mutex you block in the callback .
* @ param arg to pass to the callback function
* @ return 0 on success
*/
2019-09-03 18:11:28 +03:00
int exec_ext ( std : : ostringstream & cmd , Callbackable * obj , bool quiet ) override ;
2017-04-18 17:32:23 +03:00
2008-06-17 20:27:32 +04:00
private :
/**
* Fine - grain mutex for DB access
*/
2020-09-10 14:32:52 +03:00
std : : mutex _mutex ;
2008-06-17 20:27:32 +04:00
/**
* Pointer to the database .
*/
2020-04-13 18:32:21 +03:00
sqlite3 * db ;
2018-04-25 18:05:30 +03:00
2008-06-17 20:27:32 +04:00
} ;
2010-05-07 16:45:27 +04:00
# else
//CLass stub
class SqliteDB : public SqlDB
{
public :
2020-07-02 23:42:10 +03:00
SqliteDB ( const std : : string & db_name , int timeout )
2010-05-07 16:45:27 +04:00
{
2020-07-06 16:48:53 +03:00
throw std : : runtime_error ( " Aborting oned, Sqlite support not compiled! " ) ;
2019-09-03 18:11:28 +03:00
}
~ SqliteDB ( ) = default ;
2010-05-07 16:45:27 +04:00
2020-07-05 23:01:32 +03:00
char * escape_str ( const std : : string & str ) const override { return 0 ; }
2010-05-07 16:45:27 +04:00
2020-07-05 23:01:32 +03:00
void free_str ( char * str ) const override { } ;
2017-04-18 17:32:23 +03:00
protected :
2019-09-03 18:11:28 +03:00
int exec_ext ( std : : ostringstream & cmd , Callbackable * obj , bool quiet ) override
{
return - 1 ;
}
2010-05-07 16:45:27 +04:00
} ;
# endif
2008-06-17 20:27:32 +04:00
# endif /*SQLITE_DB_H_*/