2012-11-30 02:59:26 +01:00
/* -------------------------------------------------------------------------- */
2021-02-09 16:07:56 +01:00
/* Copyright 2002-2021, OpenNebula Project, OpenNebula Systems */
2012-11-30 02:59:26 +01: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 SYSTEM_DB_H_
# define SYSTEM_DB_H_
# include "Callbackable.h"
class Nebula ;
2019-12-10 11:45:15 +01:00
class SqlDB ;
2012-11-30 02:59:26 +01:00
/**
* This class represents the OpenNebula core system data tables :
* - pool_control
* - db_versioning
* - system attributes
*/
class SystemDB : public Callbackable
{
public :
/**
* Reads a System attribute from the DB
* @ param attr_name name of the attribute
* @ param attr_xml the attribute in a XML document
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int select_sys_attribute ( const std : : string & attr_name , std : : string & attr_zml ) ;
2012-11-30 02:59:26 +01:00
/**
* Writes a system attribute in the database .
* @ param db pointer to the db
* @ return 0 on success
*/
int insert_sys_attribute (
2020-07-02 22:42:10 +02:00
const std : : string & attr_name ,
const std : : string & xml_attr ,
std : : string & error_str )
2012-11-30 02:59:26 +01:00
{
return insert_replace ( attr_name , xml_attr , false , error_str ) ;
} ;
/**
* Updates the system attribute in the database .
* @ param db pointer to the db
* @ return 0 on success
*/
int update_sys_attribute (
2020-07-02 22:42:10 +02:00
const std : : string & attr_name ,
const std : : string & xml_attr ,
std : : string & error_str )
2012-11-30 02:59:26 +01:00
{
return insert_replace ( attr_name , xml_attr , true , error_str ) ;
} ;
private :
friend class Nebula ; //Only for Nebula class
SystemDB ( SqlDB * _db ) : db ( _db ) { } ;
~ SystemDB ( ) { } ;
// Pool control table
static const char * pc_names ;
static const char * pc_bootstrap ;
static const char * pc_table ;
// DB versioning table
2014-02-23 19:31:08 +01:00
static const char * shared_ver_names ;
2012-11-30 02:59:26 +01:00
2014-02-23 19:31:08 +01:00
static const char * shared_ver_bootstrap ;
2012-11-30 02:59:26 +01:00
2014-02-23 19:31:08 +01:00
static const char * shared_ver_table ;
2012-11-30 02:59:26 +01:00
2014-02-05 19:30:35 +01:00
// DB slave versioning table
2014-02-23 19:31:08 +01:00
static const char * local_ver_names ;
2014-02-05 19:30:35 +01:00
2014-02-23 19:31:08 +01:00
static const char * local_ver_bootstrap ;
2014-02-05 19:30:35 +01:00
2014-02-23 19:31:08 +01:00
static const char * local_ver_table ;
2014-02-05 19:30:35 +01:00
2012-11-30 02:59:26 +01:00
// System attributes table
static const char * sys_names ;
static const char * sys_bootstrap ;
static const char * sys_table ;
// Pointer to the db database
SqlDB * db ;
/**
* Execute an INSERT or REPLACE Sql query for a system attribute .
* @ param db The SQL DB
* @ param replace Execute an INSERT or a REPLACE
* @ param error_str Returns the error reason , if any
* @ return 0 one success
*/
2020-07-02 22:42:10 +02:00
int insert_replace ( const std : : string & attr_name ,
const std : : string & xml_attr ,
bool replace ,
std : : string & error_str ) ;
2012-11-30 02:59:26 +01:00
/**
2014-02-23 19:31:08 +01:00
* Bootstraps the database control tables for shared tables
2012-11-30 02:59:26 +01:00
*
* @ return 0 on success
*/
2014-02-23 19:31:08 +01:00
int shared_bootstrap ( ) ;
2012-11-30 02:59:26 +01:00
2014-02-05 19:30:35 +01:00
/**
2014-02-23 19:31:08 +01:00
* Bootstraps the database control tables for a local DB tables
2014-02-05 19:30:35 +01:00
*
* @ return 0 on success
*/
2014-02-23 19:31:08 +01:00
int local_bootstrap ( ) ;
2014-02-05 19:30:35 +01:00
2012-11-30 02:59:26 +01:00
/**
* Callback function for the check_db_version method . Stores the read
* version in loaded_db_version
* @ param _loaded_db_version returned columns
* @ param num the number of columns read from the DB
* @ param names the column names
* @ param vaues the column values
* @ return 0 on success
*/
int select_cb ( void * _loaded_db_version ,
int num ,
char * * values ,
char * * names ) ;
/**
* Callback function for selecting system attributes
*/
int select_attr_cb ( void * _attr_xml ,
int num ,
char * * values ,
char * * names ) ;
/**
* Reads the current DB version .
2014-02-05 19:30:35 +01:00
* @ param is_federation_slave
2014-02-23 19:31:08 +01:00
* @ param local_bs boostrap local DB tables
* @ param shared_bs boostrap shared DB tables
2012-11-30 02:59:26 +01:00
*
* @ return 0 on success ,
2014-02-23 19:31:08 +01:00
* - 1 if there is a version mismatch , or replica config error .
*/
int check_db_version ( bool is_slave , bool & local_bs , bool & shared_bs ) ;
/**
* check_db_version to check versioning
* @ param table name of the DB table
* @ param version target DB version
* @ return 0 success , - 1 upgrade needed , - 2 bootstrap needed
2012-11-30 02:59:26 +01:00
*/
2020-07-02 22:42:10 +02:00
int check_db_version ( const std : : string & table ,
const std : : string & version ,
std : : string & error ) ;
2012-11-30 02:59:26 +01:00
} ;
# endif //SYSTEM_DB_H