Jump to content

.  

24 members have voted

  1. 1. Cand ia Nervos permisul?

    • Anu asta
      8
    • Anu viitor
      11
    • Niciodata
      5


Recommended Posts

Posted

Lasal ma si tu ..ca nu da nimeni 2 bani pe el si el se cearta cu noi ca vai domne noi suntem aia de vina ca a luat el ban si ca de ce nu ii oferim suport. (Eu cu opinia mea el cu a lui dar se pare ca omu nu poate sa asculte si opinia la alte persoane mai ales cand ii se zice adevarul)

Si nu sunt singurul care are aceiasi opinie despre ce se intampla aici,sido a explicat situatia actuala destul de concret ptr toti.

 

/END. (sa terminam odata cu circu asta)

 

 


 

 

Baga asta la maxim trance  ;D

 


 

Ce dreacu faci cu conturi de youtube raule ?

 

Ofc ca stiu mel <3.

 

Oricum nu dau 2 bani, eu dau reply aiurea. : ) Sincer nu am nimic cu el,daca el extinde chat-ul, de ce nu? ;D

Posted

E cineva pe aici care e in stare sa transcrie codul asta in java ?

// SimpleModulus.cpp : Defines the entry point for the application.
//

#include "Header\StdAfx.h"
#include "SimpleModules.h"

DWORD CSimpleModulus::s_dwSaveLoadXOR[4]={0x3F08A79B, 0xE25CC287, 0x93D27AB9, 0x20DEA7BF};

//#pragma warning(disable : 4244)

CSimpleModulus::CSimpleModulus()	// Completed
{ 
this->Init(); 
}


CSimpleModulus::~CSimpleModulus()	// Completed
{
return;
}

VOID CSimpleModulus::Init()	// Completed
{
memset(this->m_dwEncryptionKey, 0, sizeof(this->m_dwEncryptionKey));
memset(this->m_dwModulus, 0, sizeof(this->m_dwModulus));
memset(this->m_dwDecryptionKey, 0, sizeof(this->m_dwDecryptionKey));
} 

int CSimpleModulus::Encrypt(void * lpDest, void * lpSource, int iSize)	// Emulated - Completed
{
int iTempSize = iSize;
int iTempSize2;
int iOriSize ;
unsigned char * lpTempDest = (LPBYTE)lpDest;
unsigned char * lpTempSource = (LPBYTE)lpSource;

int iDec = ((iSize+7)/8);
iSize = (iDec + iDec*4)*2 + iDec;

if ( lpDest != NULL )
{
	iOriSize = iTempSize;
	for ( int i=0; i<iTempSize; i+=8,iOriSize-=8,lpTempDest+=11)
	{
		iTempSize2 = iOriSize;
		if ( iOriSize >= 8 )
			iTempSize2 = 8;

		this->EncryptBlock(lpTempDest, lpTempSource+i, iTempSize2);
	}
}

return iSize;
}


int CSimpleModulus::Decrypt(void * lpDest, void * lpSource, int iSize)
{
if ( lpDest == NULL)
{
	return iSize*8/11;
}

LPBYTE lpTempDest = (LPBYTE)lpDest;
LPBYTE lpTempSrc = (LPBYTE)lpSource;

int iResult = 0;
int iDecLen = 0;


if ( iSize > 0 )
{
	while ( iDecLen < iSize )
	{
		int iTempResult = this->DecryptBlock(lpTempDest, lpTempSrc);

		if ( iResult < 0 )
		{
			return iResult;
		}

		iResult += iTempResult;
		iDecLen += 11;
		lpTempSrc += 11;
		lpTempDest += 8;

	}
}

return iResult;
}



