/* -------------------------------------------------------------------------- */ /* Copyright 2002-2014, OpenNebula Project (OpenNebula.org), C12G Labs */ /* */ /* 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_ #include "SqlDB.h" #include "SystemDB.h" #include "NebulaTemplate.h" #include "VirtualMachinePool.h" #include "VirtualNetworkPool.h" #include "HostPool.h" #include "UserPool.h" #include "VMTemplatePool.h" #include "GroupPool.h" #include "DatastorePool.h" #include "ClusterPool.h" #include "DocumentPool.h" #include "ZonePool.h" #include "VirtualMachineManager.h" #include "LifeCycleManager.h" #include "InformationManager.h" #include "TransferManager.h" #include "DispatchManager.h" #include "RequestManager.h" #include "HookManager.h" #include "AuthManager.h" #include "AclManager.h" #include "ImageManager.h" #include "DefaultQuotas.h" #include "Callbackable.h" /** * 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 { public: static Nebula& instance() { static Nebula nebulad; return nebulad; }; // -------------------------------------------------------------- // Pool Accessors // -------------------------------------------------------------- VirtualMachinePool * get_vmpool() { return vmpool; }; HostPool * get_hpool() { return hpool; }; VirtualNetworkPool * get_vnpool() { return vnpool; }; UserPool * get_upool() { return upool; }; ImagePool * get_ipool() { return ipool; }; GroupPool * get_gpool() { return gpool; }; VMTemplatePool * get_tpool() { return tpool; }; DatastorePool * get_dspool() { return dspool; }; ClusterPool * get_clpool() { return clpool; }; DocumentPool * get_docpool() { return docpool; }; ZonePool * get_zonepool() { return zonepool; }; // -------------------------------------------------------------- // Manager Accessors // -------------------------------------------------------------- VirtualMachineManager * get_vmm() { return vmm; }; LifeCycleManager * get_lcm() { return lcm; }; InformationManager * get_im() { return im; }; TransferManager * get_tm() { return tm; }; DispatchManager * get_dm() { return dm; }; HookManager * get_hm() { return hm; }; AuthManager * get_authm() { return authm; }; ImageManager * get_imagem() { return imagem; }; AclManager * get_aclm() { return aclm; }; // -------------------------------------------------------------- // Environment & Configuration // -------------------------------------------------------------- /** * Returns the value of LOG->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; vector logs; int rc; int log_level_int; rc = nebula_configuration->get("LOG", logs); if ( rc != 0 ) { string value; const VectorAttribute * log = static_cast (logs[0]); value = log->vector_value("DEBUG_LEVEL"); log_level_int = atoi(value.c_str()); if ( Log::ERROR <= log_level_int && log_level_int <= Log::DDDEBUG ) { clevel = static_cast(log_level_int); } } return clevel; } /** * Returns the value of LOG->SYSTEM in oned.conf file * @return the logging system CERR, FILE_TS or SYSLOG */ NebulaLog::LogType get_log_system() const { vector logs; int rc; NebulaLog::LogType log_system = NebulaLog::UNDEFINED; rc = nebula_configuration->get("LOG", logs); if ( rc != 0 ) { string value; const VectorAttribute * log = static_cast (logs[0]); value = log->vector_value("SYSTEM"); log_system = NebulaLog::str_to_type(value); } return log_system; }; /** * Returns the value of ONE_LOCATION env variable. When this variable is * not defined the nebula location is "/". * @return the nebula location. */ const string& get_nebula_location() { 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. */ const string& get_mad_location() { 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. */ const string& get_defaults_location() { 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. */ const string& get_log_location() { 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. */ const string& get_var_location() { return var_location; }; /** * * */ int get_ds_location(int cluster_id, string& dsloc) { if ( cluster_id != -1 ) { Cluster * cluster = clpool->get(cluster_id, true); if ( cluster == 0 ) { return -1; } cluster->get_ds_location(dsloc); cluster->unlock(); } else { get_configuration_attribute("DATASTORE_LOCATION", dsloc); } return 0; } /** * 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. */ const string& get_vms_location() { return vms_location; }; /** * 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; if (nebula_location == "/") { oss << log_location << oid << ".log"; } else { oss << vms_location << oid << "/vm.log"; } return oss.str(); }; /** * Returns the name of the host running oned * @return the name */ const string& get_nebula_hostname() { return hostname; }; /** * Returns the version of oned * @return the version */ static string version() { return "OpenNebula " + code_version(); }; /** * Returns the version of oned * @return */ static string code_version() { return "4.8.0"; // bump version } /** * Version needed for the DB, shared tables * @return */ static string shared_db_version() { return "4.6.0"; } /** * Version needed for the DB, local tables * @return */ static string local_db_version() { return "4.7.80"; } /** * Starts all the modules and services for OpenNebula */ void start(bool bootstrap_only=false); /** * Initialize the database */ void bootstrap_db(); // -------------------------------------------------------------- // Federation // -------------------------------------------------------------- bool is_federation_enabled() { return federation_enabled; }; bool is_federation_master() { return federation_master; }; bool is_federation_slave() { return federation_enabled && !federation_master; }; int get_zone_id() { return zone_id; }; const string& get_master_oned() { return master_oned; }; // ----------------------------------------------------------------------- // Configuration attributes (read from oned.conf) // ----------------------------------------------------------------------- /** * Gets a configuration attribute for oned * @param name of the attribute * @param value of the attribute */ void get_configuration_attribute( const char * name, string& value) const { string _name(name); nebula_configuration->Template::get(_name, value); }; /** * Gets a configuration attribute for oned (long long version) */ void get_configuration_attribute( const char * name, long long& value) const { string _name(name); nebula_configuration->Template::get(_name, value); }; /** * Gets a configuration attribute for oned (time_t version) */ void get_configuration_attribute( const char * name, time_t& value) const { nebula_configuration->get(name, value); }; /** * Gets a configuration attribute for oned, bool version */ void get_configuration_attribute( const char * name, bool& value) const { string _name(name); nebula_configuration->Template::get(_name, value); }; /** * Gets a TM configuration attribute */ int get_tm_conf_attribute( const string& tm_name, const VectorAttribute* &value) const { vector::const_iterator it; vector values; nebula_configuration->Template::get("TM_MAD_CONF", values); for (it = values.begin(); it != values.end(); it ++) { value = dynamic_cast(*it); if (value == 0) { continue; } if (value->vector_value("NAME") == tm_name) { return 0; } } value = 0; return -1; }; /** * Gets an XML document with all of the configuration attributes * @return the XML */ string get_configuration_xml() const { string xml; return nebula_configuration->to_xml(xml); }; // ----------------------------------------------------------------------- // Default Quotas // ----------------------------------------------------------------------- /** * Get the default quotas for OpenNebula users * @return the default quotas */ const DefaultQuotas& get_default_user_quota() { return default_user_quota; }; /** * 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 */ int set_default_user_quota(Template *tmpl, string& error) { int rc = default_user_quota.set(tmpl, error); if ( rc == 0 ) { rc = default_user_quota.update(); } return rc; }; /** * Get the default quotas for OpenNebula for groups * @return the default quotas */ const DefaultQuotas& get_default_group_quota() { return default_group_quota; }; /** * 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 */ int set_default_group_quota(Template *tmpl, string& error) { int rc = default_group_quota.set(tmpl, error); if ( rc == 0 ) { rc = default_group_quota.update(); } return rc; }; // ----------------------------------------------------------------------- // 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 */ int select_sys_attribute(const string& attr_name, string& attr_xml) { 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( const string& attr_name, const string& xml_attr, string& error_str) { 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( const string& attr_name, const string& xml_attr, string& error_str) { return system_db->update_sys_attribute(attr_name, xml_attr, error_str); }; private: // ----------------------------------------------------------------------- //Constructors and = are private to only access the class through instance // ----------------------------------------------------------------------- Nebula():nebula_configuration(0), 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"), system_db(0), db(0), vmpool(0), hpool(0), vnpool(0), upool(0), ipool(0), gpool(0), tpool(0), dspool(0), clpool(0), docpool(0), zonepool(0), lcm(0), vmm(0), im(0), tm(0), dm(0), rm(0), hm(0), authm(0), aclm(0), imagem(0) { 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/"; } }; ~Nebula() { delete vmpool; delete vnpool; delete hpool; delete upool; delete ipool; delete gpool; delete tpool; delete dspool; delete clpool; delete docpool; delete zonepool; delete vmm; delete lcm; delete im; delete tm; delete dm; delete rm; delete hm; delete authm; delete aclm; delete imagem; delete nebula_configuration; delete db; delete system_db; }; Nebula& operator=(Nebula const&){return *this;}; // --------------------------------------------------------------- // Environment variables // --------------------------------------------------------------- string nebula_location; string mad_location; string etc_location; string log_location; string var_location; string hook_location; string remotes_location; string vms_location; string hostname; // --------------------------------------------------------------- // Configuration // --------------------------------------------------------------- OpenNebulaTemplate * nebula_configuration; // --------------------------------------------------------------- // Federation // --------------------------------------------------------------- bool federation_enabled; bool federation_master; int zone_id; string master_oned; // --------------------------------------------------------------- // Default quotas // --------------------------------------------------------------- DefaultQuotas default_user_quota; DefaultQuotas default_group_quota; // --------------------------------------------------------------- // The system database // --------------------------------------------------------------- SystemDB * system_db; // --------------------------------------------------------------- // Nebula Pools // --------------------------------------------------------------- SqlDB * db; VirtualMachinePool * vmpool; HostPool * hpool; VirtualNetworkPool * vnpool; UserPool * upool; ImagePool * ipool; GroupPool * gpool; VMTemplatePool * tpool; DatastorePool * dspool; ClusterPool * clpool; DocumentPool * docpool; ZonePool * zonepool; // --------------------------------------------------------------- // Nebula Managers // --------------------------------------------------------------- LifeCycleManager * lcm; VirtualMachineManager * vmm; InformationManager * im; TransferManager * tm; DispatchManager * dm; RequestManager * rm; HookManager * hm; AuthManager * authm; AclManager * aclm; ImageManager * imagem; // --------------------------------------------------------------- // Implementation functions // --------------------------------------------------------------- friend void nebula_signal_handler (int sig); }; #endif /*NEBULA_H_*/