2020-03-04 16:05:57 +01:00
/* -------------------------------------------------------------------------- */
2021-02-09 16:07:56 +01:00
/* Copyright 2002-2021, OpenNebula Project, OpenNebula Systems */
2020-03-04 16:05:57 +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 NEBULA_SERVICE_H_
# define NEBULA_SERVICE_H_
# include "NebulaTemplate.h"
# include "NebulaLog.h"
# include <assert.h>
# include <memory>
/**
* This is the base class for the OpenNebula daemon . It provides access to
* configuration and basic services . Only one instance of NebulaService
* can exists .
*/
class NebulaService
{
public :
static NebulaService & instance ( )
{
assert ( nebula_service ) ;
return * nebula_service ;
} ;
// --------------------------------------------------------------
// Environment & Configuration
// --------------------------------------------------------------
/**
* Returns the value of LOG - > DEBUG_LEVEL in config file
* @ param default_ value returned if level not found in config
* @ return the debug level , to instantiate Log ' ers
*/
Log : : MessageType get_debug_level (
Log : : MessageType default_ = Log : : ERROR ) const ;
/**
* Returns the value of LOG - > SYSTEM in oned . conf file
* @ return the logging system CERR , FILE_TS or SYSLOG
*/
NebulaLog : : LogType get_log_system (
NebulaLog : : LogType default_ = NebulaLog : : UNDEFINED ) const ;
/**
* Returns the value of ONE_LOCATION env variable . When this variable is
* not defined the nebula location is " / " .
* @ return the nebula location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_nebula_location ( ) const
2020-03-04 16:05:57 +01:00
{
return nebula_location ;
} ;
/**
* Returns the path where mad executables are stored , if ONE_LOCATION is
* defined this path points to $ ONE_LOCATION / bin , otherwise it is
* / usr / lib / one / mads .
* @ return the mad execs location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_mad_location ( ) const
2020-03-04 16:05:57 +01:00
{
return mad_location ;
} ;
/**
* Returns the path where defaults for mads are stored , if ONE_LOCATION is
* defined this path points to $ ONE_LOCATION / etc , otherwise it is / etc / one
* @ return the mad defaults location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_defaults_location ( ) const
2020-03-04 16:05:57 +01:00
{
return etc_location ;
} ;
/**
* Returns the path where logs ( oned . log , schedd . log , . . . ) are generated
* if ONE_LOCATION is defined this path points to $ ONE_LOCATION / var ,
* otherwise it is / var / log / one .
* @ return the log location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_log_location ( ) const
2020-03-04 16:05:57 +01:00
{
return log_location ;
} ;
/**
* Returns the default var location . When ONE_LOCATION is defined this path
* points to $ ONE_LOCATION / var , otherwise it is / var / lib / one .
* @ return the log location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_var_location ( ) const
2020-03-04 16:05:57 +01:00
{
return var_location ;
} ;
/**
* Returns the default vms location . When ONE_LOCATION is defined this path
* points to $ ONE_LOCATION / var / vms , otherwise it is / var / lib / one / vms . This
* location stores vm related files : deployment , transfer , context , and
* logs ( in self - contained mode only )
* @ return the vms location .
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_vms_location ( ) const
2020-03-04 16:05:57 +01:00
{
return vms_location ;
} ;
/**
* Returns the version of oned
* @ return the version
*/
2020-07-02 22:42:10 +02:00
static std : : string version ( )
2020-03-04 16:05:57 +01:00
{
2020-07-02 22:42:10 +02:00
std : : ostringstream os ;
2020-03-04 16:05:57 +01:00
os < < " OpenNebula " < < code_version ( ) ;
os < < " ( " < < GITVERSION < < " ) " ;
return os . str ( ) ;
} ;
/**
* Returns the version of oned
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string code_version ( )
2020-03-04 16:05:57 +01:00
{
return " 5.9.90 " ; // bump version
}
/**
* Version needed for the DB , shared tables
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string shared_db_version ( )
2020-03-04 16:05:57 +01:00
{
2020-09-29 18:23:39 +02:00
return " 6.0.0 " ;
2020-03-04 16:05:57 +01:00
}
/**
* Version needed for the DB , local tables
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string local_db_version ( )
2020-03-04 16:05:57 +01:00
{
2020-09-29 18:23:39 +02:00
return " 6.0.0 " ;
2020-03-04 16:05:57 +01:00
}
// -----------------------------------------------------------------------
// Configuration attributes (read from oned.conf)
// -----------------------------------------------------------------------
/**
* Gets a configuration attribute for oned
* @ param name of the attribute
* @ param value of the attribute
*/
template < typename T >
2020-07-02 22:42:10 +02:00
void get_configuration_attribute ( const std : : string & name , T & value ) const
2020-03-04 16:05:57 +01:00
{
config - > get ( name , value ) ;
} ;
/**
* Gets an XML document with all of the configuration attributes
* @ return the XML
*/
2020-07-02 22:42:10 +02:00
std : : string get_configuration_xml ( ) const
2020-03-04 16:05:57 +01:00
{
2020-07-02 22:42:10 +02:00
std : : string xml ;
2020-03-04 16:05:57 +01:00
return config - > to_xml ( xml ) ;
} ;
protected :
// -----------------------------------------------------------------------
//Constructors and = are private to only access the class through instance
// -----------------------------------------------------------------------
NebulaService ( )
{
assert ( ! nebula_service & & " Trying to create second NebulaServcie " ) ;
nebula_service = this ;
const char * nl = getenv ( " ONE_LOCATION " ) ;
if ( nl = = 0 ) //OpenNebula installed under root directory
{
nebula_location = " / " ;
mad_location = " /usr/lib/one/mads/ " ;
etc_location = " /etc/one/ " ;
log_location = " /var/log/one/ " ;
var_location = " /var/lib/one/ " ;
remotes_location = " /var/lib/one/remotes/ " ;
vms_location = " /var/lib/one/vms/ " ;
}
else
{
nebula_location = nl ;
if ( nebula_location . at ( nebula_location . size ( ) - 1 ) ! = ' / ' )
{
nebula_location + = " / " ;
}
mad_location = nebula_location + " lib/mads/ " ;
etc_location = nebula_location + " etc/ " ;
log_location = nebula_location + " var/ " ;
var_location = nebula_location + " var/ " ;
remotes_location = nebula_location + " var/remotes/ " ;
vms_location = nebula_location + " var/vms/ " ;
}
} ;
virtual ~ NebulaService ( )
{
nebula_service = nullptr ;
} ;
std : : unique_ptr < NebulaTemplate > config ;
private :
static NebulaService * nebula_service ;
// ---------------------------------------------------------------
// Environment variables
// ---------------------------------------------------------------
2020-07-02 22:42:10 +02:00
std : : string nebula_location ;
2020-03-04 16:05:57 +01:00
2020-07-02 22:42:10 +02:00
std : : string mad_location ;
std : : string etc_location ;
std : : string log_location ;
std : : string var_location ;
std : : string remotes_location ;
std : : string vms_location ;
2020-03-04 16:05:57 +01:00
} ;
# endif /*NEBULA_SERVICE_H_*/