2013-02-24 08:26:10 +01:00
|
|
|
/******************************************************************************
|
|
|
|
* Icinga 2 *
|
2013-09-25 07:43:57 +02:00
|
|
|
* Copyright (C) 2012-2013 Icinga Development Team (http://www.icinga.org/) *
|
2013-02-24 08:26:10 +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-03-17 20:19:29 +01:00
|
|
|
#include "icinga/user.h"
|
|
|
|
#include "icinga/usergroup.h"
|
2013-03-16 21:18:53 +01:00
|
|
|
#include "base/dynamictype.h"
|
2013-03-25 18:36:15 +01:00
|
|
|
#include "base/utility.h"
|
2013-09-09 13:52:37 +02:00
|
|
|
#include "base/objectlock.h"
|
2013-03-16 21:18:53 +01:00
|
|
|
#include <boost/smart_ptr/make_shared.hpp>
|
2013-02-24 08:26:10 +01:00
|
|
|
|
|
|
|
using namespace icinga;
|
|
|
|
|
2013-03-01 12:07:52 +01:00
|
|
|
REGISTER_TYPE(User);
|
2013-02-24 08:26:10 +01:00
|
|
|
|
2013-08-29 16:53:57 +02:00
|
|
|
void User::OnConfigLoaded(void)
|
2013-02-26 10:13:54 +01:00
|
|
|
{
|
2013-08-20 11:06:04 +02:00
|
|
|
Array::Ptr groups = GetGroups();
|
2013-02-27 21:49:03 +01:00
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
if (groups) {
|
2013-09-09 13:52:37 +02:00
|
|
|
ObjectLock olock(groups);
|
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
BOOST_FOREACH(const String& name, groups) {
|
|
|
|
UserGroup::Ptr ug = UserGroup::GetByName(name);
|
2013-03-02 09:07:47 +01:00
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
if (ug)
|
|
|
|
ug->AddMember(GetSelf());
|
|
|
|
}
|
|
|
|
}
|
2013-02-26 10:13:54 +01:00
|
|
|
}
|
2013-02-24 08:26:10 +01:00
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
void User::Stop(void)
|
2013-02-24 08:26:10 +01:00
|
|
|
{
|
2013-08-20 11:06:04 +02:00
|
|
|
DynamicObject::Stop();
|
|
|
|
|
|
|
|
Array::Ptr groups = GetGroups();
|
|
|
|
|
|
|
|
if (groups) {
|
2013-09-09 13:52:37 +02:00
|
|
|
ObjectLock olock(groups);
|
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
BOOST_FOREACH(const String& name, groups) {
|
|
|
|
UserGroup::Ptr ug = UserGroup::GetByName(name);
|
2013-02-24 08:26:10 +01:00
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
if (ug)
|
|
|
|
ug->RemoveMember(GetSelf());
|
|
|
|
}
|
|
|
|
}
|
2013-02-24 08:26:10 +01:00
|
|
|
}
|
|
|
|
|
2013-02-28 10:50:20 +01:00
|
|
|
String User::GetDisplayName(void) const
|
|
|
|
{
|
|
|
|
if (!m_DisplayName.IsEmpty())
|
|
|
|
return m_DisplayName;
|
|
|
|
else
|
|
|
|
return GetName();
|
|
|
|
}
|
|
|
|
|
2013-03-14 12:17:46 +01:00
|
|
|
Array::Ptr User::GetGroups(void) const
|
2013-02-27 21:49:03 +01:00
|
|
|
{
|
|
|
|
return m_Groups;
|
|
|
|
}
|
|
|
|
|
2013-02-24 08:26:10 +01:00
|
|
|
Dictionary::Ptr User::GetMacros(void) const
|
|
|
|
{
|
2013-02-26 10:13:54 +01:00
|
|
|
return m_Macros;
|
2013-02-24 08:26:10 +01:00
|
|
|
}
|
|
|
|
|
2013-07-16 13:17:10 +02:00
|
|
|
bool User::GetEnableNotifications(void) const
|
|
|
|
{
|
|
|
|
if (m_EnableNotifications.IsEmpty())
|
|
|
|
return true;
|
|
|
|
else
|
|
|
|
return m_EnableNotifications;
|
|
|
|
}
|
|
|
|
|
|
|
|
void User::SetEnableNotifications(bool enabled)
|
|
|
|
{
|
|
|
|
m_EnableNotifications = enabled;
|
|
|
|
}
|
|
|
|
|
2013-03-21 13:42:46 +01:00
|
|
|
TimePeriod::Ptr User::GetNotificationPeriod(void) const
|
|
|
|
{
|
|
|
|
return TimePeriod::GetByName(m_NotificationPeriod);
|
|
|
|
}
|
|
|
|
|
2013-06-26 09:50:04 +02:00
|
|
|
unsigned long User::GetNotificationTypeFilter(void) const
|
2013-06-26 09:08:50 +02:00
|
|
|
{
|
2013-06-26 09:50:04 +02:00
|
|
|
if (m_NotificationTypeFilter.IsEmpty())
|
2013-06-26 09:08:50 +02:00
|
|
|
return ~(unsigned long)0; /* All states. */
|
|
|
|
else
|
2013-06-26 09:50:04 +02:00
|
|
|
return m_NotificationTypeFilter;
|
2013-06-26 09:08:50 +02:00
|
|
|
}
|
|
|
|
|
2013-06-26 09:50:04 +02:00
|
|
|
unsigned long User::GetNotificationStateFilter(void) const
|
2013-06-26 09:08:50 +02:00
|
|
|
{
|
2013-06-26 09:50:04 +02:00
|
|
|
if (m_NotificationStateFilter.IsEmpty())
|
2013-06-26 09:08:50 +02:00
|
|
|
return ~(unsigned long)0; /* All states. */
|
|
|
|
else
|
2013-06-26 09:50:04 +02:00
|
|
|
return m_NotificationStateFilter;
|
2013-06-26 09:08:50 +02:00
|
|
|
}
|
|
|
|
|
2013-08-08 08:30:19 +02:00
|
|
|
void User::SetLastNotification(double ts)
|
|
|
|
{
|
|
|
|
m_LastNotification = ts;
|
|
|
|
}
|
|
|
|
|
|
|
|
double User::GetLastNotification(void) const
|
|
|
|
{
|
|
|
|
return m_LastNotification;
|
|
|
|
}
|
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
bool User::ResolveMacro(const String& macro, const Dictionary::Ptr&, String *result) const
|
2013-02-24 08:26:10 +01:00
|
|
|
{
|
2013-10-02 19:01:03 +02:00
|
|
|
if (macro == "USERNAME" || macro == "CONTACTNAME") {
|
2013-03-22 14:40:55 +01:00
|
|
|
*result = GetName();
|
|
|
|
return true;
|
2013-10-02 19:01:03 +02:00
|
|
|
} else if (macro == "USERDISPLAYNAME" || macro == "CONTACTALIAS") {
|
2013-07-02 09:54:24 +02:00
|
|
|
*result = GetDisplayName();
|
2013-03-22 14:40:55 +01:00
|
|
|
return true;
|
|
|
|
} else {
|
2013-08-30 15:16:25 +02:00
|
|
|
String tmacro;
|
|
|
|
|
2013-10-02 19:01:03 +02:00
|
|
|
if (macro == "USEREMAIL" || macro == "CONTACTEMAIL")
|
2013-08-30 15:16:25 +02:00
|
|
|
tmacro = "email";
|
2013-10-02 19:01:03 +02:00
|
|
|
else if (macro == "USERPAGER" || macro == "CONTACTPAGER")
|
2013-08-30 15:16:25 +02:00
|
|
|
tmacro = "pager";
|
|
|
|
else
|
|
|
|
tmacro = macro;
|
|
|
|
|
2013-03-22 14:40:55 +01:00
|
|
|
Dictionary::Ptr macros = GetMacros();
|
|
|
|
|
2013-08-30 15:16:25 +02:00
|
|
|
if (macros && macros->Contains(tmacro)) {
|
|
|
|
*result = macros->Get(tmacro);
|
2013-03-22 14:40:55 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2013-02-24 08:26:10 +01:00
|
|
|
}
|
2013-08-08 08:30:19 +02:00
|
|
|
|
2013-08-20 11:06:04 +02:00
|
|
|
void User::InternalSerialize(const Dictionary::Ptr& bag, int attributeTypes) const
|
|
|
|
{
|
|
|
|
DynamicObject::InternalSerialize(bag, attributeTypes);
|
|
|
|
|
|
|
|
if (attributeTypes & Attribute_Config) {
|
|
|
|
bag->Set("display_name", m_DisplayName);
|
|
|
|
bag->Set("macros", m_Macros);
|
|
|
|
bag->Set("groups", m_Groups);
|
|
|
|
bag->Set("notification_period", m_NotificationPeriod);
|
|
|
|
bag->Set("notification_type_filter", m_NotificationTypeFilter);
|
|
|
|
bag->Set("notification_state_filter", m_NotificationStateFilter);
|
|
|
|
}
|
|
|
|
|
2013-08-29 10:40:43 +02:00
|
|
|
if (attributeTypes & Attribute_State) {
|
|
|
|
bag->Set("enable_notifications", m_EnableNotifications);
|
|
|
|
bag->Set("last_notification", m_LastNotification);
|
|
|
|
}
|
2013-08-20 11:06:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void User::InternalDeserialize(const Dictionary::Ptr& bag, int attributeTypes)
|
|
|
|
{
|
|
|
|
DynamicObject::InternalDeserialize(bag, attributeTypes);
|
|
|
|
|
|
|
|
if (attributeTypes & Attribute_Config) {
|
|
|
|
m_DisplayName = bag->Get("display_name");
|
|
|
|
m_Macros = bag->Get("macros");
|
|
|
|
m_Groups = bag->Get("groups");
|
|
|
|
m_NotificationPeriod = bag->Get("notification_period");
|
|
|
|
m_NotificationTypeFilter = bag->Get("notification_type_filter");
|
|
|
|
m_NotificationStateFilter = bag->Get("notification_state_filter");
|
|
|
|
}
|
|
|
|
|
2013-08-29 10:40:43 +02:00
|
|
|
if (attributeTypes & Attribute_State) {
|
|
|
|
m_EnableNotifications = bag->Get("enable_notifications");
|
|
|
|
m_LastNotification = bag->Get("last_notification");
|
|
|
|
}
|
2013-08-20 11:06:04 +02:00
|
|
|
}
|