1
0
mirror of https://github.com/OpenNebula/one.git synced 2025-01-21 18:03:38 +03:00
one/include/HookLog.h
Ruben S. Montero 6143dd95ce
F #3380: New Hook system. Drivers, oned and command line tool
Co-authored-by: Christian González <cgonzalez@opennebula.systems>
2019-09-09 14:47:42 +02:00

120 lines
3.6 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 HOOKLOG_H_
#define HOOKLOG_H_
#include <string>
#include "ActionManager.h"
#include "Attribute.h"
class SqlDB;
/**
* Thread loop (timer action to purge the log)
*/
extern "C" void * hlog_action_loop(void *arg);
/**
* This class represents the execution log of Hooks. It writes/reads execution
* records in the DB.
*/
class HookLog
{
public:
HookLog(SqlDB *db, const VectorAttribute * hl_conf);
virtual ~HookLog() = default;
/**
* Get the execution log for a given hook
* @param hkid the ID of the hook
* @param xml_log execution records in XML format
*
* @return 0 on success
*/
int dump_log(int hkid, std::string &xml_log);
/**
* Get the execution log for all hooks
* @param xml_log execution records in XML format
*
* @return 0 on success
*/
int dump_log(std::string &xml_log);
/**
* Adds a new execution record to the hook
* @param hkid the ID of the hook
* @param rc return code of the execution
* @param xml_result rc, std streams and execution context
*
* @return 0 on success
*/
int add(int hkid, int rc, std::string &xml_result);
/**
* Retries a given execution for a host, using the same execution context
* @param hkid the ID of the hook
* @param exeid the execution identifier
* @param err_msg error message
*
* @return 0 on success
*/
int retry(int hkid, int exeid, std::string& err_msg);
/**
* Bootstraps the database table(s) associated to the Hook Log
* @return 0 on success
*/
static int bootstrap(SqlDB *_db);
private:
// ----------------------------------------
// DataBase implementation variables
// ----------------------------------------
static const char * table;
static const char * db_names;
static const char * db_bootstrap;
/**
* Pointer to the database.
*/
SqlDB * db;
/**
* Number of log records saved for each hook.
*/
int log_retention;
/**
* Dumps hook log records
* @param hkid -1 to dump all records
* @param exec_id -1 to dump all records
* @param xml_log execution results in xml format
*
* @return 0 on success
*/
int _dump_log(int hkid, int exec_id, std::string &xml_log);
};
#endif /*HOOKLOG_H_*/