summaryrefslogtreecommitdiff
path: root/protocols
diff options
context:
space:
mode:
Diffstat (limited to 'protocols')
-rw-r--r--protocols/MRA/Mra_11.vcxproj1
-rw-r--r--protocols/MRA/Mra_11.vcxproj.filters3
-rw-r--r--protocols/MRA/src/Mra.h1
-rw-r--r--protocols/MRA/src/MraProto.h1
-rw-r--r--protocols/MRA/src/Mra_functions.cpp41
-rw-r--r--protocols/MRA/src/Sdk/MemoryCompare.h101
-rw-r--r--protocols/MRA/src/Sdk/MemoryFind.h2
-rw-r--r--protocols/MRA/src/Sdk/SHA1.h5
8 files changed, 39 insertions, 116 deletions
diff --git a/protocols/MRA/Mra_11.vcxproj b/protocols/MRA/Mra_11.vcxproj
index 5901a6818d..31849c1183 100644
--- a/protocols/MRA/Mra_11.vcxproj
+++ b/protocols/MRA/Mra_11.vcxproj
@@ -237,7 +237,6 @@
<ClInclude Include="src\Sdk\InterlockedFunctions.h" />
<ClInclude Include="src\Sdk\InternetTime.h" />
<ClInclude Include="src\Sdk\ListMT.h" />
- <ClInclude Include="src\Sdk\MemoryCompare.h" />
<ClInclude Include="src\Sdk\MemoryFind.h" />
<ClInclude Include="src\Sdk\MemoryFindByte.h" />
<ClInclude Include="src\Sdk\MemoryReplace.h" />
diff --git a/protocols/MRA/Mra_11.vcxproj.filters b/protocols/MRA/Mra_11.vcxproj.filters
index a55f64dcae..ebe8e62f72 100644
--- a/protocols/MRA/Mra_11.vcxproj.filters
+++ b/protocols/MRA/Mra_11.vcxproj.filters
@@ -161,9 +161,6 @@
<ClInclude Include="src\Sdk\ListMT.h">
<Filter>Header Files\SDK</Filter>
</ClInclude>
- <ClInclude Include="src\Sdk\MemoryCompare.h">
- <Filter>Header Files\SDK</Filter>
- </ClInclude>
<ClInclude Include="src\Sdk\MemoryFind.h">
<Filter>Header Files\SDK</Filter>
</ClInclude>
diff --git a/protocols/MRA/src/Mra.h b/protocols/MRA/src/Mra.h
index 04dc97c624..d6aa29a04d 100644
--- a/protocols/MRA/src/Mra.h
+++ b/protocols/MRA/src/Mra.h
@@ -80,7 +80,6 @@
#include "Sdk/SocketFunctions.h"
#include "Sdk/MemoryFind.h"
#include "Sdk/MemoryFindByte.h"
-#include "Sdk/MemoryCompare.h"
#include "Sdk/MemoryReplace.h"
#include "Sdk/BuffToLowerCase.h"
#include "Sdk/StrToNum.h"
diff --git a/protocols/MRA/src/MraProto.h b/protocols/MRA/src/MraProto.h
index a9788ef432..79fd39359b 100644
--- a/protocols/MRA/src/MraProto.h
+++ b/protocols/MRA/src/MraProto.h
@@ -295,6 +295,7 @@ struct CMraProto : public PROTO<CMraProto>
bool SetPassDB(const CMStringA& pass);
bool GetPassDB(CMStringA& pass);
+ bool GetPassDB_v1(CMStringA &res);
bool MraRequestXStatusDetails(DWORD dwXStatus);
bool MraSendReplyBlogStatus(HANDLE hContact);
diff --git a/protocols/MRA/src/Mra_functions.cpp b/protocols/MRA/src/Mra_functions.cpp
index 2e08684f42..079904ea72 100644
--- a/protocols/MRA/src/Mra_functions.cpp
+++ b/protocols/MRA/src/Mra_functions.cpp
@@ -1359,12 +1359,45 @@ bool CMraProto::SetPassDB(const CMStringA& pass)
/////////////////////////////////////////////////////////////////////////////////////////
+
+bool CMraProto::GetPassDB_v1(CMStringA &res)
+{
+ BYTE btRandomData[256] = {0}, btCryptedPass[256] = {0}, bthmacSHA1[MIR_SHA1_HASH_SIZE] = {0};
+ size_t dwRandomDataSize, dwCryptedPass, dwPassSize;
+ CMStringA szEmail;
+
+ if (mraGetContactSettingBlob(NULL, "pCryptData", btRandomData, sizeof(btRandomData), &dwRandomDataSize))
+ if (dwRandomDataSize == sizeof(btRandomData))
+ if (mraGetContactSettingBlob(NULL, "pCryptPass", btCryptedPass, sizeof(btCryptedPass), &dwCryptedPass))
+ if (dwCryptedPass == sizeof(btCryptedPass))
+ if (mraGetStringA(NULL, "e-mail", szEmail)) {
+ mir_hmac_sha1(bthmacSHA1, (BYTE*)szEmail.c_str(), szEmail.GetLength(), btRandomData, sizeof(btRandomData));
+
+ RC4(btCryptedPass, sizeof(btCryptedPass), bthmacSHA1, MIR_SHA1_HASH_SIZE);
+ CopyMemoryReverseDWORD(btCryptedPass, btCryptedPass, sizeof(btCryptedPass));
+ RC4(btCryptedPass, sizeof(btCryptedPass), btRandomData, dwRandomDataSize);
+ RC4(btCryptedPass, sizeof(btCryptedPass), bthmacSHA1, MIR_SHA1_HASH_SIZE);
+
+ dwPassSize = (*btCryptedPass);
+ btCryptedPass[dwPassSize] = 0;
+
+ unsigned dwDecodedSize;
+ mir_ptr<BYTE> pDecoded((PBYTE)mir_base64_decode((LPCSTR)&btCryptedPass[(1+MIR_SHA1_HASH_SIZE)], &dwDecodedSize));
+ SHA1GetDigest(pDecoded, dwDecodedSize, btRandomData);
+ if ( !memcmp(&btCryptedPass[1], btRandomData, MIR_SHA1_HASH_SIZE)) {
+ res = CMStringA((LPSTR)(PBYTE)pDecoded, dwDecodedSize);
+ return true;
+ }
+ }
+
+ return false;
+}
+
bool CMraProto::GetPassDB(CMStringA &res)
{
switch (getDword("pCryptVer", 0)) {
case 1:
- MessageBox(NULL, TranslateT("Your password expired. Please reenter password in the Options dialog"), TranslateT("Error"), MB_OK);
- return false;
+ return GetPassDB_v1(res);
case 2:
break;
default:
@@ -1387,9 +1420,9 @@ bool CMraProto::GetPassDB(CMStringA &res)
RC4(btCryptedPass, sizeof(btCryptedPass), btRandomData, dwRandomDataSize);
RC4(btCryptedPass, sizeof(btCryptedPass), bthmacSHA1, MIR_SHA1_HASH_SIZE);
- DWORD dwPassSize = ((*btCryptedPass)&0xff);
+ DWORD dwPassSize = btCryptedPass[0];
SHA1GetDigest(&btCryptedPass[(1+MIR_SHA1_HASH_SIZE)], dwPassSize, btRandomData);
- if (MemoryCompare(&btCryptedPass[1], MIR_SHA1_HASH_SIZE, btRandomData, MIR_SHA1_HASH_SIZE) == CMEM_EQUAL)
+ if ( !memcmp(&btCryptedPass[1], btRandomData, MIR_SHA1_HASH_SIZE))
res = CMStringA((char*)&btCryptedPass[(1+MIR_SHA1_HASH_SIZE)], dwPassSize);
return true;
}
diff --git a/protocols/MRA/src/Sdk/MemoryCompare.h b/protocols/MRA/src/Sdk/MemoryCompare.h
deleted file mode 100644
index 17ef96f35a..0000000000
--- a/protocols/MRA/src/Sdk/MemoryCompare.h
+++ /dev/null
@@ -1,101 +0,0 @@
-/*
- * Copyright (c) 2003 Rozhuk Ivan <rozhuk.im@gmail.com>
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions
- * are met:
- * 1. Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * 2. Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- *
- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
- * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
- * SUCH DAMAGE.
- *
- */
-
-
-
-#if !defined(AFX_MEMORYCOMPARE__H__INCLUDED_)
-#define AFX_MEMORYCOMPARE__H__INCLUDED_
-
-#if _MSC_VER > 1000
-#pragma once
-#endif // _MSC_VER > 1000
-
-
-// If the string pointed to by lpString1 is less than the string pointed
-// to by lpString2, the return value is negative.
-// If the string pointed to by lpString1 is greater than the string pointed
-// to by lpString2, the return value is positive.
-// If the strings are equal, the return value is zero.
-//
-// lpString1<lpString2 >> ret=1=CSTR_LESS_THAN
-// lpString1=lpString2 >> ret=2=CSTR_EQUAL
-// lpString1>lpString2 >> ret=3=CSTR_GREATER_THAN
-
-#define CMEM_EQUAL 0
-#define CMEM_GREATER_THAN 1
-#define CMEM_LESS_THAN 2
-
-
-__inline unsigned int MemoryCompare(const void *pBuff1,size_t dwBuff1Size,const void *pBuff2,size_t dwBuff2Size)
-{
- unsigned int uiRet;
-
- if (dwBuff1Size==dwBuff2Size)
- {
- if (pBuff1==pBuff2)
- {
- uiRet=CMEM_EQUAL;
- }else{
- if (pBuff1 && pBuff2)
- {
- int iRet;
-
- iRet=memcmp(pBuff1,pBuff2,dwBuff1Size);
- if (iRet==0)
- {
- uiRet=CMEM_EQUAL;
- }else{
- if (iRet<0)
- {
- uiRet=CMEM_GREATER_THAN;
- }else{
- uiRet=CMEM_LESS_THAN;
- }
- }
- }else{
- if (pBuff1)
- {//pBuff2==NULL
- uiRet=CMEM_GREATER_THAN;
- }else{//pBuff1==NULL
- uiRet=CMEM_LESS_THAN;
- }
- }
- }
- }else{
- if (dwBuff1Size<dwBuff2Size)
- {
- uiRet=CMEM_LESS_THAN;
- }else{
- uiRet=CMEM_GREATER_THAN;
- }
- }
-return(uiRet);
-}
-
-
-
-#endif // !defined(AFX_MEMORYCOMPARE__H__INCLUDED_)
diff --git a/protocols/MRA/src/Sdk/MemoryFind.h b/protocols/MRA/src/Sdk/MemoryFind.h
index 860c5ce20a..8395f86249 100644
--- a/protocols/MRA/src/Sdk/MemoryFind.h
+++ b/protocols/MRA/src/Sdk/MemoryFind.h
@@ -51,7 +51,7 @@ __inline void *MemoryFind(size_t dwFrom,const void *pBuff,size_t dwBuffSize,cons
pCurPos=(void*)(((size_t)pBuff)+dwFrom);
if ((dwFrom+dwWhatFindSize)==dwBuffSize)
- {// only MemoryCompare
+ {
if (memcmp(pCurPos,pWhatFind,dwWhatFindSize)==0) pRet=pCurPos;
}else{
dwBuffSize-=(dwWhatFindSize-1);
diff --git a/protocols/MRA/src/Sdk/SHA1.h b/protocols/MRA/src/Sdk/SHA1.h
index 61f6c58399..bdac4cad8c 100644
--- a/protocols/MRA/src/Sdk/SHA1.h
+++ b/protocols/MRA/src/Sdk/SHA1.h
@@ -38,11 +38,6 @@
////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////
-void hmac_sha1(BYTE *text,size_t text_len,BYTE *key,size_t key_len,BYTE *digest);
-
-////////////////////////////////////////////////////////////////////
-////////////////////////////////////////////////////////////////////
-
__inline DWORD BSWAP(DWORD dwIn)
{
return((((dwIn<<8) & 0x00ff0000) | (dwIn<<24) | ((dwIn>>8) & 0x0000ff00) | (dwIn>>24)));