forked from p15670423/monkey
Agent: Change logic for generating random password
This commit is contained in:
parent
b8ed464909
commit
820d47c9cc
|
@ -41,7 +41,7 @@ class CommunicateAsBackdoorUser(PBA):
|
|||
def run(self):
|
||||
username = CommunicateAsBackdoorUser.get_random_new_user_name()
|
||||
try:
|
||||
password = get_random_password()
|
||||
password = get_random_password(14)
|
||||
with create_auto_new_user(username, password) as new_user:
|
||||
http_request_commandline = (
|
||||
CommunicateAsBackdoorUser.get_commandline_for_http_request(
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
import secrets
|
||||
import string
|
||||
|
||||
SECRET_BYTE_LENGTH = 32
|
||||
SECRET_LENGTH = 32
|
||||
|
||||
|
||||
def get_random_password(length: int = SECRET_BYTE_LENGTH) -> str:
|
||||
password = secrets.token_urlsafe(length)
|
||||
def get_random_password(length: int = SECRET_LENGTH) -> str:
|
||||
alphabet = string.ascii_letters + string.digits + string.punctuation
|
||||
password = "".join(secrets.choice(alphabet) for i in range(length))
|
||||
return password
|
||||
|
|
|
@ -2,12 +2,17 @@ from infection_monkey.utils.random_password_generator import get_random_password
|
|||
|
||||
|
||||
def test_get_random_password__length():
|
||||
password_byte_length = len(get_random_password().encode())
|
||||
password_length = len(get_random_password())
|
||||
# 32 is the recommended secure byte length for secrets
|
||||
assert password_byte_length >= 32
|
||||
assert password_length == 32
|
||||
|
||||
|
||||
def test_get_random_password__custom_length():
|
||||
password_length = len(get_random_password(14))
|
||||
assert password_length == 14
|
||||
|
||||
|
||||
def test_get_random_password__randomness():
|
||||
random_password1 = get_random_password()
|
||||
random_password2 = get_random_password()
|
||||
assert not random_password1 == random_password2
|
||||
assert random_password1 != random_password2
|
||||
|
|
Loading…
Reference in New Issue