split-secret/scripts/generate.py

86 lines
3.9 KiB
Python
Raw Normal View History

2022-12-08 21:25:03 +01:00
import argparse
import random
import string
import math
import numpy
import re
2022-12-09 11:19:21 +01:00
from classes.Cli import Cli
2022-12-08 21:25:03 +01:00
def getPassword():
characters = string.ascii_letters + string.digits
return ''.join(random.choice(characters) for i in range(int(64*quota_factor))).upper()
def getStartnumber():
index = 0
start_number = ''
while index < group_members_amount:
start_number += '1'
index += 1
return int(start_number)
def getEndnumber():
index = 0
start_number = ''
while index < group_members_amount:
start_number += str(amount_of_secret_holders)
index += 1
return int(start_number)
def savePassword(password,password_file_path):
print("Saving password to: " + password_file_path)
master_password_file = open(password_file_path, "a")
master_password_file.seek(0)
master_password_file.truncate()
master_password_file.write(password)
master_password_file.close()
if __name__ == '__main__':
2022-12-09 11:19:21 +01:00
cli = Cli()
decrypted_master_password_file_path="data/decrypted/password_files/master-password.txt"
2022-12-08 21:25:03 +01:00
parser = argparse.ArgumentParser()
parser.add_argument('-a', '--amount',type=int, dest='amount_of_secret_holders',required=True,choices=range(1,9))
parser.add_argument('-q', '--quota', type=int, dest='decryption_quota', choices=range(1,101),required=True)
2022-12-09 11:19:21 +01:00
#parser.add_argument('-p', '--master-password', type=str, dest='master_password', required=False)
2022-12-08 21:25:03 +01:00
args = parser.parse_args()
amount_of_secret_holders = args.amount_of_secret_holders
2022-12-09 11:19:21 +01:00
#master_password = args.master_password
2022-12-08 21:25:03 +01:00
decryption_quota = args.decryption_quota
2022-12-09 11:19:21 +01:00
#savePassword(master_password,decrypted_master_password_file_path)
2022-12-08 21:25:03 +01:00
quota_factor=decryption_quota/100
group_members_amount=math.ceil(amount_of_secret_holders * quota_factor)
width= range(1,(amount_of_secret_holders+1))
regex="([" + ','.join([str(x) for x in width]) + "]{" + str(group_members_amount) + "})"
valid_numbers = re.compile(regex)
unvalid_sequenz = re.compile("(.)\\1+")
index = getStartnumber()
password_groups = {}
while index < getEndnumber():
password_group_index_str = ''.join(sorted(str(index)))
if re.search(valid_numbers, password_group_index_str) and not re.search(unvalid_sequenz, password_group_index_str):
password_group_index_int = int(password_group_index_str)
if not password_group_index_int in password_groups:
password_index = 1
password_groups[password_group_index_int] = {}
password_groups[password_group_index_int]['members'] = {}
password_groups[password_group_index_int]['password'] = ''
password = ''
for secret_holder_index in password_group_index_str:
password_groups[password_group_index_int]['members'][secret_holder_index]={}
password_part = getPassword()
password_groups[password_group_index_int]['members'][secret_holder_index]['password_part'] = password_part
password_groups[password_group_index_int]['members'][secret_holder_index]['password_index'] = password_index
password += password_part
password_index += 1
password_groups[password_group_index_int]['password'] += password
2022-12-09 11:19:21 +01:00
decrypted_splitted_password_file = "data/decrypted/splitted_password_files/" + password_group_index_str + ".txt"
encrypted_splitted_password_file = "data/encrypted/splitted_password_files/" + password_group_index_str + ".txt.gpg"
cli.executeCommand('cp -v "' + decrypted_master_password_file_path + '" "' + decrypted_splitted_password_file + '" && gpg --batch --passphrase "' + password + '" -c "' + decrypted_splitted_password_file + '"')
print(cli.getCommandString())
2022-12-08 21:25:03 +01:00
index += 1
print(password_groups)