mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2025-07-11 05:20:16 +02:00
Allow different sources for EVE data types.
This commit is contained in:
parent
66240ad296
commit
ec9b43b083
@ -359,10 +359,15 @@ API_SSO_VALIDATION = 'True' == os.environ.get('AA_API_SSO_VALIDATION', 'False')
|
|||||||
#######################
|
#######################
|
||||||
# EVE Provider Settings
|
# EVE Provider Settings
|
||||||
#######################
|
#######################
|
||||||
# EVEONLINE_DATA_PROVIDER - Name of default data source for getting eve entity data
|
# EVEONLINE_CHARACTER_PROVIDER - Name of default data source for getting eve character data
|
||||||
|
# EVEONLINE_CORP_PROVIDER - Name of default data source for getting eve corporation data
|
||||||
|
# EVEONLINE_ALLIANCE_PROVIDER - Name of default data source for getting eve alliance data
|
||||||
|
#
|
||||||
# Available soruces are 'esi' and 'xml'
|
# Available soruces are 'esi' and 'xml'
|
||||||
#######################
|
#######################
|
||||||
EVEONLINE_DATA_PROVIDER = os.environ.get('AA_EVEONLINE_DATA_PROVIDER', 'esi')
|
EVEONLINE_CHARACTER_PROVIDER = os.environ.get('AA_EVEONLINE_CHARACTER_PROVIDER', 'esi')
|
||||||
|
EVEONLINE_CORP_PROVIDER = os.environ.get('AA_EVEONLINE_CORP_PROVIDER', 'esi')
|
||||||
|
EVEONLINE_ALLIANCE_PROVIDER = os.environ.get('AA_EVEONLINE_ALLIANCE_PROVIDER', 'esi')
|
||||||
|
|
||||||
#####################
|
#####################
|
||||||
# Alliance Market
|
# Alliance Market
|
||||||
|
@ -96,15 +96,20 @@ class EveProvider:
|
|||||||
raise NotImplementedError()
|
raise NotImplementedError()
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class EveSwaggerProvider(EveProvider):
|
class EveSwaggerProvider(EveProvider):
|
||||||
def __init__(self, token=None):
|
def __init__(self, token=None, adapter=None):
|
||||||
self.client = esi_client_factory(token=token)
|
self.client = esi_client_factory(token=token)
|
||||||
|
self.adapter = adapter or self
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return 'esi'
|
||||||
|
|
||||||
def get_alliance(self, alliance_id):
|
def get_alliance(self, alliance_id):
|
||||||
data = self.client.Alliance.get_alliances_alliance_id(alliance_id=alliance_id).result()
|
data = self.client.Alliance.get_alliances_alliance_id(alliance_id=alliance_id).result()
|
||||||
corps = self.client.Alliance.get_alliances_alliance_id_corporations(alliance_id=alliance_id).result()
|
corps = self.client.Alliance.get_alliances_alliance_id_corporations(alliance_id=alliance_id).result()
|
||||||
model = Alliance(
|
model = Alliance(
|
||||||
self,
|
self.adapter,
|
||||||
alliance_id,
|
alliance_id,
|
||||||
data['alliance_name'],
|
data['alliance_name'],
|
||||||
data['ticker'],
|
data['ticker'],
|
||||||
@ -115,7 +120,7 @@ class EveSwaggerProvider(EveProvider):
|
|||||||
def get_corp(self, corp_id):
|
def get_corp(self, corp_id):
|
||||||
data = self.client.Corporation.get_corporations_corporation_id(corporation_id=corp_id).result()
|
data = self.client.Corporation.get_corporations_corporation_id(corporation_id=corp_id).result()
|
||||||
model = Corporation(
|
model = Corporation(
|
||||||
self,
|
self.adapter,
|
||||||
corp_id,
|
corp_id,
|
||||||
data['corporation_name'],
|
data['corporation_name'],
|
||||||
data['ticker'],
|
data['ticker'],
|
||||||
@ -127,9 +132,9 @@ class EveSwaggerProvider(EveProvider):
|
|||||||
|
|
||||||
def get_character(self, character_id):
|
def get_character(self, character_id):
|
||||||
data = self.client.Character.get_characters_character_id(character_id=character_id).result()
|
data = self.client.Character.get_characters_character_id(character_id=character_id).result()
|
||||||
alliance_id = self.get_corp(data['corporation_id']).alliance_id
|
alliance_id = self.adapter.get_corp(data['corporation_id']).alliance_id
|
||||||
model = Character(
|
model = Character(
|
||||||
self,
|
self.adapter,
|
||||||
character_id,
|
character_id,
|
||||||
data['name'],
|
data['name'],
|
||||||
data['corporation_id'],
|
data['corporation_id'],
|
||||||
@ -138,19 +143,24 @@ class EveSwaggerProvider(EveProvider):
|
|||||||
return model
|
return model
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class EveXmlProvider(EveProvider):
|
class EveXmlProvider(EveProvider):
|
||||||
def __init__(self, api_key=None):
|
def __init__(self, api_key=None, adapter=None):
|
||||||
"""
|
"""
|
||||||
:param api_key: eveonline.EveApiKeyPair
|
:param api_key: eveonline.EveApiKeyPair
|
||||||
"""
|
"""
|
||||||
self.api = evelink.api.API(api_key=(api_key.api_id, api_key.api_key)) if api_key else evelink.api.API()
|
self.api = evelink.api.API(api_key=(api_key.api_id, api_key.api_key)) if api_key else evelink.api.API()
|
||||||
|
self.adapter = adapter or self
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return 'xml'
|
||||||
|
|
||||||
def get_alliance(self, id):
|
def get_alliance(self, id):
|
||||||
api = evelink.eve.EVE(api=self.api)
|
api = evelink.eve.EVE(api=self.api)
|
||||||
alliances = api.alliances().result
|
alliances = api.alliances().result
|
||||||
results = alliances[int(id)]
|
results = alliances[int(id)]
|
||||||
model = Alliance(
|
model = Alliance(
|
||||||
self,
|
self.adapter,
|
||||||
id,
|
id,
|
||||||
results['name'],
|
results['name'],
|
||||||
results['ticker'],
|
results['ticker'],
|
||||||
@ -162,7 +172,7 @@ class EveXmlProvider(EveProvider):
|
|||||||
api = evelink.corp.Corp(api=self.api)
|
api = evelink.corp.Corp(api=self.api)
|
||||||
corpinfo = api.corporation_sheet(corp_id=int(id)).result
|
corpinfo = api.corporation_sheet(corp_id=int(id)).result
|
||||||
model = Corporation(
|
model = Corporation(
|
||||||
self,
|
self.adapter,
|
||||||
id,
|
id,
|
||||||
corpinfo['name'],
|
corpinfo['name'],
|
||||||
corpinfo['ceo']['id'],
|
corpinfo['ceo']['id'],
|
||||||
@ -176,7 +186,7 @@ class EveXmlProvider(EveProvider):
|
|||||||
api = evelink.eve.EVE(api=self.api)
|
api = evelink.eve.EVE(api=self.api)
|
||||||
charinfo = api.character_info_from_id(id).result
|
charinfo = api.character_info_from_id(id).result
|
||||||
model = Character(
|
model = Character(
|
||||||
self,
|
self.adapter,
|
||||||
id,
|
id,
|
||||||
charinfo['name'],
|
charinfo['name'],
|
||||||
charinfo['corp']['id'],
|
charinfo['corp']['id'],
|
||||||
@ -185,31 +195,43 @@ class EveXmlProvider(EveProvider):
|
|||||||
return model
|
return model
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class EveAdapter(EveProvider):
|
class EveAdapter(EveProvider):
|
||||||
"""
|
"""
|
||||||
Redirects queries to appropriate data source.
|
Redirects queries to appropriate data source.
|
||||||
"""
|
"""
|
||||||
def __init__(self, provider):
|
def __init__(self, char_provider, corp_provider, alliance_provider):
|
||||||
self.provider = provider
|
self.char_provider = char_provider
|
||||||
|
self.corp_provider = corp_provider
|
||||||
|
self.alliance_provider = alliance_provider
|
||||||
|
self.char_provider.adapter = self
|
||||||
|
self.corp_provider.adapter = self
|
||||||
|
self.alliance_provider.adapter = self
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return "<{} ({})>".format(self.__class__.__name__, self.provider.__class__.__name__)
|
return "<{} (char:{}, corp:{}, alliance:{})>".format(self.__class__.__name__, str(self.char_provider), str(self.corp_provider), str(self.alliance_provider))
|
||||||
|
|
||||||
def get_character(self, id):
|
def get_character(self, id):
|
||||||
return self.provider.get_character(id)
|
return self.char_provider.get_character(id)
|
||||||
|
|
||||||
def get_corporation(self, id):
|
def get_corp(self, id):
|
||||||
return self.provider.get_corporation(id)
|
return self.corp_provider.get_corp(id)
|
||||||
|
|
||||||
def get_alliance(self, id):
|
def get_alliance(self, id):
|
||||||
return self.provider.get_alliance(id)
|
return self.alliance_provider.get_alliance(id)
|
||||||
|
|
||||||
|
|
||||||
def adapter_factory(source=settings.EVEONLINE_DATA_PROVIDER, **kwargs):
|
def eve_adapter_factory(character_source=settings.EVEONLINE_CHARACTER_PROVIDER, corp_source=settings.EVEONLINE_CORP_PROVIDER, alliance_source=settings.EVEONLINE_ALLIANCE_PROVIDER, api_key=None, token=None):
|
||||||
|
sources = [character_source, corp_source, alliance_source]
|
||||||
|
providers = []
|
||||||
|
|
||||||
|
xml = EveXmlProvider(api_key=api_key)
|
||||||
|
esi = EveSwaggerProvider(token=token)
|
||||||
|
|
||||||
|
for source in sources:
|
||||||
if source == 'xml':
|
if source == 'xml':
|
||||||
return EveAdapter(EveXmlProvider(**kwargs))
|
providers.append(xml)
|
||||||
elif source == 'esi':
|
elif source == 'esi':
|
||||||
return EveAdapter(EveSwaggerProvider(**kwargs))
|
providers.append(esi)
|
||||||
else:
|
else:
|
||||||
raise ValueError('Unrecognized data source.')
|
raise ValueError('Unrecognized data source "%s"' % source)
|
||||||
|
return EveAdapter(providers[0], providers[1], providers[2])
|
||||||
|
Loading…
x
Reference in New Issue
Block a user