2016-12-11 21:05:07 +01:00
/* -------------------------------------------------------------------------- */
/* Copyright 2002-2016, 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_ATTRIBUTE_H_
# define VIRTUAL_MACHINE_ATTRIBUTE_H_
2017-04-10 18:41:43 +02:00
# include "ExtendedAttribute.h"
2016-12-11 21:05:07 +01:00
/**
* This class represents a generic VirtualMachine attribute , it exposes the
* basic VectorAttribute interface and can be decorated with functionality
* for an specific class , ( e . g . disks or nics ) .
*
* The attribute operates directly on the VirtualMachineTemplate attribute . IT
* IS NOT CLONED OR COPIED
*/
2017-04-10 18:41:43 +02:00
class VirtualMachineAttribute : public ExtendedAttribute
2016-12-11 21:05:07 +01:00
{
protected :
/**
* Creates the attribute with a reference to a VectorAttribute . The object
* is shared and WILL BE modified through this interface .
* @ param va pointer to the VectorAttribute .
*/
VirtualMachineAttribute ( VectorAttribute * _va ) :
2017-04-10 18:41:43 +02:00
ExtendedAttribute ( _va ) { } ;
2016-12-11 21:05:07 +01:00
VirtualMachineAttribute ( VectorAttribute * _va , int _id ) :
2017-04-10 18:41:43 +02:00
ExtendedAttribute ( _va , _id ) { } ;
2016-12-11 21:05:07 +01:00
virtual ~ VirtualMachineAttribute ( ) { } ;
/* ---------------------------------------------------------------------- */
/* VirtualMachineAttribute Interface */
/* ---------------------------------------------------------------------- */
/**
* Sets the flag in the attribute in the form ( FLAG = " YES " )
*/
void set_flag ( const string & flag )
{
replace ( flag , true ) ;
} ;
/**
* Clears a previously set flag
*/
void clear_flag ( const string & flag )
{
remove ( flag ) ;
} ;
bool is_flag ( const string & flag ) const
{
bool value ;
2017-04-10 18:41:43 +02:00
vector_value ( flag , value ) ;
2016-12-11 21:05:07 +01:00
return value ;
}
private :
friend class VirtualMachineAttributeSet ;
} ;
/**
* This class represents a set of VirtualMachineAttributes it provides fast
* access to individual elements ( by ID ) and implement collective operations
*/
2017-04-10 18:41:43 +02:00
class VirtualMachineAttributeSet : public ExtendedAttributeSet
2016-12-11 21:05:07 +01:00
{
protected :
/**
2016-12-12 10:26:55 +01:00
* Creates the VirtualMachineAttribute set
* @ param dispose elements upon set destruction
2016-12-11 21:05:07 +01:00
*/
2017-04-10 18:41:43 +02:00
VirtualMachineAttributeSet ( bool _dispose ) : ExtendedAttributeSet ( _dispose ) { } ;
2016-12-11 21:05:07 +01:00
2017-04-10 18:41:43 +02:00
virtual ~ VirtualMachineAttributeSet ( ) { } ;
2016-12-11 21:05:07 +01:00
/* ---------------------------------------------------------------------- */
/* Methods to access attributes */
/* ---------------------------------------------------------------------- */
/**
* @ return attribute by id or 0 if not found
*/
2017-04-10 18:41:43 +02:00
VirtualMachineAttribute * get_attribute ( int id ) const
{
return static_cast < VirtualMachineAttribute * > ( get_attribute ( id ) ) ;
}
2016-12-11 21:05:07 +01:00
/**
* @ return attribute with the given flag set or 0 if not found
*/
VirtualMachineAttribute * get_attribute ( const string & flag ) const ;
/**
* Deletes the attribute with the given flag set .
* @ return Pointer to the attribute or 0 if not found
*/
VirtualMachineAttribute * remove_attribute ( const string & flag ) ;
/**
* Sets flag in a VirtualMachineAttribute
* @ param a_id of the attribute
* @ param flag_name
* @ return 0 on success
*/
int set_flag ( int a_id , const string & flag_name ) ;
/**
* Clears the flag from the VirtualMachineAttributes in the set .
* @ return the attribute for which the flag was cleared , 0 if none
*/
VirtualMachineAttribute * clear_flag ( const string & flag_name ) ;
/* ---------------------------------------------------------------------- */
/* Attribute map interface */
/* ---------------------------------------------------------------------- */
/**
* Abstract method to create the VirtualMachineAttributes for this set
*/
2017-04-10 18:41:43 +02:00
virtual ExtendedAttribute * attribute_factory ( VectorAttribute * va ,
2016-12-11 21:05:07 +01:00
int id ) const = 0 ;
} ;
# endif /*VIRTUAL_MACHINE_ATTRIBUTE_H_*/