1
0
Fork 0
mirror of https://gitlab.com/SIGBUS/nyaa.git synced 2024-12-22 08:49:59 +00:00

Early filename validation (#354)

Currently just rejects torrents with RTL overrides in filenames
This commit is contained in:
Anna-Maria Meriniemi 2017-09-02 01:27:14 +03:00 committed by Arylide
parent 04a8ff95d2
commit 36d3f8aed0

View file

@ -49,6 +49,34 @@ def _replace_utf8_values(dict_or_list):
return did_change return did_change
def _recursive_dict_iterator(source):
''' Iterates over a given dict, yielding (key, value) pairs,
recursing inside any dicts. '''
# TODO Make a proper dict-filetree walker
for key, value in source.items():
yield (key, value)
if isinstance(value, dict):
for kv in _recursive_dict_iterator(value):
yield kv
def _validate_torrent_filenames(torrent):
''' Checks path parts of a torrent's filetree against blacklisted characters,
returning False on rejection '''
# TODO Move to config.py
character_blacklist = [
'\u202E', # RIGHT-TO-LEFT OVERRIDE
]
file_tree = json.loads(torrent.filelist.filelist_blob.decode('utf-8'))
for path_part, value in _recursive_dict_iterator(file_tree):
if any(True for c in character_blacklist if c in path_part):
return False
return True
def validate_torrent_post_upload(torrent, upload_form=None): def validate_torrent_post_upload(torrent, upload_form=None):
''' Validates a Torrent instance before it's saved to the database. ''' Validates a Torrent instance before it's saved to the database.
Enforcing user-and-such-based validations is more flexible here vs WTForm context ''' Enforcing user-and-such-based validations is more flexible here vs WTForm context '''
@ -61,6 +89,9 @@ def validate_torrent_post_upload(torrent, upload_form=None):
if torrent.user is None and torrent.filesize < minimum_anonymous_torrent_size: if torrent.user is None and torrent.filesize < minimum_anonymous_torrent_size:
errors['torrent_file'].append('Torrent too small for an anonymous uploader') errors['torrent_file'].append('Torrent too small for an anonymous uploader')
if not _validate_torrent_filenames(torrent):
errors['torrent_file'].append('Torrent has forbidden characters in filenames')
# Remove keys with empty lists # Remove keys with empty lists
errors = {k: v for k, v in errors.items() if v} errors = {k: v for k, v in errors.items() if v}
if errors: if errors: