Refactoring: Changed all check parameters starting with a 'p' to the new rulespec...
[check_mk.git] / livestatus / src / ContactGroupsColumn.cc
blobc66e89892a5606cc930240e51398fe689faf5dd0
1 // +------------------------------------------------------------------+
2 // | ____ _ _ __ __ _ __ |
3 // | / ___| |__ ___ ___| | __ | \/ | |/ / |
4 // | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
5 // | | |___| | | | __/ (__| < | | | | . \ |
6 // | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
7 // | |
8 // | Copyright Mathias Kettner 2014 mk@mathias-kettner.de |
9 // +------------------------------------------------------------------+
11 // This file is part of Check_MK.
12 // The official homepage is at http://mathias-kettner.de/check_mk.
14 // check_mk is free software; you can redistribute it and/or modify it
15 // under the terms of the GNU General Public License as published by
16 // the Free Software Foundation in version 2. check_mk is distributed
17 // in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
18 // out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
19 // PARTICULAR PURPOSE. See the GNU General Public License for more de-
20 // tails. You should have received a copy of the GNU General Public
21 // License along with GNU Make; see the file COPYING. If not, write
22 // to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
23 // Boston, MA 02110-1301 USA.
25 #include "ContactGroupsColumn.h"
26 #include "Row.h"
28 #ifdef CMC
29 #include "ContactList.h"
30 #include "Object.h"
31 #include "cmc.h"
32 #else
33 #include "nagios.h"
34 #endif
36 std::vector<std::string> ContactGroupsColumn::getValue(
37 Row row, const contact * /*auth_user*/,
38 std::chrono::seconds /*timezone_offset*/) const {
39 std::vector<std::string> names;
40 #ifdef CMC
41 if (auto object = columnData<Object>(row)) {
42 for (const auto &name : object->_contact_list->groupNames()) {
43 names.push_back(name);
46 #else
47 if (auto p = columnData<contactgroupsmember *>(row)) {
48 for (auto cgm = *p; cgm != nullptr; cgm = cgm->next) {
49 names.emplace_back(cgm->group_ptr->group_name);
52 #endif
53 return names;