Skip to content
/ LCRYPT Public

Unbreakable encryption combination [ Byte Shuffle | reverse-bits | bit-padding | byte-to-decimal | decimal-to-byte | XOR Key ]

License

Notifications You must be signed in to change notification settings

Locotir/LCRYPT

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Python Visual Studio Code Arch Windows 11 PayPal

LCRYPT: Unbreakable Binary-Level Encryption

Remake of this project on LCRYPT on C | Gained 99.68% performance | All I/O operations runs on RAM now

In the digital age, securing data at its core is crucial. LCRYPT offers a revolutionary encryption solution that protects data at the binary level, ensuring integrity and confidentiality. Unauthorized access is impossible without the decryption keys.

Description

LCRYPT encrypts files at the binary level, making data indecipherable without the correct keys. This method provides top-tier security, rendering manual decryption futile without the appropriate keys. LCRYPT-encrypted files resist reverse engineering due to their complexity. Each byte is shuffled randomly with a dynamic password and corresponds to a value between 0 and 255, shuffled, and also if the user decides so, it can add a random padding for each original bit, lenght defined by user. Finally an XOR Key string matching the same lenght of the total bits of the result is applied, all this steps results on complicating decryption attempts without the original tool. Even with the LCRYPT tool, brute force decryption is impractical due to the vast number of possible combinations and the required computational resources. The encryption's complexity remains a significant barrier, even against advancements in quantum computing.

Disclaimer: This tool does not leave any identifiable signature or trace that could be linked back to the tool or its author. The resulting encryption cannot be analyzed or reverse-engineered to understand the algorithm's nature without access to the program's source code.

Installation & Run

git clone https://github.com/Locotir/LCRYPT
cd LCRYPT
pip3 install -r requirements.txt
python LCRYPT.py

Targets accepted

All type of files and folders (The lighter, the better):
· Text Files -> .txt .docx .pdf...
· Data Files -> .xls .xlsx .csv...
. Small Databases -> .sql .db .mdb...
· Image Files -> .png .jpg .gif...
· Audio Files -> .mp3 .wav...
· Video Files -> .mp4 .mkv .avi...
· Presentation Files -> .ppt .pptx...
· Programming Files -> .py .c .cpp...
· Config Files -> .cfg .ini...
· Key Files -> .key .cer
· Compressed Files -> .zip .rar...

I take NO responsibility in misuse

This program is provided for educational and research purposes only. The user assumes all responsibility for the use of the program. The developer is not responsible for any misuse, damage or problems caused by the program. It is strongly recommended to use this software in an ethical and legal manner.

Program Operation

Note

[@] Shuffle each Byte
[@] Reverse Binary Chain
[@] Fill with n bits between each original bit
[@] Substitute each byte with decimal Table (0-255):Psswd randomized
[@] XOR Key unique string applied as long as entire file bit string

Graphical Explanation

LCRYPT-Diagrama drawio

Target

2024-06-06-200547_702x294_scrot

After compresion, shuffling, reverse, padding, bytes to decimal number saved in binary format and XOR Key finally applied:

2024-06-06-200703_710x304_scrot

Console Preview

2024-06-06-200619_954x608_scrot

Breakthrough Attempt

Scenario

For a simpler visualization, in this case we are not using TAR as it leads to a bigger file for the small files.

Target: Text file, contains 'a'

  • Content in binary: 01100001 00001010
  • Content in HEX: 610a

Encrypted with padding = 1:

  • Content in binary: 10011110 11111100 00110010 10111101
  • Content in HEX: 9efc 32bd

Process

    1. Original bits: 01100001 00001010
    1. Byte random sequence: [1, 2, 5, 3, 0, 6, 4, 7] & [7, 2, 6, 5, 3, 1, 4, 0] : Randomized with the passwd for each byte
    1. Result reversed: 00111110 11011101
    1. Adding Padding: 00000111 01011110 11010011 11010011 : Each bit generated is also random
    1. Byte to decimal (Each list is randomized with passwd (padding value)):
  • 00000111 : 142 | 01011110 : 167 | 11010011 : 151 | 11010011 : 151
    1. Decimal to byte:
  • 142 : 10001110 | 167: 10100111 | 151 : 10010111 | 151 : 10010111
    1. Result: 10001110 10100111 10010111 10010111
    1. XOR Key: 00010000 01011011 10100101 00101010
    1. Final Result: 10011110 11111100 00110010 10111101

Break Attempt

The result file is never gonna have metadata about the original file. Also the lack of a file type patterns vanishes with XOR Key. From here, any atempt for decrypting the file is impossible.

Let's imagine, the atacker knows the encryption method and the original file size:

  • As in this case, the file is double the size, so padding is 1.

  • If he attempts to remove the padding, the result will be: 01101110 01000111

  • ㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤㅤthe original looks: 01100001 00001010 (not even close obviously)

  • In just 2 bytes of 8bits exists 65.536 possible combinations.

  • The correct way to decrypt the file is by having the decimal to byte reference list which is generated with passwd (padding value)

  • Only if the attacker knows exactly the start or end of a byte in the file: He would need to create the original XOR Key which is the same lenght as the file, and after replicate each unique list 1-256 of 256 lenght and then remove padding and verify if the original byte is there. This sounds possible, but it really dosen't make sense as the possible unique lists is: 857817775342842654119082271681232625157781520279485619859655650377269452553147589377440291360451408450375885342336584306157196834693696475322289288497426025679637332563368786442675207626794560187968867971521143307702077526646451464709187326100832876325702818980773671781454170250523018608495319068138257481070252817586386376987034665712738139286205234756808218860701203611083152093501947437109101726968262861606263662435022840944191408424615936000000000000000000000000000000000000000000000000000000000000000

  • The last option and only possible one is by bruteforcing the decryption process from the program. For the smallests files, the execution time is aprox 0.05s. If the attacker uses a 14M passwords dictionary: ~8 days would take. But using a password long enough and not listed in any dictionary, it would take for ever.