/* -------------------------------------------------------------------------- */ /* Copyright 2002-2015, 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 using namespace std; /** * 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(VirtualMachineTemplate& vmt):Template(vmt){}; /** * Checks the template for RESTRICTED ATTRIBUTES * @param rs_attr the first restricted attribute found if any * @return true if a restricted attribute is found in the template */ bool check(string& rs_attr) { return Template::check(rs_attr, restricted_attributes); }; /** * Deletes all restricted attributes */ void remove_restricted() { Template::remove_restricted(restricted_attributes); }; /** * Deletes all the attributes, except the restricted ones */ void remove_all_except_restricted() { Template::remove_all_except_restricted(restricted_attributes); }; 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 string& target_name, const string& target_uname, const string& new_name, const string& new_uname); private: friend class VirtualMachinePool; static vector restricted_attributes; bool has_restricted() { return restricted_attributes.size() > 0; }; /** * Stores the attributes as restricted, these attributes will be used in * VirtualMachineTemplate::check * @param rattrs Attributes to restrict */ static void set_restricted_attributes(vector& rattrs) { Template::set_restricted_attributes(rattrs, restricted_attributes); }; }; /* -------------------------------------------------------------------------- */ /* -------------------------------------------------------------------------- */ #endif /*VIRTUAL_MACHINE_TEMPLATE_H_*/