Make Scryfall errors easier to catch and handle
This commit is contained in:
parent
49fd9bd112
commit
20256fa38e
|
@ -2,6 +2,12 @@ import aiohttp
|
||||||
import asyncio
|
import asyncio
|
||||||
import urllib
|
import urllib
|
||||||
|
|
||||||
|
class ScryfallError(Exception):
|
||||||
|
def __init__(self, error_obj, *args, **kwargs):
|
||||||
|
super(self.__class__, self).__init__(*args, **kwargs)
|
||||||
|
self.error_details = **error_obj
|
||||||
|
|
||||||
|
|
||||||
class FoundationObject(object):
|
class FoundationObject(object):
|
||||||
|
|
||||||
def __init__(self, _url, override=False, **kwargs):
|
def __init__(self, _url, override=False, **kwargs):
|
||||||
|
@ -28,7 +34,7 @@ class FoundationObject(object):
|
||||||
loop.run_until_complete(main(loop))
|
loop.run_until_complete(main(loop))
|
||||||
|
|
||||||
if self.scryfallJson['object'] == 'error':
|
if self.scryfallJson['object'] == 'error':
|
||||||
raise Exception(self.scryfallJson['details'])
|
raise ScryfallError(self.scryfallJson, message=self.scryfallJson['details'])
|
||||||
|
|
||||||
def _checkForKey(self, key):
|
def _checkForKey(self, key):
|
||||||
"""Checks for a key in the scryfallJson object.
|
"""Checks for a key in the scryfallJson object.
|
||||||
|
@ -58,4 +64,4 @@ class FoundationObject(object):
|
||||||
KeyError: If key is not found.
|
KeyError: If key is not found.
|
||||||
"""
|
"""
|
||||||
if not key in self.scryfallJson[parent][num]:
|
if not key in self.scryfallJson[parent][num]:
|
||||||
raise KeyError('This tuple has no key \'{}\''.format(key))
|
raise KeyError('This tuple has no key \'{}\''.format(key))
|
||||||
|
|
Loading…
Reference in New Issue