2015-05-14 19:43:31 +02:00
/* -------------------------------------------------------------------------- */
2023-01-09 12:23:19 +01:00
/* Copyright 2002-2023, OpenNebula Project, OpenNebula Systems */
2015-05-14 19:43:31 +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. */
/* -------------------------------------------------------------------------- */
2015-05-19 18:41:23 +02:00
# ifndef SNAPSHOTS_H_
# define SNAPSHOTS_H_
2015-05-14 19:43:31 +02:00
# include <string>
# include <map>
# include "Template.h"
class VectorAttribute ;
/**
2015-05-19 18:41:23 +02:00
* This class represents a list of Snapshots associated to an image or Virtual
* Machine Disk . The list is in the form :
* < SNAPSHOTS >
* < DISK_ID > : of the disk the snapshots are taken from ( the initial backing )
* < ACTIVE > : the current snapshot in use by the VM . 0 for the original DISK
* < SNAPSHOT >
* < ID >
2015-07-09 13:13:07 +02:00
* < NAME > : Description
2015-05-19 18:41:23 +02:00
* < DATE > : the snapshot was taken
2015-05-26 13:52:40 +02:00
* < PARENT > : backing for this snapshot , - 1 for the original image
* < CHILDREN > : comma separated list of children snapshots
2015-05-14 19:43:31 +02:00
*/
class Snapshots
{
public :
2018-12-24 13:58:27 +01:00
/**
* ALLOW_ORPHANS : Define how child snapshots are handled .
* - ALLOW : Children can be orphan ( no parent snapshot )
* | - snap_1
* | - snap_2
* | - snap_3
*
* - DENY : New snapshots are set active and child of the previous one
* | - snap_1
* | - snap_2
* | - snap_3
*
* - MIXED : Snapshots are children of last snapshot reverted to
* | - snap_1 ( < - - - revert )
* | - snap_2
* | - snap_3
2021-05-26 18:21:13 +02:00
* - FORMAT : Depends on the image format , ( used in shared TM )
* - for qcow2 - > DENY
* - for raw - > ALLOW
2018-12-24 13:58:27 +01:00
*/
enum AllowOrphansMode
{
2021-05-26 18:21:13 +02:00
ALLOW = 0 ,
DENY = 1 ,
MIXED = 2 ,
FORMAT = 3
2018-12-24 13:58:27 +01:00
} ;
2020-07-02 22:42:10 +02:00
static std : : string allow_orphans_mode_to_str ( AllowOrphansMode aom )
2018-12-24 13:58:27 +01:00
{
switch ( aom )
{
2021-05-26 18:21:13 +02:00
case ALLOW : return " YES " ;
case DENY : return " NO " ;
case MIXED : return " MIXED " ;
case FORMAT : return " FORMAT " ;
2018-12-24 13:58:27 +01:00
}
return " NO " ;
} ;
2020-07-02 22:42:10 +02:00
static AllowOrphansMode str_to_allow_orphans_mode ( const std : : string & aom )
2018-12-24 13:58:27 +01:00
{
if ( aom = = " YES " )
{
return ALLOW ;
}
else if ( aom = = " MIXED " )
{
return MIXED ;
}
2021-05-26 18:21:13 +02:00
else if ( aom = = " FORMAT " )
{
return FORMAT ;
}
2018-12-24 13:58:27 +01:00
else
{
return DENY ;
}
} ;
Snapshots ( int _disk_id , AllowOrphansMode orphans ) ;
2015-05-14 19:43:31 +02:00
2015-05-30 13:31:25 +02:00
Snapshots ( const Snapshots & s ) ;
2015-06-01 19:25:02 +02:00
Snapshots & operator = ( const Snapshots & s ) ;
2019-07-10 19:36:43 +02:00
~ Snapshots ( ) = default ;
2015-05-14 19:43:31 +02:00
// *************************************************************************
// Inititalization functions
// *************************************************************************
/**
* Builds the snapshot list from its XML representation . This function
* is used when importing it from the DB .
* @ param node xmlNode for the template
* @ return 0 on success
*/
int from_xml_node ( const xmlNodePtr node ) ;
2015-05-19 18:41:23 +02:00
/**
* XML Representation of the Snapshots
*/
2020-07-02 22:42:10 +02:00
std : : string & to_xml ( std : : string & xml ) const
2015-05-19 18:41:23 +02:00
{
return snapshot_template . to_xml ( xml ) ;
} ;
/**
* Creates a new ( empty ) snapshot of the active disk
2015-07-09 13:13:07 +02:00
* @ param name description of this snapshot ( optional )
2015-06-16 23:40:09 +02:00
* @ param size_mb of the snapshot ( virtual size )
2015-05-19 18:41:23 +02:00
* @ return id of the new snapshot
*/
2020-07-02 22:42:10 +02:00
int create_snapshot ( const std : : string & name , long long size_mb ) ;
2015-05-14 19:43:31 +02:00
2015-05-19 18:41:23 +02:00
/**
2023-07-20 09:51:15 +02:00
* Check if an snapshot can be deleted , for the snap_delete operation on
* VMs
2015-05-19 18:41:23 +02:00
* @ param id of the snapshot
2015-05-26 11:24:34 +02:00
* @ param error if any
2015-06-04 19:46:46 +02:00
* @ return true if can be deleted , false otherwise
2015-05-19 18:41:23 +02:00
*/
2023-07-20 09:51:15 +02:00
bool test_delete ( int id , bool persistent , std : : string & error ) const ;
// Version for the snap_delete operation on images
bool test_delete_image ( int id , std : : string & error ) const ;
2015-06-04 19:46:46 +02:00
/**
* Removes the snapshot from the list
* @ param id of the snapshot
*/
2015-07-01 17:50:47 +02:00
void delete_snapshot ( int id ) ;
2015-05-14 19:43:31 +02:00
/**
* Set the given snapshot as active . Updates the values of the current
* snapshot
2018-12-24 13:58:27 +01:00
*
* @ param id id of the snapshot
* @ param revert true if the cause of changing the active snapshot
* is because a revert
2015-05-14 19:43:31 +02:00
*/
2018-12-24 13:58:27 +01:00
int active_snapshot ( int id , bool revert ) ;
2015-05-19 18:41:23 +02:00
2018-10-11 17:01:36 +02:00
/**
* Rename the given snapshot by the given name
*/
2020-07-02 22:42:10 +02:00
int rename_snapshot ( int id , const std : : string & name , std : : string & str_error ) ;
2018-10-11 17:01:36 +02:00
2015-06-05 16:01:06 +02:00
/**
* Clear all the snapshots in the list
*/
void clear ( )
{
2023-07-20 09:51:15 +02:00
active = - 1 ;
_disk_id = - 1 ;
2015-06-05 16:01:06 +02:00
snapshot_template . clear ( ) ;
snapshot_pool . clear ( ) ;
}
2015-05-19 18:41:23 +02:00
/**
* Return the disk_id of the snapshot list
*/
2023-07-20 09:51:15 +02:00
int disk_id ( ) const
2015-05-19 18:41:23 +02:00
{
2023-07-20 09:51:15 +02:00
return _disk_id ;
2015-05-19 18:41:23 +02:00
}
2015-05-14 19:43:31 +02:00
2023-07-20 09:51:15 +02:00
/**
* Sets the disk id for this snapshot list
* @ param did the id
*/
void set_disk_id ( int did )
{
_disk_id = did ;
snapshot_template . replace ( " DISK_ID " , did ) ;
} ;
2015-06-04 19:46:46 +02:00
/**
* Return the active snapshot id
*/
2023-07-20 09:51:15 +02:00
int active_id ( ) const
2015-06-04 19:46:46 +02:00
{
return active ;
}
2015-05-30 13:31:25 +02:00
/**
* Removes the DISK_ID attribute to link the list to an Image
*/
void clear_disk_id ( )
{
2023-07-20 09:51:15 +02:00
_disk_id = - 1 ;
2015-05-30 13:31:25 +02:00
snapshot_template . erase ( " DISK_ID " ) ;
} ;
2015-06-01 19:25:02 +02:00
/**
* @ return number of snapshots in the list
*/
2015-06-04 19:46:46 +02:00
unsigned int size ( ) const
2015-06-01 19:25:02 +02:00
{
return snapshot_pool . size ( ) ;
2015-06-04 19:46:46 +02:00
} ;
2015-06-01 19:25:02 +02:00
2023-07-20 09:51:15 +02:00
unsigned int next ( ) const
{
return next_snapshot ;
}
2018-03-19 17:03:09 +01:00
/**
* @ return true if snapshot_pool is empty
*/
bool empty ( ) const
{
return snapshot_pool . empty ( ) ;
} ;
2015-06-05 13:32:00 +02:00
/**
* Check if snapshot exists
* @ param snap_id of the snapshot
* @ return true if the snapshot with snap_id exisits
*/
bool exists ( int snap_id ) const
{
const VectorAttribute * snap = get_snapshot ( snap_id ) ;
return ( snap ! = 0 ) ;
}
2015-06-16 23:40:09 +02:00
/**
* @ return total snapshot size ( virtual ) in mb
*/
2023-07-20 09:51:15 +02:00
long long total_size ( ) const ;
2015-06-16 23:40:09 +02:00
2015-06-17 17:45:37 +02:00
/**
* Get the size ( virtual ) in mb of the given snapshot
* @ param id of the snapshot
* @ return size or 0 if not found
*/
2023-07-20 09:51:15 +02:00
long long snapshot_size ( int id ) const ;
/**
* Return Snapshot children
* @ param if of the snapshot
* @ param children the attribute string
* @ return the number of children
* - 1 No snapshot
* 0 CHILDREN not defined
* N number of children in " 0,2,3,5 " - - - > 4
*/
int children ( int id , std : : string & children ) const ;
2015-06-17 17:45:37 +02:00
2015-05-20 17:48:27 +02:00
/**
* Get Attribute from the given snapshot
* @ param id of the snapshot
* @ param name of the attribute
*
* @ return value or empty if not found
*/
2023-07-20 09:51:15 +02:00
std : : string snapshot_attribute ( int id , const char * name ) const ;
2015-05-20 17:48:27 +02:00
2015-05-14 19:43:31 +02:00
private :
/**
* Get a snapshot from the pool
* @ param id of the snapshot
* @ return pointer to the snapshot ( VectorAttribute ) or null
*/
2015-07-01 17:50:47 +02:00
const VectorAttribute * get_snapshot ( int id ) const ;
2015-06-04 19:46:46 +02:00
2015-07-01 17:50:47 +02:00
VectorAttribute * get_snapshot ( int id )
2015-06-04 19:46:46 +02:00
{
return const_cast < VectorAttribute * > (
2024-06-03 11:40:24 +02:00
static_cast < const Snapshots & > ( * this ) . get_snapshot ( id ) ) ;
2015-06-04 19:46:46 +02:00
} ;
2015-05-14 19:43:31 +02:00
2015-05-30 13:31:25 +02:00
/**
* Build the object internal representation from an initialized
* template
*/
void init ( ) ;
2018-12-24 13:58:27 +01:00
/**
* Updates children list for the current base snapshot in the tree
* @ param snapshot new child to be added
*/
void add_child_mixed ( VectorAttribute * snapshot ) ;
/**
* Updates children list of the active snapshot
* @ param snapshot new child to be added
* @ return - 1 in case of error ( current active does not exist )
*/
int add_child_deny ( VectorAttribute * snapshot ) ;
2015-05-19 18:41:23 +02:00
/**
* Text representation of the snapshot pool . To be stored as part of the
* VM or Image Templates
*/
2015-05-14 19:43:31 +02:00
Template snapshot_template ;
2015-05-19 18:41:23 +02:00
/**
* Next id
*/
2015-07-01 17:50:47 +02:00
int next_snapshot ;
2015-05-14 19:43:31 +02:00
2015-05-19 18:41:23 +02:00
/**
* Id of the active ( current ) snapshot , 0 represents the base image
*/
2015-05-26 12:52:55 +02:00
int active ;
2015-05-19 18:41:23 +02:00
/**
* Id of the disk associated with this snapshot list
*/
2023-07-20 09:51:15 +02:00
int _disk_id ;
2015-05-14 19:43:31 +02:00
2017-07-05 18:07:22 +02:00
/**
* Allow to remove parent snapshots and active one
*/
2018-12-24 13:58:27 +01:00
AllowOrphansMode orphans ;
2017-07-05 18:07:22 +02:00
2015-05-19 18:41:23 +02:00
/**
* Snapshot pointer map
*/
2020-07-02 22:42:10 +02:00
std : : map < int , VectorAttribute * > snapshot_pool ;
2018-12-24 13:58:27 +01:00
/**
* Current snaphsot base for mixed mode
*/
int current_base ;
2015-05-14 19:43:31 +02:00
} ;
2015-05-19 18:41:23 +02:00
# endif /*SNAPSHOTS_H_*/