1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-11 05:17:41 +03:00
one/include/Snapshots.h
Ruben S. Montero 904b3248e9 feature #3782: Remove SOURCE and PARENT from snapshots. Drivers MUST
generate internal snapshot references from snapshot_id, parent_id
2015-05-21 14:12:35 +02:00

146 lines
4.3 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2015, OpenNebula Project (OpenNebula.org), C12G Labs */
/* */
/* 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 SNAPSHOTS_H_
#define SNAPSHOTS_H_
#include <iostream>
#include <string>
#include <map>
#include <libxml/parser.h>
#include "Template.h"
using namespace std;
class VectorAttribute;
/**
* 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>
* <TAG>: Description
* <DATE>: the snapshot was taken
* <PARENT_ID>: backing for this snapshot, 0 for the original image
* <PARENT>: Opaque (driver specific) string representing the parent
* <SOURCE>: Opaque (driver specific) string representing the snapshot
*/
class Snapshots
{
public:
Snapshots(int _disk_id);
virtual ~Snapshots();
// *************************************************************************
// 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);
/**
* XML Representation of the Snapshots
*/
string& to_xml(string& xml) const
{
return snapshot_template.to_xml(xml);
};
/**
* Creates a new (empty) snapshot of the active disk
* @param tag description of this snapshot (optional)
* @return id of the new snapshot
*/
int create_snapshot(const string& tag);
/**
* Removes the snapshot from the list
* @param id of the snapshot
*/
int delete_snapshot(unsigned int id);
/**
* Set the given snapshot as active. Updates the values of the current
* snapshot
*/
int active_snapshot(unsigned int id, string& error);
/**
* Return the disk_id of the snapshot list
*/
int get_disk_id()
{
return disk_id;
}
/**
* Get Attribute from the given snapshot
* @param id of the snapshot
* @param name of the attribute
*
* @return value or empty if not found
*/
string get_snapshot_attribute(unsigned int id, const char* name);
private:
/**
* Get a snapshot from the pool
* @param id of the snapshot
* @return pointer to the snapshot (VectorAttribute) or null
*/
VectorAttribute * get_snapshot(unsigned int id);
/**
* Text representation of the snapshot pool. To be stored as part of the
* VM or Image Templates
*/
Template snapshot_template;
/**
* Next id
*/
unsigned int next_snapshot;
/**
* Id of the active (current) snapshot, 0 represents the base image
*/
unsigned int active;
/**
* Id of the disk associated with this snapshot list
*/
unsigned int disk_id;
/**
* Snapshot pointer map
*/
map<unsigned int, VectorAttribute *> snapshot_pool;
};
#endif /*SNAPSHOTS_H_*/