-/******************************************************************************
- * Icinga 2 *
- * Copyright (C) 2012-2015 Icinga Development Team (http://www.icinga.org) *
- * *
- * 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. *
- ******************************************************************************/
+/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
#include "livestatus/table.hpp"
#include "livestatus/statustable.hpp"
#include "livestatus/commentstable.hpp"
#include "livestatus/downtimestable.hpp"
#include "livestatus/endpointstable.hpp"
+#include "livestatus/zonestable.hpp"
#include "livestatus/timeperiodstable.hpp"
#include "livestatus/logtable.hpp"
#include "livestatus/statehisttable.hpp"
#include "base/array.hpp"
#include "base/dictionary.hpp"
#include <boost/algorithm/string/case_conv.hpp>
-#include <boost/tuple/tuple.hpp>
-#include <boost/foreach.hpp>
-#include <boost/bind.hpp>
using namespace icinga;
Table::Table(LivestatusGroupByType type)
- : m_GroupByType(type), m_GroupByObject(Empty)
+ : m_GroupByType(type), m_GroupByObject(Empty)
{ }
Table::Ptr Table::GetByName(const String& name, const String& compat_log_path, const unsigned long& from, const unsigned long& until)
return new StateHistTable(compat_log_path, from, until);
else if (name == "endpoints")
return new EndpointsTable();
+ else if (name == "zones")
+ return new ZonesTable();
- return Table::Ptr();
+ return nullptr;
}
void Table::AddColumn(const String& name, const Column& column)
{
std::pair<String, Column> item = std::make_pair(name, column);
- std::pair<std::map<String, Column>::iterator, bool> ret = m_Columns.insert(item);
+ auto ret = m_Columns.insert(item);
if (!ret.second)
ret.first->second = column;
if (dname.Find(prefix) == 0)
dname = dname.SubStr(prefix.GetLength());
- std::map<String, Column>::const_iterator it = m_Columns.find(dname);
+ auto it = m_Columns.find(dname);
if (it == m_Columns.end())
BOOST_THROW_EXCEPTION(std::invalid_argument("Column '" + dname + "' does not exist in table '" + GetName() + "'."));
return it->second;
}
-std::vector<String> Table::GetColumnNames(void) const
+std::vector<String> Table::GetColumnNames() const
{
std::vector<String> names;
- String name;
- BOOST_FOREACH(boost::tie(name, boost::tuples::ignore), m_Columns) {
- names.push_back(name);
+ for (const auto& kv : m_Columns) {
+ names.push_back(kv.first);
}
return names;
{
std::vector<LivestatusRowValue> rs;
- FetchRows(boost::bind(&Table::FilteredAddRow, this, boost::ref(rs), filter, limit, _1, _2, _3));
+ FetchRows(std::bind(&Table::FilteredAddRow, this, std::ref(rs), filter, limit, _1, _2, _3));
return rs;
}
bool Table::FilteredAddRow(std::vector<LivestatusRowValue>& rs, const Filter::Ptr& filter, int limit, const Value& row, LivestatusGroupByType groupByType, const Object::Ptr& groupByObject)
{
- if (limit != -1 && rs.size() == limit)
+ if (limit != -1 && static_cast<int>(rs.size()) == limit)
return false;
if (!filter || filter->Apply(this, row)) {
rval.GroupByType = groupByType;
rval.GroupByObject = groupByObject;
- rs.push_back(rval);
-
+ rs.emplace_back(std::move(rval));
}
return true;
return new Dictionary();
}
-LivestatusGroupByType Table::GetGroupByType(void) const
+LivestatusGroupByType Table::GetGroupByType() const
{
return m_GroupByType;
}