icinga2/lib/compat/compatlogger.hpp

76 lines
3.0 KiB
C++
Raw Normal View History

2013-03-19 13:04:30 +01:00
/******************************************************************************
* Icinga 2 *
2018-01-02 12:06:00 +01:00
* Copyright (C) 2012-2018 Icinga Development Team (https://www.icinga.com/) *
2013-03-19 13:04:30 +01:00
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation; either version 2 *
* of the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation *
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
******************************************************************************/
2013-09-25 10:55:50 +02:00
#ifndef COMPATLOGGER_H
#define COMPATLOGGER_H
2013-03-19 13:04:30 +01:00
2014-05-25 16:23:35 +02:00
#include "compat/compatlogger.thpp"
#include "icinga/service.hpp"
#include "base/timer.hpp"
2013-03-19 13:04:30 +01:00
#include <fstream>
namespace icinga
{
/**
* An Icinga compat log writer.
*
* @ingroup compat
*/
2018-01-04 06:11:04 +01:00
class CompatLogger final : public ObjectImpl<CompatLogger>
2013-03-19 13:04:30 +01:00
{
public:
2014-11-03 00:44:04 +01:00
DECLARE_OBJECT(CompatLogger);
DECLARE_OBJECTNAME(CompatLogger);
2013-03-19 13:04:30 +01:00
static void StatsFunc(const Dictionary::Ptr& status, const Array::Ptr& perfdata);
void ValidateRotationMethod(const Lazy<String>& lvalue, const ValidationUtils& utils) override;
2013-03-19 13:04:30 +01:00
protected:
void Start(bool runtimeCreated) override;
void Stop(bool runtimeRemoved) override;
2013-03-19 13:04:30 +01:00
private:
void WriteLine(const String& line);
void Flush();
2013-03-19 13:04:30 +01:00
2014-04-03 15:36:13 +02:00
void CheckResultHandler(const Checkable::Ptr& service, const CheckResult::Ptr& cr);
void NotificationSentHandler(const Notification::Ptr& notification, const Checkable::Ptr& service,
const User::Ptr& user, NotificationType notification_type, CheckResult::Ptr const& cr,
const String& author, const String& comment_text, const String& command_name);
void FlappingChangedHandler(const Checkable::Ptr& checkable);
void EnableFlappingChangedHandler(const Checkable::Ptr& checkable);
void TriggerDowntimeHandler(const Downtime::Ptr& downtime);
void RemoveDowntimeHandler(const Downtime::Ptr& downtime);
void ExternalCommandHandler(const String& command, const std::vector<String>& arguments);
2014-04-03 15:36:13 +02:00
void EventCommandHandler(const Checkable::Ptr& service);
2013-03-19 13:04:30 +01:00
Timer::Ptr m_RotationTimer;
void RotationTimerHandler();
void ScheduleNextRotation();
2013-03-19 13:04:30 +01:00
std::ofstream m_OutputFile;
void ReopenFile(bool rotate);
2013-03-19 13:04:30 +01:00
};
}
2013-09-25 10:55:50 +02:00
#endif /* COMPATLOGGER_H */