28 lines
1.1 KiB
C#
28 lines
1.1 KiB
C#
|
namespace dnlib.Protection {
|
||
|
public class Permute2EncryptionOperation : IEncryptionInstruction {
|
||
|
|
||
|
private readonly uint _xIndex1;
|
||
|
private readonly uint _kIndex;
|
||
|
private readonly uint _c;
|
||
|
|
||
|
public Permute2EncryptionOperation(uint xIndex1, uint kIndex, uint c) {
|
||
|
_xIndex1 = xIndex1;
|
||
|
_kIndex = kIndex % EncryptionInfo.KeyLength;
|
||
|
_c = c;
|
||
|
}
|
||
|
|
||
|
public void Encrypt(byte[] content, uint start, uint length, byte[] encryptionParam) {
|
||
|
uint xIndex1 = _xIndex1 % length + start;
|
||
|
uint xIndex2 = (encryptionParam[_kIndex] + _c) % length + start;
|
||
|
byte a = (byte)(content[xIndex1] + content[xIndex2]);
|
||
|
byte b = (byte)(content[xIndex2] + 1);
|
||
|
content[xIndex1] = a;
|
||
|
content[xIndex2] = b;
|
||
|
}
|
||
|
|
||
|
public string GenerateDecryptExpression(string dataVarName, string dataLengthVarName, string keyVarName) {
|
||
|
return $"{{ uint32_t xIndex1 = {_xIndex1} % {dataLengthVarName}; uint32_t xIndex2 = ((uint32_t){keyVarName}[{_kIndex}] + {_c}u) % {dataLengthVarName}; byte a = {dataVarName}[xIndex1]; byte b = {dataVarName}[xIndex2] - 1; {dataVarName}[xIndex1] = a - b; {dataVarName}[xIndex2] = b; }}";
|
||
|
}
|
||
|
}
|
||
|
}
|