1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-22 22:03:39 +03:00
one/include/VirtualMachineTemplate.h

167 lines
5.5 KiB
C
Raw Normal View History

/* -------------------------------------------------------------------------- */
2021-02-09 16:07:56 +01:00
/* Copyright 2002-2021, OpenNebula Project, OpenNebula Systems */
/* */
/* 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 VIRTUAL_MACHINE_TEMPLATE_H_
#define VIRTUAL_MACHINE_TEMPLATE_H_
#include "Template.h"
#include <string>
2021-03-15 13:29:17 +01:00
#include <memory>
/**
* Virtual Machine Template class, it represents a VM configuration file.
*/
class VirtualMachineTemplate : public Template
{
public:
VirtualMachineTemplate():Template(false,'=',"TEMPLATE"){};
VirtualMachineTemplate(
bool _replace_mode,
const char _separator,
const char * _xml_root):
Template(_replace_mode, _separator, _xml_root){};
~VirtualMachineTemplate(){};
VirtualMachineTemplate(const Template& vmt):Template(vmt){};
VirtualMachineTemplate& operator=(const VirtualMachineTemplate& t)
{
if (this != &t)
{
Template::operator=(t);
}
return *this;
}
void set_xml_root(const char * _xml_root)
{
Template::set_xml_root(_xml_root);
};
/**
* Replaces the given image from the DISK attribute with a new one
* @param target_id IMAGE_ID the image to be replaced
* @param target_name IMAGE the image to be replaced
* @param target_uname IMAGE_UNAME the image to be replaced
* @param new_name of the new image
* @param new_uname of the owner of the new image
*/
int replace_disk_image(int target_id, const std::string&
target_name, const std::string& target_uname,
const std::string& new_name, const std::string& new_uname);
// -------------------------------------------------------------------------
// Restricted attributes interface implementation
// -------------------------------------------------------------------------
virtual bool check_restricted(std::string& rs_attr, const Template* base)
{
return Template::check_restricted(rs_attr, base, restricted);
}
virtual bool check_restricted(std::string& rs_attr)
{
return Template::check_restricted(rs_attr, restricted);
}
static void parse_restricted(std::vector<const SingleAttribute *>& ra)
{
Template::parse_restricted(ra, restricted);
}
2021-03-15 14:17:17 +01:00
// -------------------------------------------------------------------------
// UpdateConf attributes
2021-03-15 12:22:32 +01:00
// -------------------------------------------------------------------------
2021-03-15 13:29:17 +01:00
static std::map<std::string,std::vector<std::string>> UPDATECONF_ATTRS;
2021-03-15 12:22:32 +01:00
2021-03-15 14:17:17 +01:00
/**
* Returns a new template that contains only the attribues vaild in an
* update conf operation
*
* @return pointer to new VM template
*/
2021-03-15 13:29:17 +01:00
std::unique_ptr<VirtualMachineTemplate> get_updateconf_template() const;
2021-03-15 12:22:32 +01:00
// -------------------------------------------------------------------------
// Encrypted attributes interface implementation
// -------------------------------------------------------------------------
virtual void encrypt(const std::string& one_key)
{
Template::encrypt(one_key, encrypted);
}
virtual void decrypt(const std::string& one_key)
{
Template::decrypt(one_key, encrypted);
}
static void parse_encrypted(std::vector<const SingleAttribute *>& ea)
{
Template::parse_encrypted(ea, encrypted);
}
std::string& to_xml_short(std::string& xml) const;
/**
* Get restricted attributes for NIC
*/
static void restricted_nic(std::set<std::string>& rs)
{
get_restricted("NIC", rs);
}
/**
* Get restricted attributes for DISK
*/
static void restricted_disk(std::set<std::string>& rs)
{
get_restricted("DISK", rs);
}
private:
/**
* Restricted attribute list for VirtualMachineTemplates
*/
static std::map<std::string, std::set<std::string> > restricted;
/**
* Encrypted attribute list for VirtualMachineTemplates
*/
static std::map<std::string, std::set<std::string> > encrypted;
/**
* @param rs set of restricted attributes for a key
* @param name key in the restricted map
*/
static void get_restricted(const std::string& name, std::set<std::string>& rs)
{
auto it = restricted.find(name);
if ( it != restricted.end())
{
rs = it->second;
}
}
};
/* -------------------------------------------------------------------------- */
/* -------------------------------------------------------------------------- */
#endif /*VIRTUAL_MACHINE_TEMPLATE_H_*/