2011-05-25 12:13:17 +02:00
/* -------------------------------------------------------------------------- */
2023-01-09 12:23:19 +01:00
/* Copyright 2002-2023, OpenNebula Project, OpenNebula Systems */
2011-05-25 12:13:17 +02: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 OBJECT_COLLECTION_H_
# define OBJECT_COLLECTION_H_
# include <set>
2023-07-03 18:15:52 +02:00
# include <vector>
2020-07-05 22:01:32 +02:00
# include <string>
# include <libxml/tree.h>
2011-05-25 12:13:17 +02:00
2020-07-05 22:01:32 +02:00
class ObjectXML ;
2011-06-03 12:11:33 +02:00
2011-05-25 12:13:17 +02:00
/**
* Class to store a set of PoolObjectSQL IDs .
*/
class ObjectCollection
{
2012-02-27 14:55:43 +01:00
public :
2011-05-25 12:13:17 +02:00
2020-07-02 22:42:10 +02:00
ObjectCollection ( const std : : string & _collection_name )
2024-06-03 11:40:24 +02:00
: collection_name ( _collection_name ) { } ;
2011-05-25 12:13:17 +02:00
2020-07-02 22:42:10 +02:00
ObjectCollection ( const std : : string & cname , const std : : set < int > & cset )
2024-06-03 11:40:24 +02:00
: collection_name ( cname ) , collection_set ( cset ) { } ;
2016-03-19 23:13:10 +01:00
2024-06-03 11:40:24 +02:00
template < typename T > ObjectCollection ( const std : : string & cname , const std : : vector < T > & cvector )
2023-07-03 18:15:52 +02:00
: collection_name ( cname )
{
for ( const auto & i : cvector )
{
collection_set . insert ( static_cast < int > ( i ) ) ;
}
}
2024-06-03 11:40:24 +02:00
~ ObjectCollection ( ) { } ;
2011-05-25 12:13:17 +02:00
/**
2011-06-03 13:31:11 +02:00
* Adds an ID to the set .
* @ param id The new id
2011-05-25 12:13:17 +02:00
*
* @ return 0 on success , - 1 if the ID was already in the set
*/
2016-03-01 23:31:31 +01:00
int add ( int id ) ;
2011-05-25 12:13:17 +02:00
2023-07-03 18:15:52 +02:00
template < typename T >
void add ( const T & collection )
{
for ( const auto & i : collection )
{
collection_set . insert ( static_cast < int > ( i ) ) ;
}
}
2011-05-25 12:13:17 +02:00
/**
2011-06-03 13:31:11 +02:00
* Deletes an ID from the set .
* @ param id The id
2011-05-25 12:13:17 +02:00
*
* @ return 0 on success , - 1 if the ID was not in the set
*/
2016-03-01 23:31:31 +01:00
int del ( int id ) ;
2023-07-03 18:15:52 +02:00
/**
* Deletes IDs not present in the base collection
* @ param base the reference collection
*
* @ return number of elements deleted
*/
int del_not_present ( const ObjectCollection & base ) ;
2016-03-01 23:31:31 +01:00
/**
* Deletes all IDs from the set .
*/
void clear ( )
{
collection_set . clear ( ) ;
}
2011-05-25 12:13:17 +02:00
/**
* Returns how many IDs are there in the set .
* @ return how many IDs are there in the set .
*/
2016-03-01 23:31:31 +01:00
int size ( ) const
2011-05-25 12:13:17 +02:00
{
return collection_set . size ( ) ;
} ;
2016-03-10 16:28:33 +01:00
/**
* Rebuilds the object from an xml object
* @ param xml xml object
* @ param xpath_prefix Parent nodes , e . g . " /DATASTORE/ "
*
* @ return 0 on success , - 1 otherwise
*/
2020-07-02 22:42:10 +02:00
int from_xml ( const ObjectXML * xml , const std : : string & xpath_prefix ) ;
2016-03-10 16:28:33 +01:00
2011-05-25 12:13:17 +02:00
/**
* Function to print the Collection object into a string in
* XML format
* @ param xml the resulting XML string
* @ return a reference to the generated string
*/
2020-07-02 22:42:10 +02:00
std : : string & to_xml ( std : : string & xml ) const ;
2011-05-25 12:13:17 +02:00
2016-01-15 16:42:51 +01:00
/**
* Returns a reference to the IDs set
*/
2020-07-02 22:42:10 +02:00
const std : : set < int > & get_collection ( ) const
2016-01-15 16:42:51 +01:00
{
return collection_set ;
} ;
2015-02-02 15:38:42 +01:00
/**
* Returns true if the collection contains the given id
* @ param id ID to search
* @ return true if the collection contains the given id
*/
2016-08-31 18:24:15 +02:00
bool contains ( int id ) const
2015-02-02 15:38:42 +01:00
{
return collection_set . count ( id ) > 0 ;
}
2016-03-01 23:31:31 +01:00
/**
* Returns and deletes the first element from the set
* @ param the element
* @ return 0 on success - 1 if the set was empty
*/
int pop ( int & elem ) ;
/**
* Adds to the collection the contents of other collection
*
*/
ObjectCollection & operator < < ( const ObjectCollection & r ) ;
F #5989: Live update of Virtual Network attributes
co-authored-by: Pavel Czerný <pczerny@opennebula.systems>
co-authored-by: Frederick Borges <fborges@opennebula.io>
co-authored-by: Christian González <cgonzalez@opennebula.io>
* VNET updates trigger a driver action on running VMs with NICs in the
network.
* VNET includes a sets with VM status: updated, outdated, error and
updating. With VMs in each state.
* VNET flags error situations with a new state UPDATE_FAILURE.
* The same procedure is applied when an AR is updated (only VMs in that
AR are updated).
* A new options in the one.vn.recover API call enable to recover or
retry this VM update operations.
* The following attributes can be live-updated per VNET driver:
- PHYDEV (novlan, vlan, ovs driver)
- MTU (vlan, ovs driver)
- VLAN_ID (vlan, ovs driver)
- QINQ_TYPE (ovs driver)
- CVLANS (ovs driver)
- VLAN_TAGGED_ID (ovs driver)
- OUTER_VLAN_ID (ovs driver)
- INBOUND_AVG_BW (SG, ovs driver + KVM)
- INBOUND_PEAK_BW (SG, ovs driver + KVM)
- INBOUND_PEAK_KB (SG, ovs driver + KVM)
- OUTBOUND_AVG_BW (SG, ovs driver + KVM)
- OUTBOUND_PEAK_BW (SG, ovs driver + KVM)
- OUTBOUND_PEAK_KB (SG, ovs driver + KVM)
* New API call one.vm.updatenic, allows to update individual NICs
without the need of detach/attach (only QoS supported).
* Update operations for: 802.1Q, bridge, fw, ovswitch, ovswitch_vxlan
and vxlan network drivers.
* VNET attributes (old values) stored in VNET_UPDATE to allow
implementation of update operations. The attribute is removed after a
successful update.
* Updates to CLI onevnet (--retry option) / onevm (nicupdate command)
* XSD files updated to reflect the new data model
* Ruby and JAVA bindings updated: new VNET state and recover option, new
VM API call.
* Suntone and Fireedge implementation (lease status, recover option, new
states)
TODO: Virtual Functions does not support this functionality
iii
2022-11-16 13:35:29 +01:00
ObjectCollection & operator < < ( const std : : set < int > & r ) ;
/**
* Compute the set difference ( substract elements in the right hand side
* from this collection )
*/
ObjectCollection & operator - = ( const ObjectCollection & r ) ;
ObjectCollection & operator - = ( const std : : set < int > & r ) ;
2011-05-25 12:13:17 +02:00
private :
/**
* The collection ' s name
*/
2020-07-02 22:42:10 +02:00
std : : string collection_name ;
2011-05-25 12:13:17 +02:00
/**
* Set containing the relations IDs
*/
2020-07-02 22:42:10 +02:00
std : : set < int > collection_set ;
2011-05-25 12:13:17 +02:00
2016-03-17 18:17:37 +01:00
/**
* Rebuilds the object from an xml node
* @ param node The xml node pointer
*
* @ return 0 on success , - 1 otherwise
*/
int from_xml_node ( const xmlNodePtr node ) ;
2011-05-25 12:13:17 +02:00
} ;
# endif /*OBJECT_COLLECTION_H_*/