2008-06-17 16:27:32 +00:00
/* -------------------------------------------------------------------------- */
2020-04-30 15:00:02 +02:00
/* Copyright 2002-2020, OpenNebula Project, OpenNebula Systems */
2008-06-17 16:27:32 +00: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_H_
# define NEBULA_H_
2020-03-04 16:05:57 +01:00
# include "OpenNebulaTemplate.h"
2019-12-10 11:45:15 +01:00
# include "SystemDB.h"
2008-06-17 16:27:32 +00:00
2012-11-26 12:48:10 +01:00
# include "DefaultQuotas.h"
2019-12-10 11:45:15 +01:00
# include "UserPool.h"
2020-07-24 16:00:59 +02:00
# include "NebulaLog.h"
2012-11-19 15:19:09 +01:00
2019-12-10 11:45:15 +01:00
class LogDB ;
class FedLogDB ;
class User ;
class ClusterPool ;
class DatastorePool ;
class DocumentPool ;
class GroupPool ;
class HookPool ;
class HostPool ;
class ImagePool ;
class MarketPlacePool ;
class MarketPlaceAppPool ;
class SecurityGroupPool ;
class VdcPool ;
class VMGroupPool ;
class VMTemplatePool ;
class VNTemplatePool ;
class VirtualMachinePool ;
class VirtualNetworkPool ;
class VirtualRouterPool ;
class ZonePool ;
class AclManager ;
class AuthManager ;
class DispatchManager ;
class FedReplicaManager ;
class HookLog ;
class HookManager ;
class ImageManager ;
class InformationManager ;
class IPAMManager ;
class LifeCycleManager ;
class MarketPlaceManager ;
class RaftManager ;
class RequestManager ;
class TransferManager ;
class VirtualMachineManager ;
2012-11-30 02:59:26 +01:00
/**
* This is the main class for the OpenNebula daemon oned . It stores references
* to the main modules and data pools . It also includes functions to bootstrap
* the system and start all its components .
*/
class Nebula
2008-06-17 16:27:32 +00:00
{
public :
2010-04-10 22:19:49 +02:00
static Nebula & instance ( )
2008-06-17 16:27:32 +00:00
{
static Nebula nebulad ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
return nebulad ;
} ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
// --------------------------------------------------------------
// Pool Accessors
2010-04-10 22:19:49 +02:00
// --------------------------------------------------------------
2020-07-05 22:01:32 +02:00
LogDB * get_logdb ( ) const
2017-04-21 16:52:54 +02:00
{
return logdb ;
} ;
2010-04-10 22:19:49 +02:00
2020-07-05 22:01:32 +02:00
VirtualMachinePool * get_vmpool ( ) const
2008-06-17 16:27:32 +00:00
{
return vmpool ;
2010-04-10 22:19:49 +02:00
} ;
2008-06-17 16:27:32 +00:00
2020-07-05 22:01:32 +02:00
HostPool * get_hpool ( ) const
2008-06-17 16:27:32 +00:00
{
return hpool ;
2010-04-10 22:19:49 +02:00
} ;
2020-07-05 22:01:32 +02:00
VirtualNetworkPool * get_vnpool ( ) const
2008-11-13 16:21:17 +00:00
{
return vnpool ;
} ;
2010-04-10 22:19:49 +02:00
2020-07-05 22:01:32 +02:00
UserPool * get_upool ( ) const
2009-07-09 14:34:34 +00:00
{
return upool ;
} ;
2008-06-17 16:27:32 +00:00
2020-07-05 22:01:32 +02:00
ImagePool * get_ipool ( ) const
2010-06-25 13:24:54 +02:00
{
return ipool ;
} ;
2020-07-05 22:01:32 +02:00
GroupPool * get_gpool ( ) const
2011-05-10 18:45:15 +02:00
{
return gpool ;
} ;
2020-07-05 22:01:32 +02:00
VMTemplatePool * get_tpool ( ) const
2011-03-30 19:03:49 +02:00
{
return tpool ;
} ;
2020-07-05 22:01:32 +02:00
DatastorePool * get_dspool ( ) const
2012-02-09 17:56:47 +01:00
{
return dspool ;
} ;
2020-07-05 22:01:32 +02:00
ClusterPool * get_clpool ( ) const
2012-02-24 15:53:53 +01:00
{
return clpool ;
} ;
2020-07-05 22:01:32 +02:00
DocumentPool * get_docpool ( ) const
2012-06-08 15:41:59 +02:00
{
return docpool ;
} ;
2020-07-05 22:01:32 +02:00
ZonePool * get_zonepool ( ) const
2013-12-12 19:08:59 +01:00
{
return zonepool ;
} ;
2020-07-05 22:01:32 +02:00
SecurityGroupPool * get_secgrouppool ( ) const
2014-09-08 11:50:25 +02:00
{
return secgrouppool ;
} ;
2020-07-05 22:01:32 +02:00
VdcPool * get_vdcpool ( ) const
2014-12-19 17:30:00 +01:00
{
return vdcpool ;
} ;
2020-07-05 22:01:32 +02:00
VirtualRouterPool * get_vrouterpool ( ) const
2015-11-30 16:50:23 +01:00
{
return vrouterpool ;
} ;
2020-07-05 22:01:32 +02:00
MarketPlacePool * get_marketpool ( ) const
2015-12-05 23:52:28 +01:00
{
2015-12-11 15:53:19 +01:00
return marketpool ;
2015-12-05 23:52:28 +01:00
} ;
2015-12-11 15:53:19 +01:00
2020-07-05 22:01:32 +02:00
MarketPlaceAppPool * get_apppool ( ) const
2015-12-11 15:53:19 +01:00
{
return apppool ;
} ;
2020-07-05 22:01:32 +02:00
VMGroupPool * get_vmgrouppool ( ) const
2017-01-03 01:22:10 +01:00
{
return vmgrouppool ;
} ;
2020-07-05 22:01:32 +02:00
VNTemplatePool * get_vntpool ( ) const
2019-09-09 14:43:51 +02:00
{
2018-11-20 17:24:59 +01:00
return vntpool ;
}
2020-07-05 22:01:32 +02:00
HookPool * get_hkpool ( ) const
2019-09-09 14:43:51 +02:00
{
return hkpool ;
}
2008-06-17 16:27:32 +00:00
// --------------------------------------------------------------
// Manager Accessors
2010-04-10 22:19:49 +02:00
// --------------------------------------------------------------
2020-07-05 22:01:32 +02:00
VirtualMachineManager * get_vmm ( ) const
2008-06-17 16:27:32 +00:00
{
return vmm ;
} ;
2020-07-05 22:01:32 +02:00
LifeCycleManager * get_lcm ( ) const
2008-06-17 16:27:32 +00:00
{
return lcm ;
} ;
2010-04-10 22:19:49 +02:00
2020-07-05 22:01:32 +02:00
InformationManager * get_im ( ) const
2008-06-17 16:27:32 +00:00
{
return im ;
} ;
2020-07-05 22:01:32 +02:00
TransferManager * get_tm ( ) const
2008-06-17 16:27:32 +00:00
{
return tm ;
} ;
2020-07-05 22:01:32 +02:00
DispatchManager * get_dm ( ) const
2008-06-17 16:27:32 +00:00
{
return dm ;
} ;
2010-04-10 22:19:49 +02:00
2020-07-05 22:01:32 +02:00
HookManager * get_hm ( ) const
2009-04-03 23:34:33 +00:00
{
return hm ;
} ;
2010-04-10 22:19:49 +02:00
2020-07-05 22:01:32 +02:00
HookLog * get_hl ( ) const
2019-09-09 14:43:51 +02:00
{
return hl ;
} ;
2020-07-05 22:01:32 +02:00
AuthManager * get_authm ( ) const
2010-07-08 19:28:10 +02:00
{
return authm ;
} ;
2020-07-05 22:01:32 +02:00
ImageManager * get_imagem ( ) const
2011-03-22 18:21:09 +01:00
{
return imagem ;
} ;
2020-07-05 22:01:32 +02:00
AclManager * get_aclm ( ) const
2011-06-22 19:22:52 +02:00
{
return aclm ;
} ;
2020-07-05 22:01:32 +02:00
MarketPlaceManager * get_marketm ( ) const
2015-12-14 16:47:33 +01:00
{
return marketm ;
} ;
2020-07-05 22:01:32 +02:00
IPAMManager * get_ipamm ( ) const
2016-08-18 21:42:24 +02:00
{
return ipamm ;
} ;
2020-07-05 22:01:32 +02:00
RaftManager * get_raftm ( ) const
2017-04-25 17:15:31 +02:00
{
return raftm ;
} ;
2017-05-18 21:13:54 +02:00
2020-07-05 22:01:32 +02:00
FedReplicaManager * get_frm ( ) const
2017-05-18 21:13:54 +02:00
{
return frm ;
} ;
2020-07-05 22:01:32 +02:00
RequestManager * get_rm ( ) const
2019-09-09 14:43:51 +02:00
{
return rm ;
} ;
2008-06-17 16:27:32 +00:00
// --------------------------------------------------------------
// Environment & Configuration
2009-01-02 14:58:51 +00:00
// --------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2012-04-03 18:02:14 +02:00
/**
2013-01-31 20:43:17 +01:00
* Returns the value of LOG - > DEBUG_LEVEL in oned . conf file
2012-04-03 18:02:14 +02:00
* @ return the debug level , to instantiate Log ' ers
*/
2016-01-04 11:29:20 +01:00
Log : : MessageType get_debug_level ( ) const ;
2012-04-03 18:02:14 +02:00
2013-01-31 20:43:17 +01:00
/**
* Returns the value of LOG - > SYSTEM in oned . conf file
2013-02-01 18:49:03 +01:00
* @ return the logging system CERR , FILE_TS or SYSLOG
2013-01-31 20:43:17 +01:00
*/
2016-01-04 11:29:20 +01:00
NebulaLog : : LogType get_log_system ( ) const ;
2013-01-31 20:43:17 +01:00
2009-01-02 14:58:51 +00:00
/**
2010-04-10 22:19:49 +02:00
* Returns the value of ONE_LOCATION env variable . When this variable is
2009-01-02 14:58:51 +00:00
* not defined the nebula location is " / " .
2015-07-01 15:15:40 -04:00
* @ return the nebula location .
2010-04-10 22:19:49 +02:00
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_nebula_location ( ) const
2008-06-17 16:27:32 +00:00
{
return nebula_location ;
} ;
2009-01-02 14:58:51 +00:00
/**
2010-04-10 22:19:49 +02:00
* Returns the path where mad executables are stored , if ONE_LOCATION is
* defined this path points to $ ONE_LOCATION / bin , otherwise it is
2009-01-02 14:58:51 +00:00
* / usr / lib / one / mads .
2015-07-01 15:15:40 -04:00
* @ return the mad execs location .
2009-01-02 14:58:51 +00:00
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_mad_location ( ) const
2009-01-02 14:58:51 +00:00
{
2015-07-01 15:15:40 -04:00
return mad_location ;
2009-01-02 14:58:51 +00:00
} ;
/**
2010-04-10 22:19:49 +02:00
* Returns the path where defaults for mads are stored , if ONE_LOCATION is
2009-01-02 14:58:51 +00:00
* defined this path points to $ ONE_LOCATION / etc , otherwise it is / etc / one
2015-07-01 15:15:40 -04:00
* @ return the mad defaults location .
2009-01-02 14:58:51 +00:00
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_defaults_location ( ) const
2009-01-02 14:58:51 +00:00
{
2015-07-01 15:15:40 -04:00
return etc_location ;
2009-01-02 14:58:51 +00:00
} ;
2010-04-10 22:19:49 +02:00
2009-01-02 14:58:51 +00:00
/**
* Returns the path where logs ( oned . log , schedd . log , . . . ) are generated
2010-04-10 22:19:49 +02:00
* if ONE_LOCATION is defined this path points to $ ONE_LOCATION / var ,
2009-01-02 14:58:51 +00:00
* otherwise it is / var / log / one .
2015-07-01 15:15:40 -04:00
* @ return the log location .
2009-01-02 14:58:51 +00:00
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_log_location ( ) const
2009-01-02 14:58:51 +00:00
{
2015-07-01 15:15:40 -04:00
return log_location ;
2009-01-02 14:58:51 +00:00
} ;
/**
2012-02-24 23:13:22 +01:00
* Returns the default var location . When ONE_LOCATION is defined this path
* points to $ ONE_LOCATION / var , otherwise it is / var / lib / one .
2015-07-01 15:15:40 -04:00
* @ return the log location .
2009-01-02 14:58:51 +00:00
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_var_location ( ) const
2009-01-02 14:58:51 +00:00
{
2015-07-01 15:15:40 -04:00
return var_location ;
2009-01-02 14:58:51 +00:00
} ;
2010-04-10 22:19:49 +02:00
2020-05-18 02:23:29 +02:00
/**
* Returns the default share location . When ONE_LOCATION is defined this path
* points to $ ONE_LOCATION / share , otherwise it is / usr / share / one .
* @ return the log location .
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_share_location ( ) const
2020-05-18 02:23:29 +02:00
{
return share_location ;
} ;
2013-10-20 15:11:13 +02:00
/**
*
*
*/
2020-07-05 22:01:32 +02:00
void get_ds_location ( std : : string & dsloc ) const ;
2013-10-20 15:11:13 +02:00
2012-10-28 19:19:57 +01:00
/**
* 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-05 22:01:32 +02:00
const std : : string & get_vms_location ( ) const
2012-10-28 19:19:57 +01:00
{
return vms_location ;
} ;
2009-01-02 14:58:51 +00:00
/**
* Returns the path of the log file for a VM , depending where OpenNebula is
* installed ,
* $ ONE_LOCATION / var / $ VM_ID / vm . log
* or
* / var / log / one / $ VM_ID . log
* @ return the log location for the VM .
*/
2020-07-05 22:01:32 +02:00
std : : string get_vm_log_filename ( int oid ) const ;
2010-04-10 22:19:49 +02:00
2012-12-24 02:41:17 +01:00
/**
* Returns the name of the host running oned
* @ return the name
*/
2020-07-05 22:01:32 +02:00
const std : : string & get_nebula_hostname ( ) const
2008-11-13 16:21:17 +00:00
{
return hostname ;
} ;
2010-04-10 22:19:49 +02:00
2012-12-24 02:41:17 +01:00
/**
* Returns the version of oned
* @ return the version
*/
2020-07-02 22:42:10 +02:00
static std : : string version ( )
2008-06-17 16:27:32 +00:00
{
2020-07-02 22:42:10 +02:00
std : : ostringstream os ;
2019-03-12 20:04:12 +01:00
os < < " OpenNebula " < < code_version ( ) ;
os < < " ( " < < GITVERSION < < " ) " ;
return os . str ( ) ;
2008-06-17 16:27:32 +00:00
} ;
2010-04-10 22:19:49 +02:00
2014-02-21 18:08:41 +01:00
/**
* Returns the version of oned
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string code_version ( )
2014-02-21 18:08:41 +01:00
{
2020-06-15 19:46:29 +02:00
return " 5.13.80 " ; // bump version
2014-02-21 18:08:41 +01:00
}
/**
2014-02-23 19:31:08 +01:00
* Version needed for the DB , shared tables
2014-02-21 18:08:41 +01:00
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string shared_db_version ( )
2011-04-29 18:59:39 +02:00
{
2020-03-04 15:09:54 +01:00
return " 5.12.0 " ;
2011-07-12 13:54:53 +02:00
}
2011-04-29 18:59:39 +02:00
2014-02-21 18:08:41 +01:00
/**
* Version needed for the DB , local tables
* @ return
*/
2020-07-02 22:42:10 +02:00
static std : : string local_db_version ( )
2014-02-21 18:08:41 +01:00
{
2020-03-04 15:09:54 +01:00
return " 5.12.0 " ;
2014-02-21 18:08:41 +01:00
}
2012-12-24 02:41:17 +01:00
/**
* Starts all the modules and services for OpenNebula
*/
2013-10-08 15:09:30 +02:00
void start ( bool bootstrap_only = false ) ;
2010-04-10 22:19:49 +02:00
2013-10-05 15:34:55 -04:00
/**
* Initialize the database
*/
2016-01-04 11:29:20 +01:00
void bootstrap_db ( )
{
start ( true ) ;
}
2013-10-05 15:34:55 -04:00
2014-01-22 12:55:30 +01:00
// --------------------------------------------------------------
// Federation
// --------------------------------------------------------------
bool is_federation_enabled ( )
{
return federation_enabled ;
} ;
bool is_federation_master ( )
{
return federation_master ;
} ;
2014-01-22 18:54:48 +01:00
bool is_federation_slave ( )
{
return federation_enabled & & ! federation_master ;
} ;
2019-02-19 12:40:07 +01:00
bool is_cache ( )
{
return cache ;
} ;
2020-07-05 22:01:32 +02:00
int get_zone_id ( ) const
2014-01-22 12:55:30 +01:00
{
return zone_id ;
} ;
2020-07-05 22:01:32 +02:00
int get_server_id ( ) const
2017-04-21 16:52:54 +02:00
{
return server_id ;
} ;
2020-07-05 22:01:32 +02:00
const std : : string & get_master_oned ( ) const
2014-01-22 12:55:30 +01:00
{
return master_oned ;
} ;
2012-12-24 02:41:17 +01:00
// -----------------------------------------------------------------------
// Configuration attributes (read from oned.conf)
// -----------------------------------------------------------------------
/**
* Gets a configuration attribute for oned
* @ param name of the attribute
* @ param value of the attribute
*/
2016-02-04 13:10:42 +01:00
template < typename T >
2020-07-02 22:42:10 +02:00
void get_configuration_attribute ( const std : : string & name , T & value ) const
2014-08-11 17:22:15 +02:00
{
nebula_configuration - > get ( name , value ) ;
} ;
2017-03-12 23:39:45 +01:00
/**
* Gets a user - configurable attribute for oned . Users ( and groups ) may
* store oned attributes in the " OPENNEBULA " vector . This function gets
* the value querying first the user , then the group and finally oned . conf
2017-03-21 12:23:02 +01:00
* @ param uid of the user , if - 1 the user template is not considered
2017-03-12 23:39:45 +01:00
* @ param gid of the group
* @ param name of the attribute
* @ param value of the attribute
*
* @ return 0 on success - 1 otherwise
*/
template < typename T >
int get_configuration_attribute ( int uid , int gid , const std : : string & name ,
T & value ) const
{
2017-03-21 12:23:02 +01:00
if ( uid ! = - 1 )
2017-03-12 23:39:45 +01:00
{
2018-10-09 11:05:08 +02:00
User * user = upool - > get_ro ( uid ) ;
2017-03-21 12:23:02 +01:00
if ( user = = 0 )
{
return - 1 ;
}
2017-03-12 23:39:45 +01:00
2017-03-21 12:23:02 +01:00
const VectorAttribute * uconf ;
2017-03-12 23:39:45 +01:00
2017-03-21 12:23:02 +01:00
uconf = user - > get_template_attribute ( " OPENNEBULA " ) ;
2017-03-12 23:39:45 +01:00
2017-03-21 12:23:02 +01:00
if ( uconf ! = 0 )
2017-03-12 23:39:45 +01:00
{
2017-03-21 12:23:02 +01:00
if ( uconf - > vector_value ( name , value ) = = 0 )
{
user - > unlock ( ) ;
return 0 ;
}
2017-03-12 23:39:45 +01:00
}
2017-03-21 12:23:02 +01:00
user - > unlock ( ) ;
}
2017-03-12 23:39:45 +01:00
2018-10-09 11:05:08 +02:00
Group * group = gpool - > get_ro ( gid ) ;
2017-03-12 23:39:45 +01:00
if ( group = = 0 )
{
return - 1 ;
}
const VectorAttribute * gconf ;
gconf = group - > get_template_attribute ( " OPENNEBULA " ) ;
if ( gconf ! = 0 )
{
if ( gconf - > vector_value ( name , value ) = = 0 )
{
group - > unlock ( ) ;
return 0 ;
}
}
group - > unlock ( ) ;
nebula_configuration - > get ( name , value ) ;
return 0 ;
}
2015-12-21 19:27:26 +01:00
/**
* Gets a DS configuration attribute
*/
2016-08-31 14:52:33 +02:00
int get_ds_conf_attribute ( const std : : string & ds_name ,
2016-02-09 16:33:13 +01:00
const VectorAttribute * & value ) const
{
return get_conf_attribute ( " DS_MAD_CONF " , ds_name , value ) ;
} ;
2015-12-21 19:27:26 +01:00
2018-09-20 13:07:05 +02:00
/**
* Gets a VN configuration attribute
*/
int get_vn_conf_attribute ( const std : : string & vn_name ,
const VectorAttribute * & value ) const
{
return get_conf_attribute ( " VN_MAD_CONF " , vn_name , value ) ;
}
2013-10-23 16:15:18 +02:00
/**
* Gets a TM configuration attribute
*/
2020-07-02 22:42:10 +02:00
int get_tm_conf_attribute ( const std : : string & tm_name ,
2016-02-09 16:33:13 +01:00
const VectorAttribute * & value ) const
{
return get_conf_attribute ( " TM_MAD_CONF " , tm_name , value ) ;
} ;
2013-10-23 16:15:18 +02:00
2016-02-03 16:03:22 +01:00
/**
* Gets a Market configuration attribute
*/
2020-07-02 22:42:10 +02:00
int get_market_conf_attribute ( const std : : string & mk_name ,
2016-02-09 16:33:13 +01:00
const VectorAttribute * & value ) const
{
return get_conf_attribute ( " MARKET_MAD_CONF " , mk_name , value ) ;
} ;
2016-02-03 16:03:22 +01:00
2016-06-29 17:17:18 +02:00
/**
* Gets an Auth driver configuration attribute
*/
2016-08-31 14:52:33 +02:00
template < typename T >
2020-07-02 22:42:10 +02:00
int get_auth_conf_attribute ( const std : : string & driver ,
const std : : string & attribute ,
2016-08-31 14:52:33 +02:00
T & value ) const
2016-06-29 17:17:18 +02:00
{
2016-08-31 14:52:33 +02:00
return get_conf_attribute ( " AUTH_MAD_CONF " , driver , attribute , value ) ;
2016-06-29 17:17:18 +02:00
} ;
2017-01-30 13:19:32 +01:00
/**
* Return the Authorization operation for a VM action
*
*/
2020-07-05 22:01:32 +02:00
AuthRequest : : Operation get_vm_auth_op ( VMActions : : Action action ) const
2017-01-30 13:19:32 +01:00
{
return nebula_configuration - > get_vm_auth_op ( action ) ;
}
2012-12-24 02:41:17 +01:00
/**
* 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
2012-11-14 12:54:31 +01:00
{
2020-07-02 22:42:10 +02:00
std : : string xml ;
2012-11-14 12:54:31 +01:00
return nebula_configuration - > to_xml ( xml ) ;
} ;
2019-01-30 00:10:18 +01:00
/**
* Gets the database backend type
* @ return database backend type
*/
2020-07-02 22:42:10 +02:00
const std : : string & get_db_backend ( ) const
2019-01-30 00:10:18 +01:00
{
return db_backend_type ;
}
2012-12-24 02:41:17 +01:00
// -----------------------------------------------------------------------
// Default Quotas
// -----------------------------------------------------------------------
/**
* Get the default quotas for OpenNebula users
* @ return the default quotas
*/
2020-07-05 22:01:32 +02:00
const DefaultQuotas & get_default_user_quota ( ) const
2012-11-19 15:19:09 +01:00
{
return default_user_quota ;
} ;
2012-12-24 02:41:17 +01:00
/**
* Set the default quotas for OpenNebula users
* @ param tmpl template with the default quotas
* @ param error describes the error if any
*
* @ return 0 if success
*/
2020-07-02 22:42:10 +02:00
int set_default_user_quota ( Template * tmpl , std : : string & error )
2012-11-23 16:03:10 +01:00
{
2012-12-24 02:41:17 +01:00
int rc = default_user_quota . set ( tmpl , error ) ;
2012-11-26 18:14:12 +01:00
if ( rc = = 0 )
{
2012-11-30 02:59:26 +01:00
rc = default_user_quota . update ( ) ;
2012-11-26 18:14:12 +01:00
}
return rc ;
2012-11-23 16:03:10 +01:00
} ;
2012-12-24 02:41:17 +01:00
/**
* Get the default quotas for OpenNebula for groups
* @ return the default quotas
*/
2020-07-05 22:01:32 +02:00
const DefaultQuotas & get_default_group_quota ( ) const
2012-11-19 16:38:39 +01:00
{
return default_group_quota ;
} ;
2012-12-24 02:41:17 +01:00
/**
* Set the default quotas for OpenNebula groups
* @ param tmpl template with the default quotas
* @ param error describes the error if any
*
* @ return 0 if success
*/
2020-07-02 22:42:10 +02:00
int set_default_group_quota ( Template * tmpl , std : : string & error )
2012-11-23 16:03:10 +01:00
{
2012-12-24 02:41:17 +01:00
int rc = default_group_quota . set ( tmpl , error ) ;
2012-11-26 18:14:12 +01:00
if ( rc = = 0 )
{
2012-11-30 02:59:26 +01:00
rc = default_group_quota . update ( ) ;
2012-11-26 18:14:12 +01:00
}
return rc ;
2012-11-23 16:03:10 +01:00
} ;
2012-11-30 02:59:26 +01:00
// -----------------------------------------------------------------------
// System attributes
// -----------------------------------------------------------------------
/**
* Reads a System attribute from the DB
* @ param attr_name name of the attribute
* @ param cb Callback that will receive the attribute in XML
* @ return 0 on success
*/
2020-07-02 22:42:10 +02:00
int select_sys_attribute ( const std : : string & attr_name , std : : string & attr_xml )
2012-11-30 02:59:26 +01:00
{
return system_db - > select_sys_attribute ( attr_name , attr_xml ) ;
} ;
/**
* 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 system_db - > insert_sys_attribute ( attr_name , xml_attr , 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 system_db - > update_sys_attribute ( attr_name , xml_attr , error_str ) ;
} ;
2008-06-17 16:27:32 +00:00
private :
2010-04-10 22:19:49 +02:00
// -----------------------------------------------------------------------
2008-06-17 16:27:32 +00:00
//Constructors and = are private to only access the class through instance
// -----------------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2012-11-19 15:19:09 +01:00
Nebula ( ) : nebula_configuration ( 0 ) ,
2012-11-26 16:12:05 +01:00
default_user_quota ( " DEFAULT_USER_QUOTAS " ,
" /DEFAULT_USER_QUOTAS/DATASTORE_QUOTA " ,
" /DEFAULT_USER_QUOTAS/NETWORK_QUOTA " ,
" /DEFAULT_USER_QUOTAS/IMAGE_QUOTA " ,
" /DEFAULT_USER_QUOTAS/VM_QUOTA " ) ,
default_group_quota ( " DEFAULT_GROUP_QUOTAS " ,
" /DEFAULT_GROUP_QUOTAS/DATASTORE_QUOTA " ,
" /DEFAULT_GROUP_QUOTAS/NETWORK_QUOTA " ,
" /DEFAULT_GROUP_QUOTAS/IMAGE_QUOTA " ,
" /DEFAULT_GROUP_QUOTAS/VM_QUOTA " ) ,
2019-01-30 00:10:18 +01:00
system_db ( 0 ) , db_backend_type ( " sqlite " ) , logdb ( 0 ) , fed_logdb ( 0 ) ,
2013-12-12 19:08:59 +01:00
vmpool ( 0 ) , hpool ( 0 ) , vnpool ( 0 ) , upool ( 0 ) , ipool ( 0 ) , gpool ( 0 ) , tpool ( 0 ) ,
2017-01-03 01:22:10 +01:00
dspool ( 0 ) , clpool ( 0 ) , docpool ( 0 ) , zonepool ( 0 ) , secgrouppool ( 0 ) ,
vdcpool ( 0 ) , vrouterpool ( 0 ) , marketpool ( 0 ) , apppool ( 0 ) , vmgrouppool ( 0 ) ,
2019-09-09 14:43:51 +02:00
vntpool ( 0 ) , hkpool ( 0 ) , lcm ( 0 ) , vmm ( 0 ) , im ( 0 ) , tm ( 0 ) , dm ( 0 ) , rm ( 0 ) , hm ( 0 ) ,
hl ( 0 ) , authm ( 0 ) , aclm ( 0 ) , imagem ( 0 ) , marketm ( 0 ) , ipamm ( 0 ) , raftm ( 0 ) , frm ( 0 )
2009-01-02 14:58:51 +00:00
{
2010-06-25 13:24:54 +02:00
const char * nl = getenv ( " ONE_LOCATION " ) ;
2009-01-02 14:58:51 +00:00
if ( nl = = 0 ) //OpenNebula installed under root directory
{
2010-06-25 13:24:54 +02:00
nebula_location = " / " ;
2010-04-10 22:19:49 +02:00
2010-08-17 00:28:48 +02:00
mad_location = " /usr/lib/one/mads/ " ;
etc_location = " /etc/one/ " ;
log_location = " /var/log/one/ " ;
var_location = " /var/lib/one/ " ;
2010-11-16 12:29:14 +01:00
remotes_location = " /var/lib/one/remotes/ " ;
2012-10-28 19:19:57 +01:00
vms_location = " /var/lib/one/vms/ " ;
2020-05-18 02:23:29 +02:00
share_location = " /usr/share/one " ;
2009-01-02 14:58:51 +00:00
}
else
{
2010-06-25 13:24:54 +02:00
nebula_location = nl ;
2010-04-10 22:19:49 +02:00
2010-06-25 13:24:54 +02:00
if ( nebula_location . at ( nebula_location . size ( ) - 1 ) ! = ' / ' )
{
nebula_location + = " / " ;
}
2010-04-10 22:19:49 +02:00
2010-08-17 00:28:48 +02:00
mad_location = nebula_location + " lib/mads/ " ;
etc_location = nebula_location + " etc/ " ;
log_location = nebula_location + " var/ " ;
var_location = nebula_location + " var/ " ;
2010-11-16 12:29:14 +01:00
remotes_location = nebula_location + " var/remotes/ " ;
2012-10-28 19:19:57 +01:00
vms_location = nebula_location + " var/vms/ " ;
2020-05-18 02:23:29 +02:00
share_location = nebula_location + " share/ " ;
2010-04-10 22:19:49 +02:00
}
2009-01-02 14:58:51 +00:00
} ;
2010-04-10 22:19:49 +02:00
2019-12-10 11:45:15 +01:00
~ Nebula ( ) ;
2010-04-10 22:19:49 +02:00
Nebula & operator = ( Nebula const & ) { return * this ; } ;
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Environment variables
// ---------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2020-07-02 22:42:10 +02:00
std : : string nebula_location ;
2010-04-10 22:19:49 +02: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 ;
std : : string share_location ;
2010-08-17 00:28:48 +02:00
2020-07-02 22:42:10 +02:00
std : : string hostname ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Configuration
// ---------------------------------------------------------------
2012-11-30 02:59:26 +01:00
OpenNebulaTemplate * nebula_configuration ;
2010-04-10 22:19:49 +02:00
2014-01-22 12:55:30 +01:00
// ---------------------------------------------------------------
2017-04-29 23:25:53 +02:00
// Federation - HA
2014-01-22 12:55:30 +01:00
// ---------------------------------------------------------------
2020-07-02 22:42:10 +02:00
bool federation_enabled ;
bool federation_master ;
bool cache ;
int zone_id ;
int server_id ;
std : : string master_oned ;
2014-01-22 12:55:30 +01:00
2012-11-19 15:19:09 +01:00
// ---------------------------------------------------------------
// Default quotas
// ---------------------------------------------------------------
2012-11-26 12:48:10 +01:00
DefaultQuotas default_user_quota ;
DefaultQuotas default_group_quota ;
2012-11-19 15:19:09 +01:00
2012-11-30 02:59:26 +01:00
// ---------------------------------------------------------------
// The system database
// ---------------------------------------------------------------
2020-07-02 22:42:10 +02:00
SystemDB * system_db ;
std : : string db_backend_type ;
2012-11-19 15:19:09 +01:00
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Nebula Pools
// ---------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2017-04-21 16:52:54 +02:00
LogDB * logdb ;
2017-05-22 18:04:16 +02:00
FedLogDB * fed_logdb ;
2008-06-17 16:27:32 +00:00
VirtualMachinePool * vmpool ;
2008-11-13 16:21:17 +00:00
HostPool * hpool ;
VirtualNetworkPool * vnpool ;
2009-07-09 14:34:34 +00:00
UserPool * upool ;
2010-06-01 18:00:44 +02:00
ImagePool * ipool ;
2011-05-10 18:45:15 +02:00
GroupPool * gpool ;
2011-03-30 19:03:49 +02:00
VMTemplatePool * tpool ;
2012-02-09 17:56:47 +01:00
DatastorePool * dspool ;
2012-02-24 15:53:53 +01:00
ClusterPool * clpool ;
2012-06-08 15:41:59 +02:00
DocumentPool * docpool ;
2013-12-12 19:08:59 +01:00
ZonePool * zonepool ;
2014-09-08 11:50:25 +02:00
SecurityGroupPool * secgrouppool ;
2014-12-19 17:30:00 +01:00
VdcPool * vdcpool ;
2015-11-30 16:50:23 +01:00
VirtualRouterPool * vrouterpool ;
2015-12-11 15:53:19 +01:00
MarketPlacePool * marketpool ;
MarketPlaceAppPool * apppool ;
2017-01-03 01:22:10 +01:00
VMGroupPool * vmgrouppool ;
2018-11-20 17:24:59 +01:00
VNTemplatePool * vntpool ;
2019-09-09 14:43:51 +02:00
HookPool * hkpool ;
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Nebula Managers
// ---------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
LifeCycleManager * lcm ;
VirtualMachineManager * vmm ;
InformationManager * im ;
TransferManager * tm ;
DispatchManager * dm ;
RequestManager * rm ;
2009-04-03 23:34:33 +00:00
HookManager * hm ;
2019-09-09 14:43:51 +02:00
HookLog * hl ;
2010-07-08 19:28:10 +02:00
AuthManager * authm ;
2011-06-22 19:22:52 +02:00
AclManager * aclm ;
2011-03-22 18:21:09 +01:00
ImageManager * imagem ;
2015-12-14 16:47:33 +01:00
MarketPlaceManager * marketm ;
2016-08-18 21:42:24 +02:00
IPAMManager * ipamm ;
2017-04-25 17:15:31 +02:00
RaftManager * raftm ;
2017-05-18 21:13:54 +02:00
FedReplicaManager * frm ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Implementation functions
// ---------------------------------------------------------------
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
friend void nebula_signal_handler ( int sig ) ;
2016-02-03 16:03:22 +01:00
// ---------------------------------------------------------------
// Helper functions
// ---------------------------------------------------------------
/**
* Gets a Generic configuration attribute
* @ param key String that identifies the configuration parameter group name
* @ param name Name of the specific configuration parameter
* @ param value Value of the specific configuration parameter
* @ return a reference to the generated string
*/
int get_conf_attribute (
const std : : string & key ,
const std : : string & name ,
const VectorAttribute * & value ) const ;
2016-08-31 14:52:33 +02:00
/**
* Gets a Generic configuration attribute
* @ param key String that identifies the configuration parameter group name
* @ param name Name of the specific configuration parameter
* @ param value Value of the specific configuration parameter
* @ return a reference to the generated string
*/
template < typename T >
int get_conf_attribute (
const std : : string & key ,
const std : : string & name ,
const std : : string & vname ,
T & value ) const
{
const VectorAttribute * vattr ;
if ( get_conf_attribute ( key , name , vattr ) ! = 0 )
{
return - 1 ;
}
return vattr - > vector_value ( vname , value ) ;
}
2008-06-17 16:27:32 +00:00
} ;
# endif /*NEBULA_H_*/