mirror of
https://github.com/kevinveenbirkenbach/splitted-secret.git
synced 2024-11-01 00:53:11 +01:00
Refactored to use AbstractSplittedSecret
This commit is contained in:
parent
6f0fd10b2e
commit
16040178e5
@ -3,17 +3,19 @@ import string
|
|||||||
import math
|
import math
|
||||||
import numpy
|
import numpy
|
||||||
import re
|
import re
|
||||||
import classes.Cli as Cli
|
from .Cli import Cli
|
||||||
|
from .AbstractSplittedSecret import AbstractSplittedSecret
|
||||||
|
|
||||||
class Generate:
|
class Generate(AbstractSplittedSecret,Cli):
|
||||||
|
|
||||||
def __init__(self, amount_of_secret_holders, decryption_quota):
|
def __init__(self, amount_of_secret_holders, decryption_quota):
|
||||||
|
super(Generate, self).__init__()
|
||||||
|
super(Cli, self).__init__()
|
||||||
self.amount_of_secret_holders = amount_of_secret_holders
|
self.amount_of_secret_holders = amount_of_secret_holders
|
||||||
self.decryption_quota = decryption_quota
|
self.decryption_quota = decryption_quota
|
||||||
self.decrypted_master_password_file_path="data/decrypted/password_files/master-password.txt"
|
self.decrypted_master_password_file_path="data/decrypted/password_files/master-password.txt"
|
||||||
self.quota_factor=self.decryption_quota/100
|
self.quota_factor=self.decryption_quota/100
|
||||||
self.group_members_amount=math.ceil(self.amount_of_secret_holders * self.quota_factor)
|
self.group_members_amount=math.ceil(self.amount_of_secret_holders * self.quota_factor)
|
||||||
self.cli = Cli.Cli()
|
|
||||||
|
|
||||||
def getStartnumber(self):
|
def getStartnumber(self):
|
||||||
index = 0
|
index = 0
|
||||||
@ -44,9 +46,8 @@ class Generate:
|
|||||||
return ''.join(random.choice(characters) for i in range(int(64*self.quota_factor))).upper()
|
return ''.join(random.choice(characters) for i in range(int(64*self.quota_factor))).upper()
|
||||||
|
|
||||||
def isGroupValid(self,password_group_index_str):
|
def isGroupValid(self,password_group_index_str):
|
||||||
width= range(1,(self.amount_of_secret_holders+1))
|
secret_stakeholders_range=range(1,(self.amount_of_secret_holders+1))
|
||||||
regex="([" + ','.join([str(x) for x in width]) + "]{" + str(self.group_members_amount) + "})"
|
valid_numbers = re.compile("([" + ','.join([str(x) for x in secret_stakeholders_range]) + "]{" + str(self.group_members_amount) + "})")
|
||||||
valid_numbers = re.compile(regex)
|
|
||||||
unvalid_sequenz = re.compile("(.)\\1+")
|
unvalid_sequenz = re.compile("(.)\\1+")
|
||||||
return re.search(valid_numbers, password_group_index_str) and not re.search(unvalid_sequenz, password_group_index_str)
|
return re.search(valid_numbers, password_group_index_str) and not re.search(unvalid_sequenz, password_group_index_str)
|
||||||
|
|
||||||
@ -71,8 +72,7 @@ class Generate:
|
|||||||
password += password_part
|
password += password_part
|
||||||
password_index += 1
|
password_index += 1
|
||||||
password_groups[password_group_index_int]['password'] += password
|
password_groups[password_group_index_int]['password'] += password
|
||||||
decrypted_splitted_password_file = "data/decrypted/splitted_password_files/" + password_group_index_str + ".txt"
|
encrypted_splitted_password_file = AbstractSplittedSecret().encrypted_splitted_password_files_folder + password_group_index_str + ".txt.gpg"
|
||||||
encrypted_splitted_password_file = "data/encrypted/splitted_password_files/" + password_group_index_str + ".txt.gpg"
|
self.executeCommand('gpg --batch --passphrase "' + password + '" -o "' + encrypted_splitted_password_file + '" -c "' + self.decrypted_master_password_file_path + '"')
|
||||||
self.cli.executeCommand('cp -v "' + self.decrypted_master_password_file_path + '" "' + decrypted_splitted_password_file + '" && gpg --batch --passphrase "' + password + '" -c "' + decrypted_splitted_password_file + '"')
|
print(self.getCommandString())
|
||||||
print(self.cli.getCommandString())
|
|
||||||
index += 1
|
index += 1
|
Loading…
Reference in New Issue
Block a user