git.stg.codes
/
stg.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Hide or add proper copy ctor and assignement operator, initialize
[stg.git]
/
projects
/
stargazer
/
user_impl.h
diff --git
a/projects/stargazer/user_impl.h
b/projects/stargazer/user_impl.h
index 935dcd0e0a90368c8c0f897667df0f963af189bf..7aab735d41ddde04c2bc3242c949bf0e52ee360a 100644
(file)
--- a/
projects/stargazer/user_impl.h
+++ b/
projects/stargazer/user_impl.h
@@
-34,13
+34,13
@@
#include "stg/user.h"
#include "stg/os_int.h"
#include "stg/user.h"
#include "stg/os_int.h"
-#include "stg/
stg_
const.h"
+#include "stg/const.h"
#include "stg/user_stat.h"
#include "stg/user_conf.h"
#include "stg/user_ips.h"
#include "stg/user_property.h"
#include "stg/auth.h"
#include "stg/user_stat.h"
#include "stg/user_conf.h"
#include "stg/user_ips.h"
#include "stg/user_property.h"
#include "stg/auth.h"
-#include "stg/
stg_
message.h"
+#include "stg/message.h"
#include "stg/noncopyable.h"
//-----------------------------------------------------------------------------
#include "stg/noncopyable.h"
//-----------------------------------------------------------------------------
@@
-48,7
+48,11
@@
class TARIFF;
class TARIFFS;
class ADMIN;
class USER_IMPL;
class TARIFFS;
class ADMIN;
class USER_IMPL;
+#ifdef USE_ABSTRACT_SETTINGS
+class SETTINGS;
+#else
class SETTINGS_IMPL;
class SETTINGS_IMPL;
+#endif
//-----------------------------------------------------------------------------
class USER_ID_GENERATOR {
friend class USER_IMPL;
//-----------------------------------------------------------------------------
class USER_ID_GENERATOR {
friend class USER_IMPL;
@@
-87,11
+91,11
@@
private:
USER_IMPL * user;
};
//-----------------------------------------------------------------------------
USER_IMPL * user;
};
//-----------------------------------------------------------------------------
-class CHG_IP
_NOTIFIER : public PROPERTY_NOTIFIER_BASE<uint32_t
>,
- private NONCOPYABLE {
+class CHG_IP
S_NOTIFIER : public PROPERTY_NOTIFIER_BASE<USER_IPS
>,
+
private NONCOPYABLE {
public:
public:
- CHG_IP_NOTIFIER(USER_IMPL * u) : user(u) {}
- void Notify(const
uint32_t & oldCash, const uint32_t & newCash
);
+ CHG_IP
S
_NOTIFIER(USER_IMPL * u) : user(u) {}
+ void Notify(const
USER_IPS & oldIPs, const USER_IPS & newIPs
);
private:
USER_IMPL * user;
private:
USER_IMPL * user;
@@
-101,13
+105,21
@@
class USER_IMPL : public USER {
friend class CHG_PASSIVE_NOTIFIER;
friend class CHG_TARIFF_NOTIFIER;
friend class CHG_CASH_NOTIFIER;
friend class CHG_PASSIVE_NOTIFIER;
friend class CHG_TARIFF_NOTIFIER;
friend class CHG_CASH_NOTIFIER;
-friend class CHG_IP_NOTIFIER;
+friend class CHG_IP
S
_NOTIFIER;
public:
public:
+#ifdef USE_ABSTRACT_SETTINGS
+ USER_IMPL(const SETTINGS * settings,
+ const STORE * store,
+ const TARIFFS * tariffs,
+ const ADMIN * sysAdmin,
+ const USERS * u);
+#else
USER_IMPL(const SETTINGS_IMPL * settings,
const STORE * store,
const TARIFFS * tariffs,
const ADMIN * sysAdmin,
const USERS * u);
USER_IMPL(const SETTINGS_IMPL * settings,
const STORE * store,
const TARIFFS * tariffs,
const ADMIN * sysAdmin,
const USERS * u);
+#endif
USER_IMPL(const USER_IMPL & u);
virtual ~USER_IMPL();
USER_IMPL(const USER_IMPL & u);
virtual ~USER_IMPL();
@@
-117,7
+129,7
@@
public:
int WriteStat();
int WriteMonthStat();
int WriteStat();
int WriteMonthStat();
-
std::string const
& GetLogin() const { return login; }
+
const std::string
& GetLogin() const { return login; }
void SetLogin(std::string const & l);
uint32_t GetCurrIP() const { return currIP; }
void SetLogin(std::string const & l);
uint32_t GetCurrIP() const { return currIP; }
@@
-184,17
+196,18
@@
public:
void MidnightResetSessionStat();
void ProcessDayFee();
void MidnightResetSessionStat();
void ProcessDayFee();
- void SetPrepaidTraff();
void ProcessDayFeeSpread();
void ProcessNewMonth();
bool IsInetable();
void ProcessDayFeeSpread();
void ProcessNewMonth();
bool IsInetable();
- std::string
GetEnabledDirs();
+ std::string GetEnabledDirs();
void OnAdd();
void OnDelete();
private:
void OnAdd();
void OnDelete();
private:
+ USER_IMPL & operator=(const USER_IMPL & rvalue);
+
const USERS * users;
USER_PROPERTIES property;
STG_LOGGER & WriteServLog;
const USERS * users;
USER_PROPERTIES property;
STG_LOGGER & WriteServLog;
@@
-203,6
+216,8
@@
private:
void Disconnect(bool fakeDisconnect, const std::string & reason);
int SaveMonthStat(int month, int year);
void Disconnect(bool fakeDisconnect, const std::string & reason);
int SaveMonthStat(int month, int year);
+ void SetPrepaidTraff();
+
int SendMessage(STG_MSG & msg) const;
void ScanMessage();
int SendMessage(STG_MSG & msg) const;
void ScanMessage();
@@
-233,7
+248,11
@@
private:
TRAFF_STAT traffStat;
std::pair<time_t, TRAFF_STAT> traffStatSaved;
TRAFF_STAT traffStat;
std::pair<time_t, TRAFF_STAT> traffStatSaved;
+#ifdef USE_ABSTRACT_SETTINGS
+ const SETTINGS * settings;
+#else
const SETTINGS_IMPL * settings;
const SETTINGS_IMPL * settings;
+#endif
std::set<const AUTH *> authorizedBy;
std::set<const AUTH *> authorizedBy;
@@
-288,7
+307,7
@@
private:
CHG_PASSIVE_NOTIFIER passiveNotifier;
CHG_TARIFF_NOTIFIER tariffNotifier;
CHG_CASH_NOTIFIER cashNotifier;
CHG_PASSIVE_NOTIFIER passiveNotifier;
CHG_TARIFF_NOTIFIER tariffNotifier;
CHG_CASH_NOTIFIER cashNotifier;
- CHG_IP
_NOTIFIER
ipNotifier;
+ CHG_IP
S_NOTIFIER
ipNotifier;
mutable pthread_mutex_t mutex;
mutable pthread_mutex_t mutex;
@@
-296,4
+315,6
@@
private:
};
//-----------------------------------------------------------------------------
};
//-----------------------------------------------------------------------------
+typedef USER_IMPL * USER_IMPL_PTR;
+
#endif //USER_H
#endif //USER_H