summaryrefslogtreecommitdiff
path: root/protocols/JabberG/src/jabber_secur.h
diff options
context:
space:
mode:
authorVadim Dashevskiy <watcherhd@gmail.com>2012-10-12 14:53:57 +0000
committerVadim Dashevskiy <watcherhd@gmail.com>2012-10-12 14:53:57 +0000
commit3b55a62fdcb1f8222de3c2c8fbed530792c419a0 (patch)
tree5b2f628e847f61bb3e16f95ecaed6e187963362f /protocols/JabberG/src/jabber_secur.h
parent1f9c986d82657f965462d289bf94aa012cf026fc (diff)
GTalkExt, ICQ, IRC, Jabber: folders restructurization
git-svn-id: http://svn.miranda-ng.org/main/trunk@1890 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/JabberG/src/jabber_secur.h')
-rw-r--r--protocols/JabberG/src/jabber_secur.h113
1 files changed, 113 insertions, 0 deletions
diff --git a/protocols/JabberG/src/jabber_secur.h b/protocols/JabberG/src/jabber_secur.h
new file mode 100644
index 0000000000..0c3287b88d
--- /dev/null
+++ b/protocols/JabberG/src/jabber_secur.h
@@ -0,0 +1,113 @@
+/*
+
+Jabber Protocol Plugin for Miranda IM
+Copyright ( C ) 2002-04 Santithorn Bunchua
+Copyright ( C ) 2005-12 George Hazan
+
+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.
+
+*/
+
+#include "jabber.h"
+
+// basic class - provides interface for various Jabber auth
+
+class TJabberAuth
+{
+
+protected: bool bIsValid;
+ const char* szName;
+ unsigned complete;
+ ThreadData* info;
+
+public:
+ TJabberAuth( ThreadData* );
+ virtual ~TJabberAuth();
+
+ virtual char* getInitialRequest();
+ virtual char* getChallenge( const TCHAR* challenge );
+ virtual bool validateLogin( const TCHAR* challenge );
+
+ inline const char* getName() const
+ { return szName;
+ }
+
+ inline bool isValid() const
+ { return bIsValid;
+ }
+};
+
+// plain auth - the most simple one
+
+class TPlainAuth : public TJabberAuth
+{
+ typedef TJabberAuth CSuper;
+
+ bool bOld;
+
+
+public: TPlainAuth( ThreadData*, bool );
+ virtual ~TPlainAuth();
+
+ virtual char* getInitialRequest();
+};
+
+// md5 auth - digest-based authorization
+
+class TMD5Auth : public TJabberAuth
+{
+ typedef TJabberAuth CSuper;
+
+ int iCallCount;
+public:
+ TMD5Auth( ThreadData* );
+ virtual ~TMD5Auth();
+
+ virtual char* getChallenge( const TCHAR* challenge );
+};
+
+class TScramAuth : public TJabberAuth
+{
+ typedef TJabberAuth CSuper;
+
+ char *cnonce, *msg1, *serverSignature;
+public:
+ TScramAuth( ThreadData* );
+ virtual ~TScramAuth();
+
+ virtual char* getInitialRequest();
+ virtual char* getChallenge( const TCHAR* challenge );
+ virtual bool validateLogin( const TCHAR* challenge );
+
+ void Hi( mir_sha1_byte_t* res , char* passw, size_t passwLen, char* salt, size_t saltLen, int ind );
+};
+
+// ntlm auth - LanServer based authorization
+
+class TNtlmAuth : public TJabberAuth
+{
+ typedef TJabberAuth CSuper;
+
+ HANDLE hProvider;
+ const TCHAR *szHostName;
+public:
+ TNtlmAuth( ThreadData*, const char* mechanism, const TCHAR* hostname = NULL );
+ virtual ~TNtlmAuth();
+
+ virtual char* getInitialRequest();
+ virtual char* getChallenge( const TCHAR* challenge );
+
+ bool getSpn( TCHAR* szSpn, size_t dwSpnLen );
+};