summaryrefslogtreecommitdiffstats
path: root/src/Authenticator.h
diff options
context:
space:
mode:
authordaniel0916 <theschokolps@gmail.com>2014-04-13 13:04:56 +0200
committerdaniel0916 <theschokolps@gmail.com>2014-04-13 13:04:56 +0200
commitb506a7407661c0527255466cf8b315824b0003c0 (patch)
treec1a08a8c495fdd9e25fbcabbc5c072efb5470798 /src/Authenticator.h
parentUpdated the NetherFort prefabs to current Gallery contents. (diff)
downloadcuberite-b506a7407661c0527255466cf8b315824b0003c0.tar
cuberite-b506a7407661c0527255466cf8b315824b0003c0.tar.gz
cuberite-b506a7407661c0527255466cf8b315824b0003c0.tar.bz2
cuberite-b506a7407661c0527255466cf8b315824b0003c0.tar.lz
cuberite-b506a7407661c0527255466cf8b315824b0003c0.tar.xz
cuberite-b506a7407661c0527255466cf8b315824b0003c0.tar.zst
cuberite-b506a7407661c0527255466cf8b315824b0003c0.zip
Diffstat (limited to 'src/Authenticator.h')
-rw-r--r--src/Authenticator.h93
1 files changed, 0 insertions, 93 deletions
diff --git a/src/Authenticator.h b/src/Authenticator.h
deleted file mode 100644
index 02cd6f4c5..000000000
--- a/src/Authenticator.h
+++ /dev/null
@@ -1,93 +0,0 @@
-
-// cAuthenticator.h
-
-// Interfaces to the cAuthenticator class representing the thread that authenticates users against the official MC server
-// Authentication prevents "hackers" from joining with an arbitrary username (possibly impersonating the server admins)
-// For more info, see http://wiki.vg/Session#Server_operation
-// In MCS, authentication is implemented as a single thread that receives queued auth requests and dispatches them one by one.
-
-
-
-
-
-#pragma once
-#ifndef CAUTHENTICATOR_H_INCLUDED
-#define CAUTHENTICATOR_H_INCLUDED
-
-#include "OSSupport/IsThread.h"
-
-
-
-
-
-// fwd: "cRoot.h"
-class cRoot;
-
-
-
-
-
-class cAuthenticator :
- public cIsThread
-{
- typedef cIsThread super;
-
-public:
- cAuthenticator(void);
- ~cAuthenticator();
-
- /// (Re-)read server and address from INI:
- void ReadINI(cIniFile & IniFile);
-
- /// Queues a request for authenticating a user. If the auth fails, the user is kicked
- void Authenticate(int a_ClientID, const AString & a_UserName, const AString & a_ServerHash);
-
- /// Starts the authenticator thread. The thread may be started and stopped repeatedly
- void Start(cIniFile & IniFile);
-
- /// Stops the authenticator thread. The thread may be started and stopped repeatedly
- void Stop(void);
-
-private:
-
- class cUser
- {
- public:
- int m_ClientID;
- AString m_Name;
- AString m_ServerID;
-
- cUser(int a_ClientID, const AString & a_Name, const AString & a_ServerID) :
- m_ClientID(a_ClientID),
- m_Name(a_Name),
- m_ServerID(a_ServerID)
- {
- }
- } ;
-
- typedef std::deque<cUser> cUserList;
-
- cCriticalSection m_CS;
- cUserList m_Queue;
- cEvent m_QueueNonempty;
-
- AString m_Server;
- AString m_Address;
- bool m_ShouldAuthenticate;
-
- // cIsThread override:
- virtual void Execute(void) override;
-
- // Returns true if the user authenticated okay, false on error; iLevel is the recursion deptht (bails out if too deep)
- bool AuthFromAddress(const AString & a_Server, const AString & a_Address, const AString & a_UserName, int a_Level = 1);
-};
-
-
-
-
-
-#endif // CAUTHENTICATOR_H_INCLUDED
-
-
-
-