mirror of
https://github.com/Icinga/icinga2.git
synced 2026-05-28 04:12:13 -04:00
I've used the following command to replace the original copyright header
lines in a C-style comment block:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f -exec perl -pi -e 's{/\*[^*]*\(\s*c\s*\)\s*(\d{4})\s*Icinga\s+GmbH[^*]*\*/}{// SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n// SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
For files that use shell-style comments (#) like CMakeLists.txt, I've
used this command:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f -exec perl -pi -e 's{#.*\(\s*c\s*\)\s(\d{4})\sIcinga\s+GmbH.*}{# SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n# SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
And for SQL files:
```
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f \( -name '*.sql' \) -exec perl -pi -e 's{--.*\(c\)\s(\d{4})\sIcinga\sGmbH.*}{-- SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n-- SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
$ find . \( -type d \( -name '\..*' -o -name third-party -o -name scripts -o -name prefix -o -name malloc -o -name server -o -name docker -o -name build -o -name doc \) -prune \) -o -type f \( -name '*.sql' \) -exec perl -pi -e 's{-- Copyright \(c\)\s(\d{4})\sIcinga\s+Development\sTeam.*}{-- SPDX-FileCopyrightText: \1 Icinga GmbH <https://icinga.com>\n-- SPDX-License-Identifier: GPL-2.0-or-later}gi' {} +
```
143 lines
3.4 KiB
C++
143 lines
3.4 KiB
C++
// SPDX-FileCopyrightText: 2012 Icinga GmbH <https://icinga.com>
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#include "livestatus/commandstable.hpp"
|
|
#include "icinga/icingaapplication.hpp"
|
|
#include "icinga/checkcommand.hpp"
|
|
#include "icinga/eventcommand.hpp"
|
|
#include "icinga/notificationcommand.hpp"
|
|
#include "icinga/compatutility.hpp"
|
|
#include "base/configtype.hpp"
|
|
#include "base/objectlock.hpp"
|
|
#include "base/convert.hpp"
|
|
#include <boost/algorithm/string/replace.hpp>
|
|
|
|
using namespace icinga;
|
|
|
|
CommandsTable::CommandsTable()
|
|
{
|
|
AddColumns(this);
|
|
}
|
|
|
|
void CommandsTable::AddColumns(Table *table, const String& prefix,
|
|
const Column::ObjectAccessor& objectAccessor)
|
|
{
|
|
table->AddColumn(prefix + "name", Column(&CommandsTable::NameAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "line", Column(&CommandsTable::LineAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "custom_variable_names", Column(&CommandsTable::CustomVariableNamesAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "custom_variable_values", Column(&CommandsTable::CustomVariableValuesAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "custom_variables", Column(&CommandsTable::CustomVariablesAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "modified_attributes", Column(&Table::ZeroAccessor, objectAccessor));
|
|
table->AddColumn(prefix + "modified_attributes_list", Column(&Table::ZeroAccessor, objectAccessor));
|
|
}
|
|
|
|
String CommandsTable::GetName() const
|
|
{
|
|
return "commands";
|
|
}
|
|
|
|
String CommandsTable::GetPrefix() const
|
|
{
|
|
return "command";
|
|
}
|
|
|
|
void CommandsTable::FetchRows(const AddRowFunction& addRowFn)
|
|
{
|
|
for (auto& object : ConfigType::GetObjectsByType<CheckCommand>()) {
|
|
if (!addRowFn(object, LivestatusGroupByNone, Empty))
|
|
return;
|
|
}
|
|
|
|
for (auto& object : ConfigType::GetObjectsByType<EventCommand>()) {
|
|
if (!addRowFn(object, LivestatusGroupByNone, Empty))
|
|
return;
|
|
}
|
|
|
|
for (auto& object : ConfigType::GetObjectsByType<NotificationCommand>()) {
|
|
if (!addRowFn(object, LivestatusGroupByNone, Empty))
|
|
return;
|
|
}
|
|
}
|
|
|
|
Value CommandsTable::NameAccessor(const Value& row)
|
|
{
|
|
Command::Ptr command = static_cast<Command::Ptr>(row);
|
|
|
|
return CompatUtility::GetCommandName(command);
|
|
}
|
|
|
|
Value CommandsTable::LineAccessor(const Value& row)
|
|
{
|
|
Command::Ptr command = static_cast<Command::Ptr>(row);
|
|
|
|
if (!command)
|
|
return Empty;
|
|
|
|
return CompatUtility::GetCommandLine(command);
|
|
}
|
|
|
|
Value CommandsTable::CustomVariableNamesAccessor(const Value& row)
|
|
{
|
|
Command::Ptr command = static_cast<Command::Ptr>(row);
|
|
|
|
if (!command)
|
|
return Empty;
|
|
|
|
Dictionary::Ptr vars = command->GetVars();
|
|
|
|
ArrayData keys;
|
|
|
|
if (vars) {
|
|
ObjectLock xlock(vars);
|
|
for (const auto& kv : vars) {
|
|
keys.push_back(kv.first);
|
|
}
|
|
}
|
|
|
|
return new Array(std::move(keys));
|
|
}
|
|
|
|
Value CommandsTable::CustomVariableValuesAccessor(const Value& row)
|
|
{
|
|
Command::Ptr command = static_cast<Command::Ptr>(row);
|
|
|
|
if (!command)
|
|
return Empty;
|
|
|
|
Dictionary::Ptr vars = command->GetVars();
|
|
|
|
ArrayData keys;
|
|
|
|
if (vars) {
|
|
ObjectLock xlock(vars);
|
|
for (const auto& kv : vars) {
|
|
keys.push_back(kv.second);
|
|
}
|
|
}
|
|
|
|
return new Array(std::move(keys));
|
|
}
|
|
|
|
Value CommandsTable::CustomVariablesAccessor(const Value& row)
|
|
{
|
|
Command::Ptr command = static_cast<Command::Ptr>(row);
|
|
|
|
if (!command)
|
|
return Empty;
|
|
|
|
Dictionary::Ptr vars = command->GetVars();
|
|
|
|
ArrayData result;
|
|
|
|
if (vars) {
|
|
ObjectLock xlock(vars);
|
|
for (const auto& kv : vars) {
|
|
result.push_back(new Array({
|
|
kv.first,
|
|
kv.second
|
|
}));
|
|
}
|
|
}
|
|
|
|
return new Array(std::move(result));
|
|
}
|