int CSimpleModulus::EncryptBlock(void*lpDest,void*lpSource,int iSize)
{
DWORD dwEncBuffer[4];
DWORD dwEncValue=0;	// TempVar1

LPBYTE lpEncDest = (LPBYTE)lpDest;
LPBYTE lpEncSource = (LPBYTE)lpSource;

memset(lpEncDest, 0, 11);
int i=0;

for ( i=0;i<4;i++)
{
	dwEncBuffer[i]=((this->m_dwXORKey[i]^((WORD*)lpEncSource)[i]^dwEncValue)*this->m_dwEncryptionKey[i])%this->m_dwModulus[i];
	dwEncValue=dwEncBuffer[i]&0xFFFF;
}

for ( i=0;i<3;i++)
{
	dwEncBuffer[i] = dwEncBuffer[i] ^ this->m_dwXORKey[i] ^ ( dwEncBuffer[i+1] & 0xFFFF );
}

int iBitPos = 0;

for ( i=0;i<4;i++)
{
	iBitPos = this->AddBits(lpDest, iBitPos, &dwEncBuffer[i], 0, 16);
	iBitPos = this->AddBits(lpDest, iBitPos, &dwEncBuffer[i], 22, 2);
}

BYTE btCheckSum = 0xF8;

for ( i=0;i<8;i++)
	btCheckSum ^= lpEncSource[i];

((LPBYTE)&dwEncValue)[1] = btCheckSum ; 
((LPBYTE)&dwEncValue)[0] = btCheckSum ^ iSize ^ 0x3D; 

return this->AddBits(lpDest, iBitPos, &dwEncValue, 0, 16);
}


int CSimpleModulus::DecryptBlock(void*lpDest,void*lpSource)
{
memset(lpDest, 0, 8);
DWORD dwDecBuffer[4]= {0};
int iBitPosition = 0;

LPBYTE lpDecDest = (LPBYTE)lpDest;
LPBYTE lpDecSource = (LPBYTE)lpSource;
int i=0;

for(i=0;i<4;i++)
{
	this->AddBits(&dwDecBuffer[i], 0, lpDecSource, iBitPosition, 16);
	iBitPosition += 16;
	this->AddBits(&dwDecBuffer[i], 22, lpDecSource, iBitPosition, 2);
	iBitPosition += 2;
}

for(i=2;i>=0;i--)
{
	dwDecBuffer[i] = dwDecBuffer[i] ^ this->m_dwXORKey[i] ^ (dwDecBuffer[i+1]&0xFFFF);
}

DWORD Temp=0,Temp1;

for(i=0;i<4;i++)
{
	Temp1 = (( this->m_dwDecryptionKey[i] * (dwDecBuffer[i])) % ( this->m_dwModulus[i])) ^ this->m_dwXORKey[i]^Temp;
	Temp = dwDecBuffer[i]&0xFFFF;
	((WORD*)lpDecDest)[i] = WORD(Temp1);
}

dwDecBuffer[0]=0;
this->AddBits(&dwDecBuffer[0], 0, lpDecSource, iBitPosition, 16);
((LPBYTE)dwDecBuffer)[0]=((LPBYTE)dwDecBuffer)[1]^ ((LPBYTE)dwDecBuffer)[0]^0x3D;

BYTE btCheckSum=0xF8;

for(i=0;i<8;i++)
	btCheckSum ^= lpDecDest[i];

if( btCheckSum != ((LPBYTE)dwDecBuffer)[1] )
	return -1;

return ((LPBYTE)dwDecBuffer)[0];
}


int CSimpleModulus::AddBits(void*lpDest,int iDestBitPos,void*lpSource,int iBitSourcePos,int iBitLen)	// Completed Emulated
{
// Get Buffer Lens
int iSourceBufferBitLen = iBitLen + iBitSourcePos ;
int iTempBufferLen = this->GetByteOfBit(iSourceBufferBitLen-1);
iTempBufferLen += 1 - this->GetByteOfBit(iBitSourcePos);

// Copy the Source Buffer
unsigned char * pTempBuffer = new unsigned char[iTempBufferLen+1];
memset(pTempBuffer, 0, iTempBufferLen+1);
memcpy(pTempBuffer, (unsigned char *)lpSource+ this->GetByteOfBit(iBitSourcePos), iTempBufferLen);

// Save the Last ibt if exist
if ( (iSourceBufferBitLen%8 ) != 0 )
{
	pTempBuffer[iTempBufferLen - 1] &= 255 << (8 - (iSourceBufferBitLen%8));
}

// Get the Values to Shift
int iShiftLeft = (iBitSourcePos%8);
int iShiftRight = (iDestBitPos%8);

// Shift the Values to Add the right space of the desired bits
this->Shift(pTempBuffer, iTempBufferLen, -iShiftLeft);
this->Shift(pTempBuffer, iTempBufferLen+1, iShiftRight);

// Copy the the bits of Source to the Dest
int iNewTempBufferLen = (( iShiftRight <= iShiftLeft )?0:1) + iTempBufferLen;
unsigned char * TempDist = (unsigned char *)lpDest + this->GetByteOfBit(iDestBitPos);

for ( int i=0;i<iNewTempBufferLen;i++)
{
	TempDist[i] |= pTempBuffer[i];
}

// Delete the temp Buffer
delete [] pTempBuffer;

// Return the number of bits of the new Dest Buffer
return iDestBitPos + iBitLen;
}



