Catch KeyError where we currently catch AttributError

This fixes up some issues with the updated Mastodon.py
This commit is contained in:
Jason McBrayer 2019-05-03 09:56:19 -04:00
parent 4de237a1b5
commit 8dbebea29a
1 changed files with 9 additions and 9 deletions

View File

@ -127,12 +127,12 @@ def timeline(request, timeline='home', timeline_name='Home', max_id=None, since_
prev = None prev = None
else: else:
prev['since_id'] = data[0].id prev['since_id'] = data[0].id
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
prev = None prev = None
try: try:
next = data[-1]._pagination_next next = data[-1]._pagination_next
next['max_id'] = data[-1].id next['max_id'] = data[-1].id
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
next = None next = None
notifications = _notes_count(account, mastodon) notifications = _notes_count(account, mastodon)
@ -470,11 +470,11 @@ def note(request, next=None, prev=None):
prev = notes[0]._pagination_prev prev = notes[0]._pagination_prev
if len(mastodon.notifications(since_id=prev['since_id'])) == 0: if len(mastodon.notifications(since_id=prev['since_id'])) == 0:
prev = None prev = None
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
prev = None prev = None
try: try:
next = notes[-1]._pagination_next next = notes[-1]._pagination_next
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
next = None next = None
return render(request, 'main/notifications.html', return render(request, 'main/notifications.html',
{'notes': notes,'timeline': 'Notifications', {'notes': notes,'timeline': 'Notifications',
@ -528,11 +528,11 @@ def user(request, username, prev=None, next=None):
if len(mastodon.account_statuses(user_dict.id, if len(mastodon.account_statuses(user_dict.id,
since_id=prev['since_id'])) == 0: since_id=prev['since_id'])) == 0:
prev = None prev = None
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
prev = None prev = None
try: try:
next = data[-1]._pagination_next next = data[-1]._pagination_next
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
next = None next = None
return render(request, 'main/user.html', return render(request, 'main/user.html',
{'toots': data, {'toots': data,
@ -892,7 +892,7 @@ def follow(request, id):
try: try:
user_dict = mastodon.account(id) user_dict = mastodon.account(id)
relationship = mastodon.account_relationships(user_dict.id)[0] relationship = mastodon.account_relationships(user_dict.id)[0]
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
raise Http404("The user could not be found.") raise Http404("The user could not be found.")
if request.method == 'POST': if request.method == 'POST':
if not request.POST.get('cancel', None): if not request.POST.get('cancel', None):
@ -923,7 +923,7 @@ def block(request, id):
try: try:
user_dict = mastodon.account(id) user_dict = mastodon.account(id)
relationship = mastodon.account_relationships(user_dict.id)[0] relationship = mastodon.account_relationships(user_dict.id)[0]
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
raise Http404("The user could not be found.") raise Http404("The user could not be found.")
if request.method == 'POST': if request.method == 'POST':
if not request.POST.get('cancel', None): if not request.POST.get('cancel', None):
@ -953,7 +953,7 @@ def mute(request, id):
try: try:
user_dict = mastodon.account(id) user_dict = mastodon.account(id)
relationship = mastodon.account_relationships(user_dict.id)[0] relationship = mastodon.account_relationships(user_dict.id)[0]
except (IndexError, AttributeError): except (IndexError, AttributeError, KeyError):
raise Http404("The user could not be found.") raise Http404("The user could not be found.")
if request.method == 'POST': if request.method == 'POST':
if not request.POST.get('cancel', None): if not request.POST.get('cancel', None):