1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-03 01:17:41 +03:00
one/include/VirtualMachineMonitorInfo.h
2019-01-16 11:47:59 +01:00

109 lines
3.0 KiB
C++

/* -------------------------------------------------------------------------- */
/* Copyright 2002-2019, 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_MONITOR_INFO_H_
#define VIRTUAL_MACHINE_MONITOR_INFO_H_
#include "Template.h"
#include <string.h>
using namespace std;
/**
* Virtual Machine Monitor class, stores the monitor data for the VM
*/
class VirtualMachineMonitorInfo : public Template
{
public:
VirtualMachineMonitorInfo():Template(false,'=',"MONITORING"){};
~VirtualMachineMonitorInfo(){};
/**
* Update the monitoring information with data from the probes
* @param monitor_data of the VM
* @param error description if any
* @return 0 on success
*/
int update(const string& monitor_data, string& error)
{
VirtualMachineMonitorInfo new_info;
char * error_c = 0;
remove_state();
if (new_info.parse(monitor_data, &error_c) != 0)
{
error = error_c;
free(error_c);
return -1;
}
merge(&new_info);
return 0;
};
char remove_state()
{
string state_str;
get("STATE", state_str);
erase("STATE");
if (state_str.empty())
{
return '-';
}
return state_str[0];
};
string& to_xml_short(string& xml) const
{
ostringstream oss;
string cpu, memory, state;
if (attributes.empty())
{
oss << "<MONITORING/>";
}
else
{
get("CPU", cpu);
get("MEMORY", memory);
get("STATE", state);
oss << "<MONITORING>"
<< "<CPU>" << one_util::escape_xml(cpu) << "</CPU>"
<< "<MEMORY>" << one_util::escape_xml(memory) << "</MEMORY>"
<< "<STATE>" << one_util::escape_xml(state) << "</STATE>"
<< "</MONITORING>";
}
xml = oss.str();
return xml;
}
};
#endif