Merge pull request #2 from NandaScott/nanda/rulings-object
Nanda/rulings object
This commit is contained in:
commit
9270d6a959
|
@ -1,7 +1,14 @@
|
||||||
|
#Import classes from cards
|
||||||
from scrython.cards import Autocomplete
|
from scrython.cards import Autocomplete
|
||||||
from scrython.cards import Collector
|
from scrython.cards import Collector
|
||||||
from scrython.cards import Id
|
from scrython.cards import Id
|
||||||
from scrython.cards import Mtgo
|
from scrython.cards import Mtgo
|
||||||
from scrython.cards import Multiverse
|
from scrython.cards import Multiverse
|
||||||
from scrython.cards import Named
|
from scrython.cards import Named
|
||||||
from scrython.cards import RandomCard
|
from scrython.cards import Random
|
||||||
|
|
||||||
|
#Import classes from rulings
|
||||||
|
from scrython.rulings import Mtgo
|
||||||
|
from scrython.rulings import Multiverse
|
||||||
|
from scrython.rulings import Id
|
||||||
|
from scrython.rulings import Code
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
from .mtgo import Mtgo
|
||||||
|
from .multiverse_id import Multiverse
|
||||||
|
from .rulings_object import RulingsObject
|
||||||
|
from .scryfall_id import Id
|
||||||
|
from .set_code import Code
|
|
@ -0,0 +1,7 @@
|
||||||
|
from .rulings_object import RulingsObject
|
||||||
|
|
||||||
|
class Mtgo(RulingsObject):
|
||||||
|
def __init__(self, _id):
|
||||||
|
self.id = _id
|
||||||
|
self.url = 'cards/mtgo/{}/rulings'.format(self.id)
|
||||||
|
super(Mtgo, self).__init__(self.url)
|
|
@ -0,0 +1,7 @@
|
||||||
|
from .rulings_object import RulingsObject
|
||||||
|
|
||||||
|
class Multiverse(RulingsObject):
|
||||||
|
def __init__(self, _id):
|
||||||
|
self.id = str(_id)
|
||||||
|
self.url = 'cards/multiverse/{}/rulings'.format(self.id)
|
||||||
|
super(Multiverse, self).__init__(self.url)
|
|
@ -0,0 +1,87 @@
|
||||||
|
import asyncio
|
||||||
|
import aiohttp
|
||||||
|
|
||||||
|
class RulingsObject(object):
|
||||||
|
def __init__(self, _url, **kwargs):
|
||||||
|
self.pretty = kwargs.get('pretty')
|
||||||
|
self.format = kwargs.get('format')
|
||||||
|
self._url = 'https://api.scryfall.com/' + _url
|
||||||
|
loop = asyncio.get_event_loop()
|
||||||
|
self.session = aiohttp.ClientSession(loop=loop)
|
||||||
|
|
||||||
|
async def getRequest(url, **kwargs):
|
||||||
|
async with self.session.get(url, **kwargs) as response:
|
||||||
|
return await response.json()
|
||||||
|
|
||||||
|
self.scryfallJson = loop.run_until_complete(getRequest(
|
||||||
|
url = self._url,
|
||||||
|
params={
|
||||||
|
'format': self.format,
|
||||||
|
'pretty': self.pretty
|
||||||
|
}))
|
||||||
|
|
||||||
|
if self.scryfallJson['object'] == 'error':
|
||||||
|
self.session.close()
|
||||||
|
raise Exception(self.scryfallJson['details'])
|
||||||
|
|
||||||
|
self.session.close()
|
||||||
|
|
||||||
|
def __checkForKey(self, key):
|
||||||
|
try:
|
||||||
|
return self.scryfallJson[key]
|
||||||
|
except KeyError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
def __checkForTupleKey(self, parent, num, key):
|
||||||
|
try:
|
||||||
|
return self.scryfallJson[parent][num][key]
|
||||||
|
except KeyError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
def object(self):
|
||||||
|
if self.__checkForKey('object') is None:
|
||||||
|
return KeyError('This ruling object has no associated object key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['object']
|
||||||
|
|
||||||
|
def has_more(self):
|
||||||
|
if self.__checkForKey('has_more') is None:
|
||||||
|
return KeyError('This ruling object has no associated has_more key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['has_more']
|
||||||
|
|
||||||
|
def data(self):
|
||||||
|
if self.__checkForKey('data') is None:
|
||||||
|
return KeyError('This ruling object has no associated data key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['data']
|
||||||
|
|
||||||
|
def data_length(self):
|
||||||
|
if self.__checkForKey('data') is None:
|
||||||
|
return KeyError('This ruling object has no associated data key.')
|
||||||
|
|
||||||
|
return len(self.scryfallJson['data'])
|
||||||
|
|
||||||
|
def ruling_object(self, num):
|
||||||
|
if self.__checkForTupleKey('data', num, 'object') is None:
|
||||||
|
return KeyError('This ruling has no object key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['data'][num]['object']
|
||||||
|
|
||||||
|
def ruling_source(self, num):
|
||||||
|
if self.__checkForTupleKey('data', num, 'source') is None:
|
||||||
|
return KeyError('This ruling has no source key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['data'][num]['source']
|
||||||
|
|
||||||
|
def ruling_published_at(self, num):
|
||||||
|
if self.__checkForTupleKey('data', num, 'published_at') is None:
|
||||||
|
return KeyError('This ruling has no published_at key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['data'][num]['published_at']
|
||||||
|
|
||||||
|
def ruling_comment(self, num):
|
||||||
|
if self.__checkForTupleKey('data', num, 'comment') is None:
|
||||||
|
return KeyError('This ruling has no comment key.')
|
||||||
|
|
||||||
|
return self.scryfallJson['data'][num]['comment']
|
|
@ -0,0 +1,7 @@
|
||||||
|
from .rulings_object import RulingsObject
|
||||||
|
|
||||||
|
class Id(RulingsObject):
|
||||||
|
def __init__(self, _id):
|
||||||
|
self.id = str(_id)
|
||||||
|
self.url = 'cards/{}/rulings'.format(self.id)
|
||||||
|
super(Id, self).__init__(self.url)
|
|
@ -0,0 +1,8 @@
|
||||||
|
from .rulings_object import RulingsObject
|
||||||
|
|
||||||
|
class Code(RulingsObject):
|
||||||
|
def __init__(self, code, number):
|
||||||
|
self.code = code.lower()
|
||||||
|
self.number = str(number)
|
||||||
|
self.url = 'cards/{}/{}/rulings'.format(self.code, self.number)
|
||||||
|
super(Code, self).__init__(self.url)
|
Loading…
Reference in New Issue