#include <set>
#include <sstream>
#include <iostream>
-#include <algorithm>
#include "store.h"
-#include "stg_logger.h"
#include "admin.h"
-#include "settings.h"
#include "notifer.h"
#include "stg_logger.h"
#include "stg_locker.h"
private:
varT & value;
time_t modificationTime;
- set<PROPERTY_NOTIFIER_BASE<varT> *> beforeNotifiers;
- set<PROPERTY_NOTIFIER_BASE<varT> *> afterNotifiers;
+ std::set<PROPERTY_NOTIFIER_BASE<varT> *> beforeNotifiers;
+ std::set<PROPERTY_NOTIFIER_BASE<varT> *> afterNotifiers;
mutable pthread_mutex_t mutex;
};
//-----------------------------------------------------------------------------
class USER_PROPERTY_LOGGED: public USER_PROPERTY<varT> {
public:
USER_PROPERTY_LOGGED(varT & val,
- const string n,
+ const std::string n,
bool isPassword,
bool isStat,
STG_LOGGER & logger,
- const SETTINGS * s);
+ const std::string & sd);
virtual ~USER_PROPERTY_LOGGED();
USER_PROPERTY_LOGGED<varT> * GetPointer() throw();
const varT & Get() const;
- const string & GetName() const;
+ const std::string & GetName() const;
bool Set(const varT & val,
- const ADMIN & admin,
- const string & login,
+ const ADMIN * admin,
+ const std::string & login,
const STORE * store,
- const string & msg = "");
+ const std::string & msg = "");
private:
- void WriteAccessDenied(const string & login,
- const ADMIN & admin,
- const string & parameter);
-
- void WriteSuccessChange(const string & login,
- const ADMIN & admin,
- const string & parameter,
- const string & oldValue,
- const string & newValue,
- const string & msg,
+ void WriteAccessDenied(const std::string & login,
+ const ADMIN * admin,
+ const std::string & parameter);
+
+ void WriteSuccessChange(const std::string & login,
+ const ADMIN * admin,
+ const std::string & parameter,
+ const std::string & oldValue,
+ const std::string & newValue,
+ const std::string & msg,
const STORE * store);
- void OnChange(const string & login,
- const string & paramName,
- const string & oldValue,
- const string & newValue,
- const ADMIN & admin);
-
- string name; // parameter name. needed for logging
- bool isPassword; // is parameter password. when true, it will be logged as *******
- bool isStat; // is parameter a stat data or conf data?
- mutable pthread_mutex_t mutex;
- STG_LOGGER & stgLogger; // server's logger
- const SETTINGS * settings;
+ void OnChange(const std::string & login,
+ const std::string & paramName,
+ const std::string & oldValue,
+ const std::string & newValue,
+ const ADMIN * admin);
+
+ STG_LOGGER & stgLogger;
+ bool isPassword;
+ bool isStat;
+ std::string name;
+ const std::string scriptsDir;
};
//-----------------------------------------------------------------------------
class USER_PROPERTIES {
USER_CONF conf;
public:
- USER_PROPERTIES(const SETTINGS * settings);
+ USER_PROPERTIES(const std::string & sd);
USER_STAT & Stat() { return stat; }
USER_CONF & Conf() { return conf; }
USER_PROPERTY_LOGGED<double> freeMb;
USER_PROPERTY_LOGGED<time_t> lastActivityTime;
- USER_PROPERTY_LOGGED<string> password;
+ USER_PROPERTY_LOGGED<std::string> password;
USER_PROPERTY_LOGGED<int> passive;
USER_PROPERTY_LOGGED<int> disabled;
USER_PROPERTY_LOGGED<int> disabledDetailStat;
USER_PROPERTY_LOGGED<int> alwaysOnline;
- USER_PROPERTY_LOGGED<string> tariffName;
- USER_PROPERTY_LOGGED<string> nextTariff;
- USER_PROPERTY_LOGGED<string> address;
- USER_PROPERTY_LOGGED<string> note;
- USER_PROPERTY_LOGGED<string> group;
- USER_PROPERTY_LOGGED<string> email;
- USER_PROPERTY_LOGGED<string> phone;
- USER_PROPERTY_LOGGED<string> realName;
+ USER_PROPERTY_LOGGED<std::string> tariffName;
+ USER_PROPERTY_LOGGED<std::string> nextTariff;
+ USER_PROPERTY_LOGGED<std::string> address;
+ USER_PROPERTY_LOGGED<std::string> note;
+ USER_PROPERTY_LOGGED<std::string> group;
+ USER_PROPERTY_LOGGED<std::string> email;
+ USER_PROPERTY_LOGGED<std::string> phone;
+ USER_PROPERTY_LOGGED<std::string> realName;
USER_PROPERTY_LOGGED<double> credit;
USER_PROPERTY_LOGGED<time_t> creditExpire;
USER_PROPERTY_LOGGED<USER_IPS> ips;
- USER_PROPERTY_LOGGED<string> userdata0;
- USER_PROPERTY_LOGGED<string> userdata1;
- USER_PROPERTY_LOGGED<string> userdata2;
- USER_PROPERTY_LOGGED<string> userdata3;
- USER_PROPERTY_LOGGED<string> userdata4;
- USER_PROPERTY_LOGGED<string> userdata5;
- USER_PROPERTY_LOGGED<string> userdata6;
- USER_PROPERTY_LOGGED<string> userdata7;
- USER_PROPERTY_LOGGED<string> userdata8;
- USER_PROPERTY_LOGGED<string> userdata9;
+ USER_PROPERTY_LOGGED<std::string> userdata0;
+ USER_PROPERTY_LOGGED<std::string> userdata1;
+ USER_PROPERTY_LOGGED<std::string> userdata2;
+ USER_PROPERTY_LOGGED<std::string> userdata3;
+ USER_PROPERTY_LOGGED<std::string> userdata4;
+ USER_PROPERTY_LOGGED<std::string> userdata5;
+ USER_PROPERTY_LOGGED<std::string> userdata6;
+ USER_PROPERTY_LOGGED<std::string> userdata7;
+ USER_PROPERTY_LOGGED<std::string> userdata8;
+ USER_PROPERTY_LOGGED<std::string> userdata9;
};
//=============================================================================
template <typename varT>
void USER_PROPERTY<varT>::ModifyTime() throw()
{
- modificationTime = stgTime;
+modificationTime = stgTime;
}
//-----------------------------------------------------------------------------
template <typename varT>
{
STG_LOCKER locker(&mutex, __FILE__, __LINE__);
-typename set<PROPERTY_NOTIFIER_BASE<varT> *>::iterator ni;
+typename std::set<PROPERTY_NOTIFIER_BASE<varT> *>::iterator ni;
varT oldVal = value;
//-----------------------------------------------------------------------------
template <typename varT>
USER_PROPERTY_LOGGED<varT>::USER_PROPERTY_LOGGED(varT& val,
- string n,
+ std::string n,
bool isPass,
bool isSt,
STG_LOGGER & logger,
- const SETTINGS * s)
+ const std::string & sd)
: USER_PROPERTY<varT>(val),
- stgLogger(logger)
+ stgLogger(logger),
+ isPassword(isPass),
+ isStat(isSt),
+ name(n),
+ scriptsDir(sd)
{
-pthread_mutex_init(&mutex, NULL);
-STG_LOCKER locker(&mutex, __FILE__, __LINE__);
-isPassword = isPass;
-isStat = isSt;
-name = n;
-settings = s;
}
//-----------------------------------------------------------------------------
template <typename varT>
};
//-------------------------------------------------------------------------
template <typename varT>
-const string & USER_PROPERTY_LOGGED<varT>::GetName() const
+const std::string & USER_PROPERTY_LOGGED<varT>::GetName() const
{
return name;
};
//-------------------------------------------------------------------------
template <typename varT>
bool USER_PROPERTY_LOGGED<varT>::Set(const varT & val,
- const ADMIN & admin,
- const string & login,
+ const ADMIN * admin,
+ const std::string & login,
const STORE * store,
- const string & msg)
+ const std::string & msg)
{
-STG_LOCKER locker(&mutex, __FILE__, __LINE__);
-
-//cout << "USER_PROPERTY_LOGGED " << val << endl;
-//value = val;
-//modificationTime = stgTime;
-
-const PRIV * priv = admin.GetPriv();
-string adm_login = admin.GetLogin();
-string adm_ip = admin.GetIPStr();
+const PRIV * priv = admin->GetPriv();
+std::string adm_login = admin->GetLogin();
+std::string adm_ip = admin->GetIPStr();
if ((priv->userConf && !isStat) || (priv->userStat && isStat) || (priv->userPasswd && isPassword) || (priv->userCash && name == "cash"))
{
}
//-------------------------------------------------------------------------
template <typename varT>
-void USER_PROPERTY_LOGGED<varT>::WriteAccessDenied(const string & login,
- const ADMIN & admin,
- const string & parameter)
+void USER_PROPERTY_LOGGED<varT>::WriteAccessDenied(const std::string & login,
+ const ADMIN * admin,
+ const std::string & parameter)
{
stgLogger("%s Change user \'%s.\' Parameter \'%s\'. Access denied.",
- admin.GetLogStr().c_str(), login.c_str(), parameter.c_str());
+ admin->GetLogStr().c_str(), login.c_str(), parameter.c_str());
}
//-------------------------------------------------------------------------
template <typename varT>
-void USER_PROPERTY_LOGGED<varT>::WriteSuccessChange(const string & login,
- const ADMIN & admin,
- const string & parameter,
- const string & oldValue,
- const string & newValue,
- const string & msg,
+void USER_PROPERTY_LOGGED<varT>::WriteSuccessChange(const std::string & login,
+ const ADMIN * admin,
+ const std::string & parameter,
+ const std::string & oldValue,
+ const std::string & newValue,
+ const std::string & msg,
const STORE * store)
{
stgLogger("%s User \'%s\': \'%s\' parameter changed from \'%s\' to \'%s\'. %s",
- admin.GetLogStr().c_str(),
+ admin->GetLogStr().c_str(),
login.c_str(),
parameter.c_str(),
oldValue.c_str(),
newValue.c_str(),
msg.c_str());
-store->WriteUserChgLog(login, admin.GetLogin(), admin.GetIP(), parameter, oldValue, newValue, msg);
+store->WriteUserChgLog(login, admin->GetLogin(), admin->GetIP(), parameter, oldValue, newValue, msg);
}
//-------------------------------------------------------------------------
template <typename varT>
-void USER_PROPERTY_LOGGED<varT>::OnChange(const string & login,
- const string & paramName,
- const string & oldValue,
- const string & newValue,
- const ADMIN & admin)
+void USER_PROPERTY_LOGGED<varT>::OnChange(const std::string & login,
+ const std::string & paramName,
+ const std::string & oldValue,
+ const std::string & newValue,
+ const ADMIN * admin)
{
-string str1;
+std::string str1;
-str1 = settings->GetConfDir() + "/OnChange";
+str1 = scriptsDir + "/OnChange";
if (access(str1.c_str(), X_OK) == 0)
{
- string str2("\"" + str1 + "\" \"" + login + "\" \"" + paramName + "\" \"" + oldValue + "\" \"" + newValue + "\" \"" + admin.GetLogin() + "\" \"" + admin.GetIPStr() + "\"");
+ std::string str2("\"" + str1 + "\" \"" + login + "\" \"" + paramName + "\" \"" + oldValue + "\" \"" + newValue + "\" \"" + admin->GetLogin() + "\" \"" + admin->GetIPStr() + "\"");
ScriptExec(str2);
}
else
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
//-------------------------------------------------------------------------
-/*template<typename varT>
-stringstream & operator<< (stringstream & s, const USER_PROPERTY<varT> & v)
-{
-s << v.ConstData();
-return s;
-}*/
-//-----------------------------------------------------------------------------
template<typename varT>
ostream & operator<< (ostream & stream, const USER_PROPERTY<varT> & value)
{