| #!/usr/bin/env python3 |
| |
| import argparse |
| import binascii |
| import hashlib |
| import os |
| import struct |
| |
| def create_header(key, version, iv, random, size): |
| header = struct.pack('32s32s32s32s32s', key, version, iv, random, size) |
| |
| return header |
| |
| def create_output(args): |
| in_st = os.stat(args.input_file) |
| in_size = in_st.st_size |
| |
| key = "".encode('ascii') |
| version = args.version.encode('ascii') |
| iv = "".encode('ascii') |
| random = "".encode('ascii') |
| size = str(in_size).encode('ascii') |
| header = create_header(key, version, iv, random, size) |
| |
| out_f = open(args.output_file, 'w+b') |
| out_f.write(header) |
| out_f.close() |
| |
| md5 = hashlib.md5() |
| md5.update(header[0x60:0x80]) |
| md5.update(header[0x20:0x40]) |
| md5_1 = md5.digest() |
| |
| md5 = hashlib.md5() |
| md5.update(header[0x80:0xA0]) |
| md5.update(header[0x20:0x40]) |
| md5_2 = md5.digest() |
| |
| key = md5_1 + md5_2 |
| |
| key_f = open(args.key_file, 'w+b') |
| key_f.write(binascii.hexlify(bytearray(key))) |
| key_f.close() |
| |
| print("AES 256 CBC Key:", binascii.hexlify(bytearray(key))) |
| |
| def main(): |
| global args |
| |
| parser = argparse.ArgumentParser(description='') |
| |
| parser.add_argument('--input-file', |
| dest='input_file', |
| action='store', |
| type=str, |
| help='Input file') |
| |
| parser.add_argument('--key-file', |
| dest='key_file', |
| action='store', |
| type=str, |
| help='AES 256 CBC Key File') |
| |
| parser.add_argument('--output-file', |
| dest='output_file', |
| action='store', |
| type=str, |
| help='Output file') |
| |
| parser.add_argument('--version', |
| dest='version', |
| action='store', |
| type=str, |
| help='Version') |
| |
| args = parser.parse_args() |
| |
| if ((not args.input_file) or |
| (not args.key_file) or |
| (not args.output_file) or |
| (not args.version)): |
| parser.print_help() |
| |
| create_output(args) |
| |
| main() |