2020-04-13 17:32:21 +02:00
/* -------------------------------------------------------------------------- */
2023-01-09 12:23:19 +01:00
/* Copyright 2002-2023, OpenNebula Project, OpenNebula Systems */
2020-04-13 17:32:21 +02: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 POSTGRESQL_DB_H_
# define POSTGRESQL_DB_H_
# include <string>
# include <queue>
2020-09-10 13:32:52 +02:00
# include <mutex>
# include <condition_variable>
2020-04-13 17:32:21 +02:00
# include "SqlDB.h"
# ifdef POSTGRESQL_DB
# include <libpq-fe.h>
/**
* PostgreSqlDB class . Provides a wrapper to the PostgreSQL database interface .
*/
class PostgreSqlDB : public SqlDB
{
public :
PostgreSqlDB (
2024-06-03 11:40:24 +02:00
const std : : string & _server ,
int _port ,
const std : : string & _user ,
const std : : string & _password ,
const std : : string & _database ,
int _connections ) ;
2020-04-13 17:32:21 +02:00
~ PostgreSqlDB ( ) ;
/**
* 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 22:01:32 +02:00
char * escape_str ( const std : : string & str ) const override ;
2020-04-13 17:32:21 +02:00
/**
* Frees a previously scaped string
* @ param str pointer to the str
*/
2020-07-05 22:01:32 +02:00
void free_str ( char * str ) const override ;
2020-04-13 17:32:21 +02:00
/**
* @ param sid the offset
* @ param eid the rowcount
* @ return string with compatible LIMIT clause syntax
* LIMIT row_count OFFSET offset
2020-07-02 22:42:10 +02:00
*
2020-04-13 17:32:21 +02:00
* + - - - + - - - + - - - + - - - + - - - + - - - + - - - + - - - + - -
* | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | . . .
* + - - - + - - - + - - - + - - - + - - - + - - - + - - - + - - - + - -
* | |
* / - - - - - - - - - - - - - - - - - - - /
* LIMIT 5 OFFSET 3
*/
2020-07-05 22:01:32 +02:00
std : : string limit_string ( int sid , int eid ) const override
2020-04-13 17:32:21 +02:00
{
std : : ostringstream oss ;
oss < < " LIMIT " < < eid < < " OFFSET " < < sid ;
return oss . str ( ) ;
}
2020-07-05 22:01:32 +02:00
std : : string limit_string ( int sid ) const override
2020-04-13 17:32:21 +02:00
{
std : : ostringstream oss ;
oss < < " LIMIT " < < sid < < " OFFSET 0 " ;
return oss . str ( ) ;
}
protected :
int exec_ext ( std : : ostringstream & cmd , Callbackable * obj , bool quiet ) override ;
private :
/**
* Number of concurrent DB connections .
*/
int max_connections ;
/**
* Connection pool
*/
2020-07-02 22:42:10 +02:00
std : : queue < PGconn * > db_connect ;
2020-04-13 17:32:21 +02:00
/**
* DB connection to escape strings
*/
PGconn * db_escape_connect ;
/**
* Connection parameters
*/
2020-07-02 22:42:10 +02:00
std : : string server ;
int port ;
std : : string user ;
std : : string password ;
std : : string database ;
2020-04-13 17:32:21 +02:00
/**
* Fine - grain mutex for DB access ( pool of DB connections )
*/
2020-09-10 13:32:52 +02:00
std : : mutex _mutex ;
2020-04-13 17:32:21 +02:00
/**
* Conditional variable to wake - up waiting threads .
*/
2020-09-10 13:32:52 +02:00
std : : condition_variable cond ;
2020-04-13 17:32:21 +02:00
/**
* Gets a free DB connection from the pool .
*/
PGconn * get_db_connection ( ) ;
/**
* Returns the connection to the pool .
*/
void free_db_connection ( PGconn * db ) ;
/**
* Preprocesses the query to be compatible with PostgreSQL syntax
*
* Any change to this method should be reflected in BackEndPostgreSQL class
* in src / onedb / onedb_backend . rb
*
* This method alters to queries :
* - CREATE TABLE to adjust type names
* . MEDIUMTEXT - > TEXT
* . LONGTEXT - > TEXT
* . BIGINT UNSIGNED - > NUMERIC
*
* - REPLACE INTO into PostgreSQL INSERT INTO query with ON CONFLICT
* clause . For example :
* REPLACE INTO pool_control ( tablename , last_oid ) VALUES ( ' acl ' , 0 )
* changes to :
* INSERT INTO pool_control ( tablename , last_oid ) VALUES ( ' acl ' , 0 )
* ON CONFLICT ( tablename ) DO UPDATE SET last_oid = EXCLUDED . last_oid
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* Any change to this method should be reflected in BackEndPostgreSQL class
* in src / onedb / onedb_backend . rb
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*/
static std : : string preprocess_query ( std : : ostringstream & cmd ) ;
} ;
# else
// Class stub
class PostgreSqlDB : public SqlDB
{
public :
PostgreSqlDB (
2024-06-03 11:40:24 +02:00
const std : : string & _server ,
int _port ,
const std : : string & _user ,
const std : : string & _password ,
const std : : string & _database ,
int _connections )
2020-04-13 17:32:21 +02:00
{
2020-07-02 22:42:10 +02:00
throw std : : runtime_error ( " Aborting oned, PostgreSQL support not compiled! " ) ;
2020-04-13 17:32:21 +02:00
}
2020-07-06 15:48:53 +02:00
2024-06-03 11:40:24 +02:00
~ PostgreSqlDB ( ) { }
2020-04-13 17:32:21 +02:00
2020-07-05 22:01:32 +02:00
char * escape_str ( const std : : string & str ) const override { return 0 ; } ;
2020-04-13 17:32:21 +02:00
2020-07-05 22:01:32 +02:00
void free_str ( char * str ) const override { } ;
2020-04-13 17:32:21 +02:00
protected :
2024-06-03 11:40:24 +02:00
int exec_ext ( std : : ostringstream & c , Callbackable * o , bool q ) override
{
2020-04-13 17:32:21 +02:00
return - 1 ;
} ;
} ;
# endif
# endif /*POSTGRESQL_DB_H*/