]> git.stg.codes - stg.git/blobdiff - stargazer/plugins/authorization/inetaccess/inetaccess.h
Port to CMake, get rid of os_int.h.
[stg.git] / stargazer / plugins / authorization / inetaccess / inetaccess.h
diff --git a/stargazer/plugins/authorization/inetaccess/inetaccess.h b/stargazer/plugins/authorization/inetaccess/inetaccess.h
new file mode 100644 (file)
index 0000000..73c435a
--- /dev/null
@@ -0,0 +1,390 @@
+/*
+ *    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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+/*
+ *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
+ */
+
+/*
+ $Revision: 1.34 $
+ $Date: 2010/09/10 06:39:19 $
+ $Author: faust $
+ */
+
+#ifndef INETACCESS_H
+#define INETACCESS_H
+
+#include "stg/auth.h"
+#include "stg/store.h"
+#include "stg/notifer.h"
+#include "stg/user_ips.h"
+#include "stg/user.h"
+#include "stg/users.h"
+#include "stg/ia_packets.h"
+#include "stg/blowfish.h"
+#include "stg/logger.h"
+#include "stg/utime.h"
+#include "stg/logger.h"
+
+#include <cstring>
+#include <ctime>
+#include <cstdint>
+#include <string>
+#include <map>
+#include <list>
+#include <functional>
+#include <utility>
+
+#include <sys/time.h>
+#include <pthread.h>
+
+#define IA_PROTO_VER    (6)
+
+//#define IA_DEBUG (1)
+//#define IA_PHASE_DEBUG (1)
+
+class AUTH_IA;
+//-----------------------------------------------------------------------------
+enum FREEMB {
+    freeMb0 = 0,
+    freeMb1,
+    freeMb2,
+    freeMb3,
+    freeMb4,
+    freeMb5,
+    freeMb6,
+    freeMb7,
+    freeMb8,
+    freeMb9,
+    freeMb10,
+    freeMb11,
+    freeMb12,
+    freeMb13,
+    freeMb14,
+    freeMb15,
+    freeMb16,
+    freeMb17,
+    freeMb18,
+    freeMb19,
+    freeMbCash = 100,
+    freeMbNone = 101
+};
+//-----------------------------------------------------------------------------
+class IA_PHASE {
+public:
+    IA_PHASE();
+    ~IA_PHASE();
+
+    void    SetPhase1();
+    void    SetPhase2();
+    void    SetPhase3();
+    void    SetPhase4();
+    int     GetPhase() const;
+
+    void    UpdateTime();
+    const UTIME & GetTime() const;
+
+    #ifdef IA_PHASE_DEBUG
+    void    SetUserLogin(const std::string & login);
+    void    SetLogFileName(const std::string & logFileName);
+    #endif
+
+private:
+    int             phase;
+    UTIME           phaseTime;
+
+    #ifdef IA_PHASE_DEBUG
+    void WritePhaseChange(int newPhase);
+    std::string log;
+    std::string login;
+    FILE * flog;
+    #endif
+};
+//-----------------------------------------------------------------------------
+struct IA_USER {
+    IA_USER()
+        : login(),
+          user(NULL),
+          phase(),
+          lastSendAlive(0),
+          rnd(static_cast<uint32_t>(random())),
+          port(0),
+          ctx(),
+          messagesToSend(),
+          protoVer(0),
+          password("NO PASSWORD")
+    {
+    unsigned char keyL[PASSWD_LEN];
+    memset(keyL, 0, PASSWD_LEN);
+    strncpy((char *)keyL, password.c_str(), PASSWD_LEN);
+    Blowfish_Init(&ctx, keyL, PASSWD_LEN);
+
+    #ifdef IA_DEBUG
+    aliveSent = false;
+    #endif
+    }
+
+    IA_USER(const IA_USER & u)
+        : login(u.login),
+          user(u.user),
+          phase(u.phase),
+          lastSendAlive(u.lastSendAlive),
+          rnd(u.rnd),
+          port(u.port),
+          ctx(),
+          messagesToSend(u.messagesToSend),
+          protoVer(u.protoVer),
+          password(u.password)
+    {
+    #ifdef IA_DEBUG
+    aliveSent  = u.aliveSent;
+    #endif
+    memcpy(&ctx, &u.ctx, sizeof(BLOWFISH_CTX));
+    }
+
+    IA_USER(const std::string & l,
+            CONST_USER_PTR u,
+            uint16_t p,
+            int ver)
+        : login(l),
+          user(u),
+          phase(),
+          lastSendAlive(0),
+          rnd(static_cast<uint32_t>(random())),
+          port(p),
+          ctx(),
+          messagesToSend(),
+          protoVer(ver),
+          password(user->GetProperty().password.Get())
+    {
+    unsigned char keyL[PASSWD_LEN];
+    memset(keyL, 0, PASSWD_LEN);
+    strncpy((char *)keyL, password.c_str(), PASSWD_LEN);
+    Blowfish_Init(&ctx, keyL, PASSWD_LEN);
+
+    #ifdef IA_DEBUG
+    aliveSent = false;
+    #endif
+    }
+
+    std::string     login;
+    CONST_USER_PTR  user;
+    IA_PHASE        phase;
+    UTIME           lastSendAlive;
+    uint32_t        rnd;
+    uint16_t        port;
+    BLOWFISH_CTX    ctx;
+    std::list<STG_MSG> messagesToSend;
+    int             protoVer;
+    std::string     password;
+    #ifdef IA_DEBUG
+    bool            aliveSent;
+    #endif
+
+private:
+    IA_USER & operator=(const IA_USER & rvalue);
+};
+//-----------------------------------------------------------------------------
+class AUTH_IA_SETTINGS {
+public:
+                    AUTH_IA_SETTINGS();
+    virtual         ~AUTH_IA_SETTINGS() {}
+    const std::string & GetStrError() const { return errorStr; }
+    int             ParseSettings(const MODULE_SETTINGS & s);
+    UTIME           GetUserDelay() const { return UTIME(userDelay); }
+    UTIME           GetUserTimeout() const { return UTIME(userTimeout); }
+    uint16_t        GetUserPort() const { return port; }
+    FREEMB          GetFreeMbShowType() const { return freeMbShowType; }
+    bool            LogProtocolErrors() const { return logProtocolErrors; }
+
+private:
+    int             userDelay;
+    int             userTimeout;
+    uint16_t        port;
+    std::string     errorStr;
+    FREEMB          freeMbShowType;
+    bool            logProtocolErrors;
+};
+//-----------------------------------------------------------------------------
+class AUTH_IA;
+//-----------------------------------------------------------------------------
+class DEL_USER_NOTIFIER: public NOTIFIER_BASE<USER_PTR> {
+public:
+    explicit DEL_USER_NOTIFIER(AUTH_IA & a) : auth(a) {}
+    virtual ~DEL_USER_NOTIFIER() {}
+
+    void Notify(const USER_PTR & user);
+private:
+    DEL_USER_NOTIFIER(const DEL_USER_NOTIFIER & rvalue);
+    DEL_USER_NOTIFIER & operator=(const DEL_USER_NOTIFIER & rvalue);
+
+    AUTH_IA & auth;
+};
+//-----------------------------------------------------------------------------
+class AUTH_IA :public AUTH {
+friend class DEL_USER_NOTIFIER;
+public:
+                        AUTH_IA();
+    virtual             ~AUTH_IA();
+
+    void                SetUsers(USERS * u) { users = u; }
+    void                SetStgSettings(const SETTINGS * s) { stgSettings = s; }
+    void                SetSettings(const MODULE_SETTINGS & s) { settings = s; }
+    int                 ParseSettings();
+
+    int                 Start();
+    int                 Stop();
+    int                 Reload(const MODULE_SETTINGS & ms);
+    bool                IsRunning() { return isRunningRunTimeouter || isRunningRun; }
+
+    const std::string & GetStrError() const { return errorStr; }
+    std::string         GetVersion() const { return "InetAccess authorization plugin v.1.4"; }
+    uint16_t            GetStartPosition() const { return 30; }
+    uint16_t            GetStopPosition() const { return 30; }
+
+    int                 SendMessage(const STG_MSG & msg, uint32_t ip) const;
+
+private:
+    AUTH_IA(const AUTH_IA & rvalue);
+    AUTH_IA & operator=(const AUTH_IA & rvalue);
+
+    static void *       Run(void *);
+    static void *       RunTimeouter(void * d);
+    int                 PrepareNet();
+    int                 FinalizeNet();
+    void                DelUser(USER_PTR u);
+    int                 RecvData(char * buffer, int bufferSize);
+    int                 CheckHeader(const char * buffer, uint32_t sip, int * protoVer);
+    int                 PacketProcessor(void * buff, size_t dataLen, uint32_t sip, uint16_t sport, int protoVer, USER_PTR user);
+
+    int                 Process_CONN_SYN_6(CONN_SYN_6 * connSyn, IA_USER * iaUser, uint32_t sip);
+    int                 Process_CONN_SYN_7(CONN_SYN_7 * connSyn, IA_USER * iaUser, uint32_t sip);
+    int                 Process_CONN_SYN_8(CONN_SYN_8 * connSyn, IA_USER * iaUser, uint32_t sip);
+
+    int                 Process_CONN_ACK_6(CONN_ACK_6 * connAck, IA_USER * iaUser, uint32_t sip);
+    int                 Process_CONN_ACK_7(CONN_ACK_7 * connAck, IA_USER * iaUser, uint32_t sip);
+    int                 Process_CONN_ACK_8(CONN_ACK_8 * connAck, IA_USER * iaUser, uint32_t sip);
+
+    int                 Process_ALIVE_ACK_6(ALIVE_ACK_6 * aliveAck, IA_USER * iaUser, uint32_t sip);
+    int                 Process_ALIVE_ACK_7(ALIVE_ACK_7 * aliveAck, IA_USER * iaUser, uint32_t sip);
+    int                 Process_ALIVE_ACK_8(ALIVE_ACK_8 * aliveAck, IA_USER * iaUser, uint32_t sip);
+
+    int                 Process_DISCONN_SYN_6(DISCONN_SYN_6 * disconnSyn, IA_USER * iaUser, uint32_t sip);
+    int                 Process_DISCONN_SYN_7(DISCONN_SYN_7 * disconnSyn, IA_USER * iaUser, uint32_t sip);
+    int                 Process_DISCONN_SYN_8(DISCONN_SYN_8 * disconnSyn, IA_USER * iaUser, uint32_t sip);
+
+    int                 Process_DISCONN_ACK_6(DISCONN_ACK_6 * disconnSyn,
+                                              IA_USER * iaUser,
+                                              uint32_t sip,
+                                              std::map<uint32_t, IA_USER>::iterator it);
+    int                 Process_DISCONN_ACK_7(DISCONN_ACK_7 * disconnSyn,
+                                              IA_USER * iaUser,
+                                              uint32_t sip,
+                                              std::map<uint32_t, IA_USER>::iterator it);
+    int                 Process_DISCONN_ACK_8(DISCONN_ACK_8 * disconnSyn,
+                                              IA_USER * iaUser,
+                                              uint32_t sip,
+                                              std::map<uint32_t, IA_USER>::iterator it);
+
+    int                 Send_CONN_SYN_ACK_6(IA_USER * iaUser, uint32_t sip);
+    int                 Send_CONN_SYN_ACK_7(IA_USER * iaUser, uint32_t sip);
+    int                 Send_CONN_SYN_ACK_8(IA_USER * iaUser, uint32_t sip);
+
+    int                 Send_ALIVE_SYN_6(IA_USER * iaUser, uint32_t sip);
+    int                 Send_ALIVE_SYN_7(IA_USER * iaUser, uint32_t sip);
+    int                 Send_ALIVE_SYN_8(IA_USER * iaUser, uint32_t sip);
+
+    int                 Send_DISCONN_SYN_ACK_6(IA_USER * iaUser, uint32_t sip);
+    int                 Send_DISCONN_SYN_ACK_7(IA_USER * iaUser, uint32_t sip);
+    int                 Send_DISCONN_SYN_ACK_8(IA_USER * iaUser, uint32_t sip);
+
+    int                 Send_FIN_6(IA_USER * iaUser, uint32_t sip, std::map<uint32_t, IA_USER>::iterator it);
+    int                 Send_FIN_7(IA_USER * iaUser, uint32_t sip, std::map<uint32_t, IA_USER>::iterator it);
+    int                 Send_FIN_8(IA_USER * iaUser, uint32_t sip, std::map<uint32_t, IA_USER>::iterator it);
+
+    int                 Timeouter();
+
+    int                 SendError(uint32_t ip, uint16_t port, int protoVer, const std::string & text);
+    int                 Send(uint32_t ip, uint16_t port, const char * buffer, size_t len);
+    int                 RealSendMessage6(const STG_MSG & msg, uint32_t ip, IA_USER & user);
+    int                 RealSendMessage7(const STG_MSG & msg, uint32_t ip, IA_USER & user);
+    int                 RealSendMessage8(const STG_MSG & msg, uint32_t ip, IA_USER & user);
+
+    BLOWFISH_CTX        ctxS;        //for loginS
+
+    mutable std::string errorStr;
+    AUTH_IA_SETTINGS    iaSettings;
+    MODULE_SETTINGS     settings;
+
+    bool                nonstop;
+
+    bool                isRunningRun;
+    bool                isRunningRunTimeouter;
+
+    USERS *             users;
+    const SETTINGS *    stgSettings;
+
+    mutable std::map<uint32_t, IA_USER> ip2user;
+
+    pthread_t           recvThread;
+    pthread_t           timeouterThread;
+    mutable pthread_mutex_t mutex;
+
+    int                 listenSocket;
+
+    CONN_SYN_ACK_6      connSynAck6;
+    CONN_SYN_ACK_8      connSynAck8;
+
+    DISCONN_SYN_ACK_6   disconnSynAck6;
+    DISCONN_SYN_ACK_8   disconnSynAck8;
+
+    ALIVE_SYN_6         aliveSyn6;
+    ALIVE_SYN_8         aliveSyn8;
+    FIN_6               fin6;
+    FIN_8               fin8;
+
+    std::map<std::string, int> packetTypes;
+
+    uint32_t            enabledDirs;
+
+    DEL_USER_NOTIFIER   onDelUserNotifier;
+
+    PLUGIN_LOGGER       logger;
+
+    friend class UnauthorizeUser;
+};
+//-----------------------------------------------------------------------------
+class UnauthorizeUser : std::unary_function<const std::pair<uint32_t, IA_USER> &, void> {
+    public:
+        explicit UnauthorizeUser(AUTH_IA * a) : auth(a) {}
+        UnauthorizeUser(const UnauthorizeUser & rvalue) : auth(rvalue.auth) {}
+        void operator()(const std::pair<uint32_t, IA_USER> & p)
+        {
+            auth->users->Unauthorize(p.second.user->GetLogin(), auth);
+        }
+    private:
+        UnauthorizeUser & operator=(const UnauthorizeUser & rvalue);
+
+        AUTH_IA * auth;
+};
+//-----------------------------------------------------------------------------
+inline
+void DEL_USER_NOTIFIER::Notify(const USER_PTR & user)
+{
+    auth.DelUser(user);
+}
+
+#endif