VOID CSimpleModulus::Shift(void*lpBuff,int iSize,int ShiftLen) // Need To be Checked
{
unsigned char * TempBuff = (unsigned char *)lpBuff;

// Case no Shift Len
if ( ShiftLen != 0  )	
{
	// Shift Right
	if ( ShiftLen > 0 )
	{
		if ( (iSize -1 ) > 0 )
		{
			for ( int i=(iSize-1); i>0 ; i--)
			{
				TempBuff[i] = (TempBuff[i-1]<<((8 - ShiftLen))) | (TempBuff[i]>>ShiftLen );
			}
		}

		TempBuff[0] >>=  ShiftLen;
	}
	else	// Shift Left
	{
		ShiftLen = - ShiftLen;

		if ( (iSize-1) > 0 )
		{
			for ( int i=0; i<(iSize-1) ;i++)
			{
				TempBuff[i] = (TempBuff[i+1]>>((8 - ShiftLen))) | (TempBuff[i]<<ShiftLen );
			}
		}

		TempBuff[iSize-1] <<= ShiftLen;
	}
}
}

int CSimpleModulus::GetByteOfBit(int btByte)
{
return btByte >> 3;
}

BOOL CSimpleModulus::SaveAllKey(LPSTR lpszFileName )
{
return this->SaveKey(lpszFileName, 4370, TRUE, TRUE, TRUE, TRUE);
}

BOOL CSimpleModulus::LoadAllKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, TRUE, TRUE, TRUE);
}

BOOL CSimpleModulus::SaveEncryptionKey(LPSTR lpszFileName)
{
return this->SaveKey(lpszFileName, 4370, TRUE, TRUE, FALSE, TRUE);
}


BOOL CSimpleModulus::LoadEncryptionKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, TRUE, FALSE ,TRUE);
}

BOOL CSimpleModulus::SaveDecryptionKey(LPSTR lpszFileName)
{
return this->SaveKey(lpszFileName, 4370, TRUE, FALSE, TRUE, TRUE);
}


BOOL CSimpleModulus::LoadDecryptionKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, FALSE ,TRUE ,TRUE);
}


