Add task to import multiple characters in one run, allowing for easier permission callbacks

This commit is contained in:
2011-01-05 09:47:35 +00:00
parent 8c39e92d85
commit da0b37dd2d
2 changed files with 33 additions and 17 deletions

View File

@@ -9,7 +9,7 @@ from eve_proxy.models import CachedDocument
from eve_api.models import EVEAccount, EVEPlayerCharacter
from eve_api.app_defines import *
from eve_api.utils import basic_xml_parse_doc
from eve_api.tasks.character import import_eve_character
from eve_api.tasks.character import import_eve_characters
from eve_api.tasks.corporation import import_corp_members, import_corp_details
from sso.tasks import update_user_access
@@ -111,20 +111,15 @@ def import_apikey_func(api_userid, api_key, user=None, force_cache=False):
# Process the account's character list
charlist = set(account.characters.all().values_list('id', flat=True))
newcharlist = []
for char in doc['result']['characters']:
tasklist.append(import_eve_character.subtask(args=(char['characterID'], api_key, api_userid)))
newcharlist.append(int(char['characterID']))
newcharlist = [char['characterID'] char in doc['result']['characters']]
toremove = charlist - set(newcharlist)
for char in account.characters.filter(id__in=toremove):
for char in account.characters.filter(id__in=set(charlist - set(newcharlist)):
account.characters.remove(char)
# If we have a user, update their details in the taskset
if account.user:
tasklist.append(update_user_access.subtask(kwargs={'user': account.user.id }))
ts = TaskSet(tasks=tasklist)
ts.apply_async()
cb = update_user_access.subtask(kwargs={'user': account.user.id })
else:
cb = None
import_eve_characters.delay(newcharlist, api_key, api_userid, callback=cb)
return account

View File

@@ -2,6 +2,7 @@ from datetime import datetime, timedelta
from xml.dom import minidom
from celery.decorators import task
from celery.task.set import subtask
from eve_proxy.models import CachedDocument
@@ -14,10 +15,33 @@ from eve_api.utils import basic_xml_parse, basic_xml_parse_doc
def import_eve_character(character_id, api_key=None, user_id=None, callback=None):
"""
Imports a character from the API, providing a API key will populate
further details
further details. Returns a single EVEPlayerCharacter object
"""
pchar = import_eve_character_func(character_id, api_key, user_id)
if callback:
subtask(callback).delay(character=pchar.id)
else:
return pchar
@task()
def import_eve_characters(character_list, api_key=None, user_id=None, callback=None):
"""
Imports characters from the API, providing a API key will populate
further details. Returns a list of EVEPlayerCharacter objects
"""
results = [import_eve_character_func(char, api_key, user_id) for char in character_list]
if callback:
subtask(callback).delay(characters=results)
else:
return results
def import_eve_character_func(character_id, api_key=None, user_id=None):
char_doc = CachedDocument.objects.api_query('/eve/CharacterInfo.xml.aspx',
params={'characterID': character_id},
no_cache=False)
@@ -107,7 +131,4 @@ def import_eve_character(character_id, api_key=None, user_id=None, callback=None
except EVEAccount.DoesNotExist:
pass
if callback:
callback.delay(character=pchar.id)
else:
return pchar
return pchar