mirror of
https://github.com/nikdoof/test-auth.git
synced 2025-12-14 14:52:15 +00:00
Switch EVE API update job to a recurring task
This commit is contained in:
@@ -10,37 +10,6 @@ from eve_api.app_defines import *
|
|||||||
|
|
||||||
from eve_api.tasks import *
|
from eve_api.tasks import *
|
||||||
|
|
||||||
class UpdateAPIs():
|
|
||||||
"""
|
|
||||||
Updates all Eve API elements in the database
|
|
||||||
"""
|
|
||||||
|
|
||||||
settings = { 'update_corp': True }
|
|
||||||
|
|
||||||
last_update_delay = 86400
|
|
||||||
batches = 50
|
|
||||||
|
|
||||||
@property
|
|
||||||
def _logger(self):
|
|
||||||
if not hasattr(self, '__logger'):
|
|
||||||
self.__logger = logging.getLogger(__name__)
|
|
||||||
return self.__logger
|
|
||||||
|
|
||||||
def job(self, args):
|
|
||||||
# Update all the eve accounts and related corps
|
|
||||||
|
|
||||||
delta = datetime.timedelta(seconds=self.last_update_delay)
|
|
||||||
self._logger.debug("Updating APIs older than %s" % (datetime.datetime.now() - delta))
|
|
||||||
|
|
||||||
accounts = EVEAccount.objects.filter(api_last_updated__lt=(datetime.datetime.now() - delta)).exclude(api_status=API_STATUS_ACC_EXPIRED).exclude(api_status=API_STATUS_AUTH_ERROR).order_by('api_last_updated')[:self.batches]
|
|
||||||
self._logger.debug("%s account(s) to update" % len(accounts))
|
|
||||||
for acc in accounts:
|
|
||||||
self._logger.info("Queueing UserID %s for update" % acc.api_user_id)
|
|
||||||
if not acc.user:
|
|
||||||
acc.delete()
|
|
||||||
continue
|
|
||||||
import_apikey.delay(api_key=acc.api_key, api_userid=acc.api_user_id)
|
|
||||||
|
|
||||||
class AllianceUpdate():
|
class AllianceUpdate():
|
||||||
"""
|
"""
|
||||||
Pulls the AllianceList.xml.aspx and updates the alliance objects
|
Pulls the AllianceList.xml.aspx and updates the alliance objects
|
||||||
|
|||||||
@@ -1,10 +1,31 @@
|
|||||||
from celery.decorators import task
|
from celery.decorators import task
|
||||||
from eve_api.models import EVEPlayerCorporation
|
from eve_api.models import EVEAccount, EVEPlayerCorporation
|
||||||
from eve_api.api_puller.accounts import import_eve_account
|
from eve_api.api_puller.accounts import import_eve_account
|
||||||
from eve_api.api_puller.corp_management import pull_corp_members
|
from eve_api.api_puller.corp_management import pull_corp_members
|
||||||
from eve_api.app_defines import *
|
from eve_api.app_defines import *
|
||||||
from sso.tasks import update_user_access
|
from sso.tasks import update_user_access
|
||||||
|
|
||||||
|
@task(ignore_result=True)
|
||||||
|
def queue_apikey_updates(update_delay=86400, batch_size=50):
|
||||||
|
"""
|
||||||
|
Updates all Eve API elements in the database
|
||||||
|
"""
|
||||||
|
|
||||||
|
log = queue_apikey_updates.get_logger()
|
||||||
|
# Update all the eve accounts and related corps
|
||||||
|
delta = datetime.timedelta(seconds=update_delay)
|
||||||
|
log.info("Updating APIs older than %s" % (datetime.datetime.now() - delta))
|
||||||
|
|
||||||
|
accounts = EVEAccount.objects.filter(api_last_updated__lt=(datetime.datetime.now() - delta)).exclude(api_status=API_STATUS_ACC_EXPIRED).exclude(api_status=API_STATUS_AUTH_ERROR).order_by('api_last_updated')[:batch_size]
|
||||||
|
log.info("%s account(s) to update" % accounts.count())
|
||||||
|
for acc in accounts:
|
||||||
|
log.debug("Queueing UserID %s for update" % acc.api_user_id)
|
||||||
|
if not acc.user:
|
||||||
|
acc.delete()
|
||||||
|
continue
|
||||||
|
import_apikey.delay(api_key=acc.api_key, api_userid=acc.api_user_id)
|
||||||
|
|
||||||
|
|
||||||
@task()
|
@task()
|
||||||
def import_apikey(api_userid, api_key, user=None, force_cache=False):
|
def import_apikey(api_userid, api_key, user=None, force_cache=False):
|
||||||
acc = import_eve_account(api_key, api_userid, force_cache=force_cache)
|
acc = import_eve_account(api_key, api_userid, force_cache=force_cache)
|
||||||
|
|||||||
Reference in New Issue
Block a user