]> git.stg.codes - stg.git/blob - projects/stargazer/plugins/authorization/inetaccess/inetaccess.h
Unified build scripts.
[stg.git] / projects / stargazer / plugins / authorization / inetaccess / inetaccess.h
1 /*
2  *    This program is free software; you can redistribute it and/or modify
3  *    it under the terms of the GNU General Public License as published by
4  *    the Free Software Foundation; either version 2 of the License, or
5  *    (at your option) any later version.
6  *
7  *    This program is distributed in the hope that it will be useful,
8  *    but WITHOUT ANY WARRANTY; without even the implied warranty of
9  *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  *    GNU General Public License for more details.
11  *
12  *    You should have received a copy of the GNU General Public License
13  *    along with this program; if not, write to the Free Software
14  *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
15  */
16
17 /*
18  *    Author : Boris Mikhailenko <stg34@stargazer.dp.ua>
19  */
20
21 /*
22  $Revision: 1.34 $
23  $Date: 2010/09/10 06:39:19 $
24  $Author: faust $
25  */
26
27 #ifndef INETACCESS_H
28 #define INETACCESS_H
29
30 #include <sys/time.h>
31 #include <pthread.h>
32
33 #include <cstring>
34 #include <ctime>
35 #include <string>
36 #include <map>
37 #include <list>
38 #include <functional>
39 #include <utility>
40
41 #include "stg/os_int.h"
42 #include "stg/auth.h"
43 #include "stg/store.h"
44 #include "stg/notifer.h"
45 #include "stg/user_ips.h"
46 #include "stg/user.h"
47 #include "stg/users.h"
48 #include "stg/ia_packets.h"
49 #include "stg/blowfish.h"
50 #include "stg/logger.h"
51 #include "stg/utime.h"
52 #include "stg/logger.h"
53
54 extern "C" PLUGIN * GetPlugin();
55
56 #define IA_PROTO_VER    (6)
57
58 //#define IA_DEBUG (1)
59 //#define IA_PHASE_DEBUG (1)
60
61 class AUTH_IA;
62 //-----------------------------------------------------------------------------
63 enum FREEMB {
64     freeMb0 = 0,
65     freeMb1,
66     freeMb2,
67     freeMb3,
68     freeMb4,
69     freeMb5,
70     freeMb6,
71     freeMb7,
72     freeMb8,
73     freeMb9,
74     freeMb10,
75     freeMb11,
76     freeMb12,
77     freeMb13,
78     freeMb14,
79     freeMb15,
80     freeMb16,
81     freeMb17,
82     freeMb18,
83     freeMb19,
84     freeMbCash = 100,
85     freeMbNone = 101
86 };
87 //-----------------------------------------------------------------------------
88 class IA_PHASE {
89 public:
90     IA_PHASE();
91     ~IA_PHASE();
92
93     void    SetPhase1();
94     void    SetPhase2();
95     void    SetPhase3();
96     void    SetPhase4();
97     void    SetPhase5();
98     int     GetPhase() const;
99
100     void    UpdateTime();
101     const UTIME & GetTime() const;
102
103     #ifdef IA_PHASE_DEBUG
104     void    SetUserLogin(const std::string & login);
105     void    SetLogFileName(const std::string & logFileName);
106     #endif
107
108 private:
109     int             phase;
110     UTIME           phaseTime;
111
112     #ifdef IA_PHASE_DEBUG
113     void WritePhaseChange(int newPhase);
114     std::string log;
115     std::string login;
116     FILE * flog;
117     #endif
118 };
119 //-----------------------------------------------------------------------------
120 struct IA_USER {
121     IA_USER()
122         : login(),
123           user(NULL),
124           phase(),
125           lastSendAlive(0),
126           rnd(random()),
127           port(0),
128           ctx(),
129           messagesToSend(),
130           protoVer(0),
131           password("NO PASSWORD")
132     {
133     unsigned char keyL[PASSWD_LEN];
134     memset(keyL, 0, PASSWD_LEN);
135     strncpy((char *)keyL, password.c_str(), PASSWD_LEN);
136     Blowfish_Init(&ctx, keyL, PASSWD_LEN);
137
138     #ifdef IA_DEBUG
139     aliveSent = false;
140     #endif
141     };
142
143     IA_USER(const IA_USER & u)
144         : login(u.login),
145           user(u.user),
146           phase(u.phase),
147           lastSendAlive(u.lastSendAlive),
148           rnd(u.rnd),
149           port(u.port),
150           ctx(),
151           messagesToSend(u.messagesToSend),
152           protoVer(u.protoVer),
153           password(u.password)
154     {
155     #ifdef IA_DEBUG
156     aliveSent  = u.aliveSent;
157     #endif
158     memcpy(&ctx, &u.ctx, sizeof(BLOWFISH_CTX));
159     };
160
161     IA_USER(const std::string & l,
162             CONST_USER_PTR u,
163             uint16_t p,
164             int ver)
165         : login(l),
166           user(u),
167           phase(),
168           lastSendAlive(0),
169           rnd(random()),
170           port(p),
171           ctx(),
172           messagesToSend(),
173           protoVer(ver),
174           password(user->GetProperty().password.Get())
175     {
176     unsigned char keyL[PASSWD_LEN];
177     memset(keyL, 0, PASSWD_LEN);
178     strncpy((char *)keyL, password.c_str(), PASSWD_LEN);
179     Blowfish_Init(&ctx, keyL, PASSWD_LEN);
180
181     #ifdef IA_DEBUG
182     aliveSent = false;
183     #endif
184     }
185
186     std::string     login;
187     CONST_USER_PTR  user;
188     IA_PHASE        phase;
189     UTIME           lastSendAlive;
190     uint32_t        rnd;
191     uint16_t        port;
192     BLOWFISH_CTX    ctx;
193     std::list<STG_MSG> messagesToSend;
194     int             protoVer;
195     std::string     password;
196     #ifdef IA_DEBUG
197     bool            aliveSent;
198     #endif
199
200 private:
201     IA_USER & operator=(const IA_USER & rvalue);
202 };
203 //-----------------------------------------------------------------------------
204 class AUTH_IA_SETTINGS {
205 public:
206                     AUTH_IA_SETTINGS();
207     virtual         ~AUTH_IA_SETTINGS() {};
208     const std::string & GetStrError() const { return errorStr; };
209     int             ParseSettings(const MODULE_SETTINGS & s);
210     int             GetUserDelay() const { return userDelay; };
211     int             GetUserTimeout() const { return userTimeout; };
212     int             GetUserPort() const { return port; };
213     FREEMB          GetFreeMbShowType() const { return freeMbShowType; };
214
215 private:
216     int             userDelay;
217     int             userTimeout;
218     uint16_t        port;
219     std::string     errorStr;
220     FREEMB          freeMbShowType;
221 };
222 //-----------------------------------------------------------------------------
223 class AUTH_IA;
224 //-----------------------------------------------------------------------------
225 class DEL_USER_NOTIFIER: public NOTIFIER_BASE<USER_PTR> {
226 public:
227     DEL_USER_NOTIFIER(AUTH_IA & a) : auth(a) {}
228     virtual ~DEL_USER_NOTIFIER() {}
229
230     void Notify(const USER_PTR & user);
231 private:
232     DEL_USER_NOTIFIER(const DEL_USER_NOTIFIER & rvalue);
233     DEL_USER_NOTIFIER & operator=(const DEL_USER_NOTIFIER & rvalue);
234
235     AUTH_IA & auth;
236 };
237 //-----------------------------------------------------------------------------
238 class AUTH_IA :public AUTH {
239 friend class DEL_USER_NOTIFIER;
240 public:
241                         AUTH_IA();
242     virtual             ~AUTH_IA();
243
244     void                SetUsers(USERS * u) { users = u; }
245     void                SetStgSettings(const SETTINGS * s) { stgSettings = s; }
246     void                SetSettings(const MODULE_SETTINGS & s) { settings = s; }
247     int                 ParseSettings();
248
249     int                 Start();
250     int                 Stop();
251     int                 Reload() { return 0; }
252     bool                IsRunning() { return isRunningRunTimeouter || isRunningRun; }
253
254     const std::string & GetStrError() const { return errorStr; }
255     const std::string   GetVersion() const { return "InetAccess authorization plugin v.1.4"; }
256     uint16_t            GetStartPosition() const { return 30; }
257     uint16_t            GetStopPosition() const { return 30; }
258
259     int                 SendMessage(const STG_MSG & msg, uint32_t ip) const;
260
261 private:
262     AUTH_IA(const AUTH_IA & rvalue);
263     AUTH_IA & operator=(const AUTH_IA & rvalue);
264
265     static void *       Run(void *);
266     static void *       RunTimeouter(void * d);
267     int                 PrepareNet();
268     int                 FinalizeNet();
269     void                DelUser(USER_PTR u);
270     int                 RecvData(char * buffer, int bufferSize);
271     int                 CheckHeader(const char * buffer, int * protoVer);
272     int                 PacketProcessor(char * buff, int dataLen, uint32_t sip, uint16_t sport, int protoVer, USER_PTR user);
273
274     int                 Process_CONN_SYN_6(CONN_SYN_6 * connSyn, IA_USER * iaUser, uint32_t sip);
275     int                 Process_CONN_SYN_7(CONN_SYN_7 * connSyn, IA_USER * iaUser, uint32_t sip);
276     int                 Process_CONN_SYN_8(CONN_SYN_8 * connSyn, IA_USER * iaUser, uint32_t sip);
277
278     int                 Process_CONN_ACK_6(CONN_ACK_6 * connAck, IA_USER * iaUser, uint32_t sip);
279     int                 Process_CONN_ACK_7(CONN_ACK_7 * connAck, IA_USER * iaUser, uint32_t sip);
280     int                 Process_CONN_ACK_8(CONN_ACK_8 * connAck, IA_USER * iaUser, uint32_t sip);
281
282     int                 Process_ALIVE_ACK_6(ALIVE_ACK_6 * aliveAck, IA_USER * iaUser, uint32_t sip);
283     int                 Process_ALIVE_ACK_7(ALIVE_ACK_7 * aliveAck, IA_USER * iaUser, uint32_t sip);
284     int                 Process_ALIVE_ACK_8(ALIVE_ACK_8 * aliveAck, IA_USER * iaUser, uint32_t sip);
285
286     int                 Process_DISCONN_SYN_6(DISCONN_SYN_6 * disconnSyn, IA_USER * iaUser, uint32_t sip);
287     int                 Process_DISCONN_SYN_7(DISCONN_SYN_7 * disconnSyn, IA_USER * iaUser, uint32_t sip);
288     int                 Process_DISCONN_SYN_8(DISCONN_SYN_8 * disconnSyn, IA_USER * iaUser, uint32_t sip);
289
290     int                 Process_DISCONN_ACK_6(DISCONN_ACK_6 * disconnSyn,
291                                               IA_USER * iaUser,
292                                               uint32_t sip,
293                                               map<uint32_t, IA_USER>::iterator it);
294     int                 Process_DISCONN_ACK_7(DISCONN_ACK_7 * disconnSyn,
295                                               IA_USER * iaUser,
296                                               uint32_t sip,
297                                               map<uint32_t, IA_USER>::iterator it);
298     int                 Process_DISCONN_ACK_8(DISCONN_ACK_8 * disconnSyn,
299                                               IA_USER * iaUser,
300                                               uint32_t sip,
301                                               map<uint32_t, IA_USER>::iterator it);
302
303     int                 Send_CONN_SYN_ACK_6(IA_USER * iaUser, uint32_t sip);
304     int                 Send_CONN_SYN_ACK_7(IA_USER * iaUser, uint32_t sip);
305     int                 Send_CONN_SYN_ACK_8(IA_USER * iaUser, uint32_t sip);
306
307     int                 Send_ALIVE_SYN_6(IA_USER * iaUser, uint32_t sip);
308     int                 Send_ALIVE_SYN_7(IA_USER * iaUser, uint32_t sip);
309     int                 Send_ALIVE_SYN_8(IA_USER * iaUser, uint32_t sip);
310
311     int                 Send_DISCONN_SYN_ACK_6(IA_USER * iaUser, uint32_t sip);
312     int                 Send_DISCONN_SYN_ACK_7(IA_USER * iaUser, uint32_t sip);
313     int                 Send_DISCONN_SYN_ACK_8(IA_USER * iaUser, uint32_t sip);
314
315     int                 Send_FIN_6(IA_USER * iaUser, uint32_t sip, map<uint32_t, IA_USER>::iterator it);
316     int                 Send_FIN_7(IA_USER * iaUser, uint32_t sip, map<uint32_t, IA_USER>::iterator it);
317     int                 Send_FIN_8(IA_USER * iaUser, uint32_t sip, map<uint32_t, IA_USER>::iterator it);
318
319     int                 Timeouter();
320
321     int                 SendError(uint32_t ip, uint16_t port, int protoVer, const std::string & text);
322     int                 Send(uint32_t ip, uint16_t port, const char * buffer, int len);
323     int                 RealSendMessage6(const STG_MSG & msg, uint32_t ip, IA_USER & user);
324     int                 RealSendMessage7(const STG_MSG & msg, uint32_t ip, IA_USER & user);
325     int                 RealSendMessage8(const STG_MSG & msg, uint32_t ip, IA_USER & user);
326
327     BLOWFISH_CTX        ctxS;        //for loginS
328
329     mutable std::string errorStr;
330     AUTH_IA_SETTINGS    iaSettings;
331     MODULE_SETTINGS     settings;
332
333     bool                nonstop;
334
335     bool                isRunningRun;
336     bool                isRunningRunTimeouter;
337
338     USERS *             users;
339     const SETTINGS *    stgSettings;
340
341     mutable std::map<uint32_t, IA_USER> ip2user;
342
343     pthread_t           recvThread;
344     pthread_t           timeouterThread;
345     mutable pthread_mutex_t mutex;
346
347     int                 listenSocket;
348
349     CONN_SYN_ACK_6      connSynAck6;
350     CONN_SYN_ACK_8      connSynAck8;
351
352     DISCONN_SYN_ACK_6   disconnSynAck6;
353     DISCONN_SYN_ACK_8   disconnSynAck8;
354
355     ALIVE_SYN_6         aliveSyn6;
356     ALIVE_SYN_8         aliveSyn8;
357     FIN_6               fin6;
358     FIN_8               fin8;
359
360     std::map<std::string, int> packetTypes;
361
362     uint32_t            enabledDirs;
363
364     DEL_USER_NOTIFIER   onDelUserNotifier;
365
366     PLUGIN_LOGGER       logger;
367
368     friend class UnauthorizeUser;
369 };
370 //-----------------------------------------------------------------------------
371 class UnauthorizeUser : std::unary_function<const std::pair<uint32_t, IA_USER> &, void> {
372     public:
373         UnauthorizeUser(AUTH_IA * a) : auth(a) {}
374         UnauthorizeUser(const UnauthorizeUser & rvalue) : auth(rvalue.auth) {}
375         void operator()(const std::pair<uint32_t, IA_USER> & p)
376         {
377             auth->users->Unauthorize(p.second.user->GetLogin(), auth);
378         }
379     private:
380         UnauthorizeUser & operator=(const UnauthorizeUser & rvalue);
381
382         AUTH_IA * auth;
383 };
384 //-----------------------------------------------------------------------------
385 inline
386 void DEL_USER_NOTIFIER::Notify(const USER_PTR & user)
387 {
388     auth.DelUser(user);
389 }
390
391 #endif