Skip to content

Commit

Permalink
Merge pull request #6525 from evilaliv3/secrets
Browse files Browse the repository at this point in the history
Replace usage of python random module with python secrets module
  • Loading branch information
legoktm authored Aug 29, 2022
2 parents a3ad874 + 072dfaa commit 87d84cf
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 23 deletions.
13 changes: 7 additions & 6 deletions securedrop/loaddata.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
import math
import os
import random
import secrets
import string
from itertools import cycle
from pathlib import Path
Expand Down Expand Up @@ -65,14 +66,14 @@ def random_bool() -> bool:
"""
Flips a coin.
"""
return random.choice((True, False))
return secrets.choice((True, False))


def random_chars(count: int, chars: str = string.ascii_letters) -> str:
"""
Returns a random string of len characters from the supplied list.
"""
return "".join([random.choice(chars) for _ in range(count)])
return "".join([secrets.choice(chars) for _ in range(count)])


def random_datetime(nullable: bool) -> Optional[datetime.datetime]:
Expand Down Expand Up @@ -330,20 +331,20 @@ def add_sources(args: argparse.Namespace, journalists: Tuple[Journalist, ...]) -
source, codename = add_source()

for _ in range(args.messages_per_source):
submit_message(source, random.choice(journalists) if seen_message_count > 0 else None)
submit_message(source, secrets.choice(journalists) if seen_message_count > 0 else None)
seen_message_count -= 1

for _ in range(args.files_per_source):
submit_file(source, random.choice(journalists) if seen_file_count > 0 else None)
submit_file(source, secrets.choice(journalists) if seen_file_count > 0 else None)
seen_file_count -= 1

if i <= starred_sources_count:
star_source(source)

if i <= replied_sources_count:
for _ in range(args.replies_per_source):
journalist_who_replied = random.choice([dellsberg, journalist_to_be_deleted])
journalist_who_saw = random.choice([default_journalist, None])
journalist_who_replied = secrets.choice([dellsberg, journalist_to_be_deleted])
journalist_who_saw = secrets.choice([default_journalist, None])
add_reply(source, journalist_who_replied, journalist_who_saw)

print(
Expand Down
2 changes: 1 addition & 1 deletion securedrop/passphrases.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
from pathlib import Path
from random import SystemRandom
from secrets import SystemRandom
from typing import Dict, List, NewType, Optional, Set

from sdconfig import config
Expand Down
2 changes: 1 addition & 1 deletion securedrop/source_user.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
from base64 import b32encode
from functools import lru_cache
from pathlib import Path
from random import SystemRandom
from secrets import SystemRandom
from typing import TYPE_CHECKING, List, Optional

import models
Expand Down
9 changes: 5 additions & 4 deletions securedrop/tests/migrations/helpers.py
Original file line number Diff line number Diff line change
@@ -1,16 +1,17 @@
# -*- coding: utf-8 -*-

import random
import secrets
import string
from datetime import datetime


def random_bool():
return bool(random.getrandbits(1))
return bool(secrets.randbits(1))


def bool_or_none():
return random.choice([None, True, False])
return secrets.choice([None, True, False])


def random_bytes(min, max, nullable):
Expand All @@ -32,11 +33,11 @@ def random_username():


def random_chars(len, chars=string.printable):
return "".join([random.choice(chars) for _ in range(len)])
return "".join([secrets.choice(chars) for _ in range(len)])


def random_ascii_chars(len, chars=string.ascii_lowercase):
return "".join([random.choice(chars) for _ in range(len)])
return "".join([secrets.choice(chars) for _ in range(len)])


def random_datetime(nullable):
Expand Down
23 changes: 12 additions & 11 deletions securedrop/tests/migrations/migration_48a75abc0121.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# -*- coding: utf-8 -*-

import random
import secrets
import string
from uuid import uuid4

Expand Down Expand Up @@ -141,7 +142,7 @@ def add_message(source_id):
"source_id": source_id,
"filename": random_chars(50) + "-msg.gpg",
"size": random.randint(0, 1024 * 1024 * 500),
"downloaded": random.choice([True, False]),
"downloaded": secrets.choice([True, False]),
}
sql = """
INSERT INTO submissions (uuid, source_id, filename, size, downloaded)
Expand All @@ -156,7 +157,7 @@ def add_file(source_id):
"source_id": source_id,
"filename": random_chars(50) + "-doc.gz.gpg",
"size": random.randint(0, 1024 * 1024 * 500),
"downloaded": random.choice([True, False]),
"downloaded": secrets.choice([True, False]),
"checksum": "sha256:" + random_chars(64),
}
sql = """
Expand Down Expand Up @@ -257,14 +258,14 @@ def check_upgrade(self):
# Now seen tables exist, so you should be able to mark some files, messages, and replies
# as seen
for submission in submissions:
if submission.filename.endswith("-doc.gz.gpg") and random.choice([0, 1]):
if submission.filename.endswith("-doc.gz.gpg") and secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_file_as_seen(submission.id, selected_journo_id)
elif random.choice([0, 1]):
elif secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_message_as_seen(submission.id, selected_journo_id)
for reply in replies:
if random.choice([0, 1]):
if secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_reply_as_seen(reply.id, selected_journo_id)

Expand Down Expand Up @@ -338,30 +339,30 @@ def load_data(self):
sql = "SELECT * FROM submissions"
submissions = db.engine.execute(text(sql)).fetchall()
for submission in submissions:
if submission.filename.endswith("-doc.gz.gpg") and random.choice([0, 1]):
if submission.filename.endswith("-doc.gz.gpg") and secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_file_as_seen(submission.id, selected_journo_id)
elif random.choice([0, 1]):
elif secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_message_as_seen(submission.id, selected_journo_id)

sql = "SELECT * FROM replies"
replies = db.engine.execute(text(sql)).fetchall()
for reply in replies:
if random.choice([0, 1]):
if secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_reply_as_seen(reply.id, selected_journo_id)

# Mark some files, messages, and replies as seen
for submission in submissions:
if submission.filename.endswith("-doc.gz.gpg") and random.choice([0, 1]):
if submission.filename.endswith("-doc.gz.gpg") and secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_file_as_seen(submission.id, selected_journo_id)
elif random.choice([0, 1]):
elif secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_message_as_seen(submission.id, selected_journo_id)
for reply in replies:
if random.choice([0, 1]):
if secrets.choice([0, 1]):
selected_journo_id = random.randint(0, self.JOURNO_NUM)
self.mark_reply_as_seen(reply.id, selected_journo_id)

Expand Down

0 comments on commit 87d84cf

Please sign in to comment.