2008-06-17 16:27:32 +00:00
/* -------------------------------------------------------------------------- */
2012-01-12 12:29:18 +01:00
/* Copyright 2002-2012, OpenNebula Project Leads (OpenNebula.org) */
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_
2010-04-10 22:19:49 +02:00
# include "SqlDB.h"
2008-06-17 16:27:32 +00:00
# include "NebulaTemplate.h"
# include "VirtualMachinePool.h"
2008-11-13 16:21:17 +00:00
# include "VirtualNetworkPool.h"
2008-06-17 16:27:32 +00:00
# include "HostPool.h"
2009-07-09 14:34:34 +00:00
# include "UserPool.h"
2011-03-30 19:03:49 +02:00
# include "VMTemplatePool.h"
2011-05-10 18:45:15 +02:00
# include "GroupPool.h"
2012-02-09 17:56:47 +01:00
# include "DatastorePool.h"
2012-02-24 15:53:53 +01:00
# include "ClusterPool.h"
2008-06-17 16:27:32 +00:00
# include "VirtualMachineManager.h"
# include "LifeCycleManager.h"
# include "InformationManager.h"
# include "TransferManager.h"
# include "DispatchManager.h"
# include "RequestManager.h"
2009-04-03 23:34:33 +00:00
# include "HookManager.h"
2010-07-08 19:28:10 +02:00
# include "AuthManager.h"
2011-06-22 19:22:52 +02:00
# include "AclManager.h"
2011-03-22 18:21:09 +01:00
# include "ImageManager.h"
2008-06-17 16:27:32 +00:00
2011-04-29 18:59:39 +02:00
# include "Callbackable.h"
class Nebula : public Callbackable
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
// --------------------------------------------------------------
2008-06-17 16:27:32 +00:00
VirtualMachinePool * get_vmpool ( )
{
return vmpool ;
2010-04-10 22:19:49 +02:00
} ;
2008-06-17 16:27:32 +00:00
HostPool * get_hpool ( )
{
return hpool ;
2010-04-10 22:19:49 +02:00
} ;
2008-11-13 16:21:17 +00:00
VirtualNetworkPool * get_vnpool ( )
{
return vnpool ;
} ;
2010-04-10 22:19:49 +02:00
2009-07-09 14:34:34 +00:00
UserPool * get_upool ( )
{
return upool ;
} ;
2008-06-17 16:27:32 +00:00
2010-06-25 13:24:54 +02:00
ImagePool * get_ipool ( )
{
return ipool ;
} ;
2011-05-10 18:45:15 +02:00
GroupPool * get_gpool ( )
{
return gpool ;
} ;
2011-03-30 19:03:49 +02:00
VMTemplatePool * get_tpool ( )
{
return tpool ;
} ;
2012-02-09 17:56:47 +01:00
DatastorePool * get_dspool ( )
{
return dspool ;
} ;
2012-02-24 15:53:53 +01:00
ClusterPool * get_clpool ( )
{
return clpool ;
} ;
2008-06-17 16:27:32 +00:00
// --------------------------------------------------------------
// Manager Accessors
2010-04-10 22:19:49 +02:00
// --------------------------------------------------------------
2008-06-17 16:27:32 +00:00
VirtualMachineManager * get_vmm ( )
{
return vmm ;
} ;
LifeCycleManager * get_lcm ( )
{
return lcm ;
} ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
InformationManager * get_im ( )
{
return im ;
} ;
TransferManager * get_tm ( )
{
return tm ;
} ;
DispatchManager * get_dm ( )
{
return dm ;
} ;
2010-04-10 22:19:49 +02:00
2009-04-03 23:34:33 +00:00
HookManager * get_hm ( )
{
return hm ;
} ;
2010-04-10 22:19:49 +02:00
2010-07-08 19:28:10 +02:00
AuthManager * get_authm ( )
{
return authm ;
} ;
2011-03-22 18:21:09 +01:00
ImageManager * get_imagem ( )
{
return imagem ;
} ;
2011-06-22 19:22:52 +02:00
AclManager * get_aclm ( )
{
return aclm ;
} ;
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
/**
* Returns the value of DEBUG_LEVEL in oned . conf file
* @ return the debug level , to instantiate Log ' ers
*/
Log : : MessageType get_debug_level ( ) const
{
Log : : MessageType clevel = Log : : ERROR ;
int log_level_int ;
nebula_configuration - > get ( " DEBUG_LEVEL " , log_level_int ) ;
if ( 0 < = log_level_int & & log_level_int < = 3 )
{
clevel = static_cast < Log : : MessageType > ( log_level_int ) ;
}
return clevel ;
}
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 " / " .
* @ return the nebula location .
2010-04-10 22:19:49 +02:00
*/
2008-11-13 16:21:17 +00:00
const string & get_nebula_location ( )
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 .
* @ return the mad execs location .
*/
const string & get_mad_location ( )
{
return mad_location ;
} ;
/**
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
* @ return the mad defaults location .
*/
const string & get_defaults_location ( )
{
return etc_location ;
} ;
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 .
* @ return the log location .
*/
const string & get_log_location ( )
{
return log_location ;
} ;
/**
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 .
2009-01-02 14:58:51 +00:00
* @ return the log location .
*/
const string & get_var_location ( )
{
return var_location ;
} ;
2010-04-10 22:19:49 +02:00
2012-03-01 14:59:19 +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 .
* @ return the log location .
*/
const string & get_ds_location ( )
{
return ds_location ;
} ;
2012-02-25 01:25:59 +01:00
/**
* Returns the Transfer Manager for the system datastore
2012-02-25 23:31:44 +01:00
* @ return the tm name .
2012-02-25 01:25:59 +01:00
*/
string get_system_ds_tm_mad ( )
{
Datastore * ds ;
2012-02-26 21:52:10 +01:00
string tm_mad = " " ;
2012-02-25 01:25:59 +01:00
ds = dspool - > get ( DatastorePool : : SYSTEM_DS_ID , true ) ;
2012-02-26 21:52:10 +01:00
if ( ds = = 0 )
{
NebulaLog : : log ( " DaS " , Log : : ERROR , " Can not get system datastore " ) ;
return tm_mad ;
}
2012-02-25 01:25:59 +01:00
tm_mad = ds - > get_tm_mad ( ) ;
ds - > unlock ( ) ;
return tm_mad ;
} ;
2012-02-26 21:52:10 +01:00
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 .
*/
string get_vm_log_filename ( int oid )
{
ostringstream oss ;
2010-04-10 22:19:49 +02:00
2009-01-02 14:58:51 +00:00
if ( nebula_location = = " / " )
{
2010-04-10 22:19:49 +02:00
oss < < log_location < < oid < < " .log " ;
2009-01-02 14:58:51 +00:00
}
else
{
2010-04-10 22:19:49 +02:00
oss < < nebula_location < < " var/ " < < oid < < " /vm.log " ;
2009-01-02 14:58:51 +00:00
}
2010-04-10 22:19:49 +02:00
2009-01-02 14:58:51 +00:00
return oss . str ( ) ;
} ;
2010-04-10 22:19:49 +02:00
2008-11-13 16:21:17 +00:00
const string & get_nebula_hostname ( )
{
return hostname ;
} ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
static string version ( )
{
2012-04-16 14:06:30 +02:00
return " OpenNebula 3.3.80 " ;
2008-06-17 16:27:32 +00:00
} ;
2010-04-10 22:19:49 +02:00
2011-07-12 13:54:53 +02:00
static string db_version ( )
2011-04-29 18:59:39 +02:00
{
2012-04-16 14:06:30 +02:00
return " 3.3.80 " ;
2011-07-12 13:54:53 +02:00
}
2011-04-29 18:59:39 +02:00
2008-06-17 16:27:32 +00:00
void start ( ) ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
void get_configuration_attribute (
2010-04-10 22:19:49 +02:00
const char * name ,
2008-06-17 16:27:32 +00:00
string & value ) const
{
string _name ( name ) ;
2010-04-10 22:19:49 +02:00
nebula_configuration - > Template : : get ( _name , value ) ;
2008-06-17 16:27:32 +00:00
} ;
2010-04-10 22:19:49 +02:00
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
2011-03-30 19:03:49 +02:00
Nebula ( ) : nebula_configuration ( 0 ) , db ( 0 ) , vmpool ( 0 ) , hpool ( 0 ) , vnpool ( 0 ) ,
2012-02-24 15:53:53 +01:00
upool ( 0 ) , ipool ( 0 ) , gpool ( 0 ) , tpool ( 0 ) , dspool ( 0 ) , clpool ( 0 ) ,
lcm ( 0 ) , vmm ( 0 ) , im ( 0 ) , tm ( 0 ) , dm ( 0 ) , rm ( 0 ) , hm ( 0 ) , authm ( 0 ) , aclm ( 0 ) , imagem ( 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-03-01 14:59:19 +01:00
ds_location = " /var/lib/one/datastores/ " ;
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-03-01 14:59:19 +01:00
ds_location = nebula_location + " var/datastores/ " ;
2010-04-10 22:19:49 +02:00
}
2009-01-02 14:58:51 +00:00
} ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
~ Nebula ( )
{
if ( vmpool ! = 0 )
{
delete vmpool ;
}
2008-11-13 20:12:52 +00:00
if ( vnpool ! = 0 )
{
delete vnpool ;
}
2008-06-17 16:27:32 +00:00
if ( hpool ! = 0 )
{
delete hpool ;
}
2009-07-09 14:34:34 +00:00
if ( upool ! = 0 )
{
delete upool ;
}
2010-06-25 13:24:54 +02:00
if ( ipool ! = 0 )
{
delete ipool ;
}
2011-05-10 18:45:15 +02:00
if ( gpool ! = 0 )
{
delete gpool ;
}
2011-03-30 19:03:49 +02:00
if ( tpool ! = 0 )
{
delete tpool ;
}
2012-02-10 01:18:46 +01:00
if ( dspool ! = 0 )
{
2012-02-10 13:24:52 +01:00
delete dspool ;
2012-02-10 01:18:46 +01:00
}
2012-02-24 15:53:53 +01:00
if ( clpool ! = 0 )
{
delete clpool ;
}
2012-02-10 01:18:46 +01:00
2008-06-17 16:27:32 +00:00
if ( vmm ! = 0 )
{
delete vmm ;
}
if ( lcm ! = 0 )
{
delete lcm ;
}
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
if ( im ! = 0 )
{
delete im ;
}
if ( tm ! = 0 )
{
delete tm ;
}
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
if ( dm ! = 0 )
{
delete dm ;
}
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
if ( rm ! = 0 )
{
delete rm ;
}
2010-04-10 22:19:49 +02:00
2009-04-04 22:07:06 +00:00
if ( hm ! = 0 )
{
delete hm ;
}
2010-04-10 22:19:49 +02:00
2010-07-08 19:28:10 +02:00
if ( authm ! = 0 )
{
delete authm ;
}
2011-06-22 19:22:52 +02:00
if ( aclm ! = 0 )
{
delete aclm ;
}
2011-03-22 18:21:09 +01:00
if ( imagem ! = 0 )
{
delete imagem ;
}
2008-06-17 16:27:32 +00:00
if ( nebula_configuration ! = 0 )
{
delete nebula_configuration ;
}
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
if ( db ! = 0 )
{
delete db ;
}
} ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
Nebula ( Nebula const & ) { } ;
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
2009-01-02 14:58:51 +00:00
string nebula_location ;
2010-04-10 22:19:49 +02:00
2009-01-02 14:58:51 +00:00
string mad_location ;
string etc_location ;
string log_location ;
string var_location ;
2010-08-02 11:24:01 +02:00
string hook_location ;
2010-08-17 00:28:48 +02:00
string remotes_location ;
2012-03-01 14:59:19 +01:00
string ds_location ;
2010-08-17 00:28:48 +02:00
2009-01-02 14:58:51 +00:00
string hostname ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Configuration
// ---------------------------------------------------------------
2011-12-13 23:57:56 +01:00
OpenNebulaTemplate * nebula_configuration ;
2010-04-10 22:19:49 +02:00
2008-06-17 16:27:32 +00:00
// ---------------------------------------------------------------
// Nebula Pools
// ---------------------------------------------------------------
2010-04-10 22:19:49 +02:00
SqlDB * db ;
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 ;
2010-04-10 22:19:49 +02:00
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 ;
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 ;
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 ) ;
2011-04-29 18:59:39 +02:00
/**
* Bootstraps the database control tables
2011-10-10 06:14:46 -07:00
*
* @ return 0 on success
2011-04-29 18:59:39 +02:00
*/
2011-10-10 06:14:46 -07:00
int bootstrap ( ) ;
2011-04-29 18:59:39 +02:00
/**
2011-09-21 16:13:04 +02:00
* Callback function for the check_db_version method . Stores the read
* version in loaded_db_version
* @ param _loaded_db_version returned columns
2011-04-29 18:59:39 +02:00
* @ 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 ) ;
2011-09-21 16:13:04 +02:00
/**
* Reads the current DB version .
*
* @ return 0 on success ,
* - 1 if there is a version mismatch ,
* - 2 if the DB needs a bootstrap
2011-04-29 18:59:39 +02:00
*/
int check_db_version ( ) ;
2008-06-17 16:27:32 +00:00
} ;
# endif /*NEBULA_H_*/