BOOL CSimpleModulus::SaveKey(LPSTR lpszFileName, WORD wFileHeader, BOOL bSaveModulus, BOOL bSaveEncKey, BOOL bSaveDecKey, BOOL bSaveXORKey)
{
// MAde by Deathway
ENCDEC_FILEHEADER HeaderBuffer;
int iSize;
DWORD XORTable[4];
HANDLE hFile = CreateFile(lpszFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0x80, NULL);

if ( hFile == INVALID_HANDLE_VALUE )
{
	return FALSE;
}

HeaderBuffer.sFileHeader = wFileHeader;
HeaderBuffer.dwSize = ( bSaveModulus + bSaveEncKey + bSaveDecKey + bSaveXORKey ) * sizeof(XORTable) + sizeof(ENCDEC_FILEHEADER);

WriteFile( hFile, &HeaderBuffer, sizeof(ENCDEC_FILEHEADER), (ULONG*)&iSize, NULL);

if ( bSaveModulus != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwModulus[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveEncKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwEncryptionKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveDecKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwDecryptionKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveXORKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwXORKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

CloseHandle(hFile);

return TRUE;
}



BOOL CSimpleModulus::LoadKey(LPSTR lpszFileName, WORD wFileHeader, BOOL bLoadModulus, BOOL bLoadEncKey, BOOL bLoadDecKey, BOOL bLoadXORKey)
{
ENCDEC_FILEHEADER HeaderBuffer;
int iSize;
DWORD XORTable[4];
HANDLE hFile = CreateFile(lpszFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0x80, NULL);

if ( hFile != INVALID_HANDLE_VALUE )
{
	ReadFile( hFile, &HeaderBuffer, sizeof(ENCDEC_FILEHEADER), (ULONG*)&iSize, NULL);
}

if ( HeaderBuffer.sFileHeader == wFileHeader  )
{
	if ( (HeaderBuffer.dwSize) == (int)((( bLoadModulus + bLoadEncKey + bLoadDecKey + bLoadXORKey )*sizeof(XORTable))+sizeof(ENCDEC_FILEHEADER)) )
	{
		if ( bLoadModulus != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwModulus[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadEncKey != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwEncryptionKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadDecKey != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwDecryptionKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadXORKey != FALSE )
		{
			ReadFile(hFile, XORTable,sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwXORKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}

		CloseHandle(hFile);
		return TRUE;
	}
}
else
{
	CloseHandle(hFile);
}
return FALSE;
}

Posted

E cineva pe aici care e in stare sa transcrie codul asta in java ?

// SimpleModulus.cpp : Defines the entry point for the application.
//

#include "Header\StdAfx.h"
#include "SimpleModules.h"

DWORD CSimpleModulus::s_dwSaveLoadXOR[4]={0x3F08A79B, 0xE25CC287, 0x93D27AB9, 0x20DEA7BF};

//#pragma warning(disable : 4244)

CSimpleModulus::CSimpleModulus()	// Completed
{ 
this->Init(); 
}


CSimpleModulus::~CSimpleModulus()	// Completed
{
return;
}

VOID CSimpleModulus::Init()	// Completed
{
memset(this->m_dwEncryptionKey, 0, sizeof(this->m_dwEncryptionKey));
memset(this->m_dwModulus, 0, sizeof(this->m_dwModulus));
memset(this->m_dwDecryptionKey, 0, sizeof(this->m_dwDecryptionKey));
} 

int CSimpleModulus::Encrypt(void * lpDest, void * lpSource, int iSize)	// Emulated - Completed
{
int iTempSize = iSize;
int iTempSize2;
int iOriSize ;
unsigned char * lpTempDest = (LPBYTE)lpDest;
unsigned char * lpTempSource = (LPBYTE)lpSource;

int iDec = ((iSize+7)/8);
iSize = (iDec + iDec*4)*2 + iDec;

if ( lpDest != NULL )
{
	iOriSize = iTempSize;
	for ( int i=0; i<iTempSize; i+=8,iOriSize-=8,lpTempDest+=11)
	{
		iTempSize2 = iOriSize;
		if ( iOriSize >= 8 )
			iTempSize2 = 8;

		this->EncryptBlock(lpTempDest, lpTempSource+i, iTempSize2);
	}
}

return iSize;
}


int CSimpleModulus::Decrypt(void * lpDest, void * lpSource, int iSize)
{
if ( lpDest == NULL)
{
	return iSize*8/11;
}

LPBYTE lpTempDest = (LPBYTE)lpDest;
LPBYTE lpTempSrc = (LPBYTE)lpSource;

int iResult = 0;
int iDecLen = 0;


if ( iSize > 0 )
{
	while ( iDecLen < iSize )
	{
		int iTempResult = this->DecryptBlock(lpTempDest, lpTempSrc);

		if ( iResult < 0 )
		{
			return iResult;
		}

		iResult += iTempResult;
		iDecLen += 11;
		lpTempSrc += 11;
		lpTempDest += 8;

	}
}

return iResult;
}



int CSimpleModulus::EncryptBlock(void*lpDest,void*lpSource,int iSize)
{
DWORD dwEncBuffer[4];
DWORD dwEncValue=0;	// TempVar1

LPBYTE lpEncDest = (LPBYTE)lpDest;
LPBYTE lpEncSource = (LPBYTE)lpSource;

memset(lpEncDest, 0, 11);
int i=0;

for ( i=0;i<4;i++)
{
	dwEncBuffer[i]=((this->m_dwXORKey[i]^((WORD*)lpEncSource)[i]^dwEncValue)*this->m_dwEncryptionKey[i])%this->m_dwModulus[i];
	dwEncValue=dwEncBuffer[i]&0xFFFF;
}

for ( i=0;i<3;i++)
{
	dwEncBuffer[i] = dwEncBuffer[i] ^ this->m_dwXORKey[i] ^ ( dwEncBuffer[i+1] & 0xFFFF );
}

int iBitPos = 0;

for ( i=0;i<4;i++)
{
	iBitPos = this->AddBits(lpDest, iBitPos, &dwEncBuffer[i], 0, 16);
	iBitPos = this->AddBits(lpDest, iBitPos, &dwEncBuffer[i], 22, 2);
}

BYTE btCheckSum = 0xF8;

for ( i=0;i<8;i++)
	btCheckSum ^= lpEncSource[i];

((LPBYTE)&dwEncValue)[1] = btCheckSum ; 
((LPBYTE)&dwEncValue)[0] = btCheckSum ^ iSize ^ 0x3D; 

return this->AddBits(lpDest, iBitPos, &dwEncValue, 0, 16);
}


int CSimpleModulus::DecryptBlock(void*lpDest,void*lpSource)
{
memset(lpDest, 0, 8);
DWORD dwDecBuffer[4]= {0};
int iBitPosition = 0;

LPBYTE lpDecDest = (LPBYTE)lpDest;
LPBYTE lpDecSource = (LPBYTE)lpSource;
int i=0;

for(i=0;i<4;i++)
{
	this->AddBits(&dwDecBuffer[i], 0, lpDecSource, iBitPosition, 16);
	iBitPosition += 16;
	this->AddBits(&dwDecBuffer[i], 22, lpDecSource, iBitPosition, 2);
	iBitPosition += 2;
}

for(i=2;i>=0;i--)
{
	dwDecBuffer[i] = dwDecBuffer[i] ^ this->m_dwXORKey[i] ^ (dwDecBuffer[i+1]&0xFFFF);
}

DWORD Temp=0,Temp1;

for(i=0;i<4;i++)
{
	Temp1 = (( this->m_dwDecryptionKey[i] * (dwDecBuffer[i])) % ( this->m_dwModulus[i])) ^ this->m_dwXORKey[i]^Temp;
	Temp = dwDecBuffer[i]&0xFFFF;
	((WORD*)lpDecDest)[i] = WORD(Temp1);
}

dwDecBuffer[0]=0;
this->AddBits(&dwDecBuffer[0], 0, lpDecSource, iBitPosition, 16);
((LPBYTE)dwDecBuffer)[0]=((LPBYTE)dwDecBuffer)[1]^ ((LPBYTE)dwDecBuffer)[0]^0x3D;

BYTE btCheckSum=0xF8;

for(i=0;i<8;i++)
	btCheckSum ^= lpDecDest[i];

if( btCheckSum != ((LPBYTE)dwDecBuffer)[1] )
	return -1;

return ((LPBYTE)dwDecBuffer)[0];
}


int CSimpleModulus::AddBits(void*lpDest,int iDestBitPos,void*lpSource,int iBitSourcePos,int iBitLen)	// Completed Emulated
{
// Get Buffer Lens
int iSourceBufferBitLen = iBitLen + iBitSourcePos ;
int iTempBufferLen = this->GetByteOfBit(iSourceBufferBitLen-1);
iTempBufferLen += 1 - this->GetByteOfBit(iBitSourcePos);

// Copy the Source Buffer
unsigned char * pTempBuffer = new unsigned char[iTempBufferLen+1];
memset(pTempBuffer, 0, iTempBufferLen+1);
memcpy(pTempBuffer, (unsigned char *)lpSource+ this->GetByteOfBit(iBitSourcePos), iTempBufferLen);

// Save the Last ibt if exist
if ( (iSourceBufferBitLen%8 ) != 0 )
{
	pTempBuffer[iTempBufferLen - 1] &= 255 << (8 - (iSourceBufferBitLen%8));
}

// Get the Values to Shift
int iShiftLeft = (iBitSourcePos%8);
int iShiftRight = (iDestBitPos%8);

// Shift the Values to Add the right space of the desired bits
this->Shift(pTempBuffer, iTempBufferLen, -iShiftLeft);
this->Shift(pTempBuffer, iTempBufferLen+1, iShiftRight);

// Copy the the bits of Source to the Dest
int iNewTempBufferLen = (( iShiftRight <= iShiftLeft )?0:1) + iTempBufferLen;
unsigned char * TempDist = (unsigned char *)lpDest + this->GetByteOfBit(iDestBitPos);

for ( int i=0;i<iNewTempBufferLen;i++)
{
	TempDist[i] |= pTempBuffer[i];
}

// Delete the temp Buffer
delete [] pTempBuffer;

// Return the number of bits of the new Dest Buffer
return iDestBitPos + iBitLen;
}



VOID CSimpleModulus::Shift(void*lpBuff,int iSize,int ShiftLen) // Need To be Checked
{
unsigned char * TempBuff = (unsigned char *)lpBuff;

// Case no Shift Len
if ( ShiftLen != 0  )	
{
	// Shift Right
	if ( ShiftLen > 0 )
	{
		if ( (iSize -1 ) > 0 )
		{
			for ( int i=(iSize-1); i>0 ; i--)
			{
				TempBuff[i] = (TempBuff[i-1]<<((8 - ShiftLen))) | (TempBuff[i]>>ShiftLen );
			}
		}

		TempBuff[0] >>=  ShiftLen;
	}
	else	// Shift Left
	{
		ShiftLen = - ShiftLen;

		if ( (iSize-1) > 0 )
		{
			for ( int i=0; i<(iSize-1) ;i++)
			{
				TempBuff[i] = (TempBuff[i+1]>>((8 - ShiftLen))) | (TempBuff[i]<<ShiftLen );
			}
		}

		TempBuff[iSize-1] <<= ShiftLen;
	}
}
}

int CSimpleModulus::GetByteOfBit(int btByte)
{
return btByte >> 3;
}

BOOL CSimpleModulus::SaveAllKey(LPSTR lpszFileName )
{
return this->SaveKey(lpszFileName, 4370, TRUE, TRUE, TRUE, TRUE);
}

BOOL CSimpleModulus::LoadAllKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, TRUE, TRUE, TRUE);
}

BOOL CSimpleModulus::SaveEncryptionKey(LPSTR lpszFileName)
{
return this->SaveKey(lpszFileName, 4370, TRUE, TRUE, FALSE, TRUE);
}


BOOL CSimpleModulus::LoadEncryptionKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, TRUE, FALSE ,TRUE);
}

