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

    • what pack you use  send me on discord for it
    • package custom.events.RandomZoneEvent; import java.io.File; import java.util.ArrayList; import java.util.List; import java.util.Random; import java.util.concurrent.ScheduledFuture; import org.w3c.dom.Document; import org.w3c.dom.Node; import org.l2jmobius.commons.threads.ThreadPool; import org.l2jmobius.commons.time.SchedulingPattern; import org.l2jmobius.commons.time.TimeUtil; import org.l2jmobius.commons.util.IXmlReader; import org.l2jmobius.gameserver.managers.ZoneManager; import org.l2jmobius.gameserver.model.StatSet; import org.l2jmobius.gameserver.model.actor.Creature; import org.l2jmobius.gameserver.model.actor.Npc; import org.l2jmobius.gameserver.model.actor.Player; import org.l2jmobius.gameserver.model.quest.Event; import org.l2jmobius.gameserver.model.zone.ZoneId; import org.l2jmobius.gameserver.model.zone.ZoneType; import org.l2jmobius.gameserver.model.zone.type.RandomZone; import org.l2jmobius.gameserver.util.Broadcast; /** * Random Zone Event - Activates one random PvP zone temporarily. No modifica la clase de la zona: usa flags PvP en runtime. * @author Juan */ public class RandomZoneEvent extends Event { private static final String CONFIG_FILE = "data/scripts/custom/events/RandomZoneEvent/config.xml"; private static int EVENT_DURATION_MINUTES = 15; private static boolean _isActive = false; private ScheduledFuture<?> _eventTask = null; private final List<ZoneType> _availableZones = new ArrayList<>(); private ZoneType _activeZone = null; public RandomZoneEvent() { loadConfig(); loadZones(); registerZoneListeners(); } /** * Registra listeners a TODAS LAS ZONAS random */ private void registerZoneListeners() { for (ZoneType zone : _availableZones) { addEnterZoneId(zone.getId()); addExitZoneId(zone.getId()); LOGGER.info("[RandomZoneEvent] Registered listener for zone: " + zone.getName()); } } private void loadConfig() { new IXmlReader() { @Override public void load() { parseDatapackFile(CONFIG_FILE); } @Override public void parseDocument(Document doc, File file) { forEach(doc, "event", eventNode -> { final StatSet att = new StatSet(parseAttributes(eventNode)); final String name = att.getString("name"); for (Node node = eventNode.getFirstChild(); node != null; node = node.getNextSibling()) { if ("schedule".equals(node.getNodeName())) { final StatSet attributes = new StatSet(parseAttributes(node)); final String pattern = attributes.getString("pattern"); final SchedulingPattern schedulingPattern = new SchedulingPattern(pattern); final StatSet params = new StatSet(); params.set("Name", name); params.set("SchedulingPattern", pattern); final long delay = schedulingPattern.getDelayToNextFromNow(); getTimers().addTimer("Schedule_" + name, params, delay + 5000, null, null); LOGGER.info("[RandomZoneEvent] Event " + name + " scheduled at " + TimeUtil.getDateTimeString(System.currentTimeMillis() + delay)); } } }); } }.load(); } private void loadZones() { for (ZoneType zone : ZoneManager.getInstance().getAllZones(RandomZone.class)) { if ((zone.getName() != null) && zone.getName().toLowerCase().startsWith("random_zone")) { _availableZones.add(zone); LOGGER.info("[RandomZoneEvent] Loaded zone: " + zone.getName() + " (id=" + zone.getId() + ")"); } } LOGGER.info("[RandomZoneEvent] Total random zones loaded: " + _availableZones.size()); } @Override public void onTimerEvent(String event, StatSet params, Npc npc, Player player) { if (event.startsWith("Schedule_")) { eventStart(null); final SchedulingPattern schedulingPattern = new SchedulingPattern(params.getString("SchedulingPattern")); final long delay = schedulingPattern.getDelayToNextFromNow(); getTimers().addTimer(event, params, delay + 5000, null, null); LOGGER.info("[RandomZoneEvent] Rescheduled for " + TimeUtil.getDateTimeString(System.currentTimeMillis() + delay)); } } @Override public boolean eventStart(Player eventMaker) { if (_isActive) { if (eventMaker != null) { eventMaker.sendMessage("RandomZoneEvent already active."); } return false; } if (_availableZones.isEmpty()) { Broadcast.toAllOnlinePlayers("[RandomZoneEvent] No zones configured."); return false; } _isActive = true; Broadcast.toAllOnlinePlayers("⚔️ Random Zone Event has started!"); _eventTask = ThreadPool.schedule(this::activateRandomZone, 5_000); return true; } private void activateRandomZone() { _activeZone = _availableZones.get(new Random().nextInt(_availableZones.size())); _activeZone.setEnabled(true); Broadcast.toAllOnlinePlayers("🔥 Random Zone Event: " + _activeZone.getName() + " is now PvP for " + EVENT_DURATION_MINUTES + " minutes!"); _eventTask = ThreadPool.schedule(this::eventStop, EVENT_DURATION_MINUTES * 60 * 1000L); } @Override public boolean eventStop() { if (!_isActive) { return false; } _isActive = false; if (_eventTask != null) { _eventTask.cancel(true); _eventTask = null; } if (_activeZone != null) { _activeZone.setEnabled(false); Broadcast.toAllOnlinePlayers("🏁 Random Zone Event ended. " + _activeZone.getName() + " is back to normal."); _activeZone = null; } else { Broadcast.toAllOnlinePlayers("🏁 Random Zone Event ended."); } return true; } @Override public void onEnterZone(Creature creature, ZoneType zone) { if (!_isActive || (_activeZone == null)) { return; } if ((zone == _activeZone) && creature.isPlayable()) { creature.setInsideZone(ZoneId.PVP, true); if (creature.isPlayer()) { creature.sendMessage("Esta zona está en modo PvP temporalmente."); } } } @Override public void onExitZone(Creature creature, ZoneType zone) { if (!_isActive || (_activeZone == null)) { return; } if ((zone == _activeZone) && creature.isPlayable()) { creature.setInsideZone(ZoneId.PVP, false); if (creature.isPlayer()) { creature.sendMessage("Abandonaste la zona PvP temporal."); } } } @Override public boolean eventBypass(Player player, String bypass) { return true; } @Override public String onEvent(String event, Npc npc, Player player) { return super.onEvent(event, npc, player); } @Override public String onFirstTalk(Npc npc, Player player) { return null; } public static void main(String[] args) { new RandomZoneEvent(); } } i have this but its not working
    • ZonePvPSpawnBossRadio=0 ZonePvPSpawnBossBarakiel=0 at the Customs.ini in L2Server folder. Im prety sure this is it because i had the same problem with you in cruma 1 floor for example and i couldn't fix it but i fixed it finally by changing these 2 lines
  • 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