BOOL CSimpleModulus::SaveDecryptionKey(LPSTR lpszFileName)
{
return this->SaveKey(lpszFileName, 4370, TRUE, FALSE, TRUE, TRUE);
}


BOOL CSimpleModulus::LoadDecryptionKey(LPSTR lpszFileName)
{
return this->LoadKey(lpszFileName, 4370, TRUE, FALSE ,TRUE ,TRUE);
}


BOOL CSimpleModulus::SaveKey(LPSTR lpszFileName, WORD wFileHeader, BOOL bSaveModulus, BOOL bSaveEncKey, BOOL bSaveDecKey, BOOL bSaveXORKey)
{
// MAde by Deathway
ENCDEC_FILEHEADER HeaderBuffer;
int iSize;
DWORD XORTable[4];
HANDLE hFile = CreateFile(lpszFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0x80, NULL);

if ( hFile == INVALID_HANDLE_VALUE )
{
	return FALSE;
}

HeaderBuffer.sFileHeader = wFileHeader;
HeaderBuffer.dwSize = ( bSaveModulus + bSaveEncKey + bSaveDecKey + bSaveXORKey ) * sizeof(XORTable) + sizeof(ENCDEC_FILEHEADER);

WriteFile( hFile, &HeaderBuffer, sizeof(ENCDEC_FILEHEADER), (ULONG*)&iSize, NULL);

if ( bSaveModulus != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwModulus[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveEncKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwEncryptionKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveDecKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwDecryptionKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

if ( bSaveXORKey != FALSE )
{
	for ( int n = 0 ; n < 4 ; n++ )
	{
		XORTable[n] = this->m_dwXORKey[n] ^ s_dwSaveLoadXOR[n];
	}
	WriteFile(hFile, &XORTable, sizeof(XORTable), (ULONG*)&iSize, NULL);
}

CloseHandle(hFile);

return TRUE;
}



BOOL CSimpleModulus::LoadKey(LPSTR lpszFileName, WORD wFileHeader, BOOL bLoadModulus, BOOL bLoadEncKey, BOOL bLoadDecKey, BOOL bLoadXORKey)
{
ENCDEC_FILEHEADER HeaderBuffer;
int iSize;
DWORD XORTable[4];
HANDLE hFile = CreateFile(lpszFileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, 0x80, NULL);

if ( hFile != INVALID_HANDLE_VALUE )
{
	ReadFile( hFile, &HeaderBuffer, sizeof(ENCDEC_FILEHEADER), (ULONG*)&iSize, NULL);
}

if ( HeaderBuffer.sFileHeader == wFileHeader  )
{
	if ( (HeaderBuffer.dwSize) == (int)((( bLoadModulus + bLoadEncKey + bLoadDecKey + bLoadXORKey )*sizeof(XORTable))+sizeof(ENCDEC_FILEHEADER)) )
	{
		if ( bLoadModulus != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwModulus[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadEncKey != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwEncryptionKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadDecKey != FALSE )
		{
			ReadFile(hFile, XORTable, sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwDecryptionKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}
		if ( bLoadXORKey != FALSE )
		{
			ReadFile(hFile, XORTable,sizeof(XORTable) , (ULONG*)&iSize, NULL);
			for ( int n = 0 ; n<4;n++)
			{
				this->m_dwXORKey[n] = s_dwSaveLoadXOR[n] ^ XORTable[n];
			}
		}

		CloseHandle(hFile);
		return TRUE;
	}
}
else
{
	CloseHandle(hFile);
}
return FALSE;
}

contra o suma de bani, e posibil.

Guest
This topic is now closed to further replies.



  • Posts

    • the price is 220 + Payment Systems?
    • Discord         :  utchiha_market Telegram        : https://t.me/utchiha_market  
    • HELLO EVERYONE. WE ARE SELLING A LOT OF ADENA ON L2 REBORN / E-Global x Lu4 DISCORD - GODDARDSHOP   HURRY TO BUY OR YOU MAY NOT MAKE IT!!!
    • Added: 🎁 Seasonal Bonus System When the seasonal bonus is enabled, players receive additional bonus coins equal to bonus_season_percent of their donation amount. 💡 How it works (example): A player donates through their personal account and immediately receives regular coins. At the same time, bonus coins equal to 30% of the donation are credited. Example: Donation: 1000 coins → Bonus: 300 coins (30%) These bonus coins are not available immediately — they can be claimed later when the next season begins. 📅 When the bonus can be claimed: bonus_season_claim_start_date – the date when the "Claim" button becomes available. bonus_season_claim_end_date – the date after which the bonus can no longer be claimed. During this time window, the "Claim" button will appear in the personal account, allowing players to collect their accumulated bonus. 'bonus_season_enabled' => true, // Enable/disable the seasonal bonus system 'bonus_season_percent' => 30, // Percentage of the donation to be given as bonus coins (30 = 30%) 'bonus_season_claim_start_date' => '2025-07-30 00:00:00', // Date when the Claim button becomes available in the new season   'bonus_season_enabled' => true, // Вкл./Выкл Сезонную бонусную систему? 'bonus_season_percent' => 30, // Процент, при донате получает монеты в процентах 30 = 30%, которые может использовать в следующем открытии 'bonus_season_claim_start_date' => '2025-07-30 00:00:00', // Дата когда доступна кнопка Claim в новом сезоне 'bonus_season_claim_end_date' => '2025-08-15 20:00:00', // Дата окончания когда кнопка Claim в новом сезоне
  • Topics

×
×
  • Create New...

AdBlock Extension Detected!

Our website is made possible by displaying online advertisements to our members.

Please disable AdBlock browser extension first, to be able to use our community.

I've Disabled AdBlock