mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
Improved task import to support global
This commit is contained in:
parent
372d252333
commit
69d1c3cea2
@ -53,10 +53,7 @@ def schedule_task(taskname, **kwargs):
|
|||||||
|
|
||||||
def offload_task(taskname, force_sync=False, *args, **kwargs):
|
def offload_task(taskname, force_sync=False, *args, **kwargs):
|
||||||
"""
|
"""
|
||||||
First check if the task method pointed
|
Create an AsyncTask if workers are running.
|
||||||
by taskname is implemented inside this file.
|
|
||||||
|
|
||||||
Then create an AsyncTask if workers are running.
|
|
||||||
This is different to a 'scheduled' task,
|
This is different to a 'scheduled' task,
|
||||||
in that it only runs once!
|
in that it only runs once!
|
||||||
|
|
||||||
@ -64,43 +61,55 @@ def offload_task(taskname, force_sync=False, *args, **kwargs):
|
|||||||
is set then the task is ran synchronously.
|
is set then the task is ran synchronously.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Get task list
|
|
||||||
tasks = get_task_list()
|
|
||||||
|
|
||||||
# Check if task exists
|
|
||||||
if taskname not in tasks:
|
|
||||||
logger.warning(f'Task "{taskname}" is not implemented in InvenTree/tasks.py')
|
|
||||||
return
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from django_q.tasks import AsyncTask
|
from django_q.tasks import AsyncTask
|
||||||
except (AppRegistryNotReady):
|
except (AppRegistryNotReady):
|
||||||
logger.warning("Could not offload task - app registry not ready")
|
logger.warning("Could not offload task - app registry not ready")
|
||||||
return
|
return
|
||||||
|
import importlib
|
||||||
from InvenTree.status import is_worker_running
|
from InvenTree.status import is_worker_running
|
||||||
|
|
||||||
if is_worker_running() and not force_sync:
|
if is_worker_running() and not force_sync:
|
||||||
# Append module path
|
|
||||||
taskname = 'InvenTree.tasks.' + taskname
|
|
||||||
# Running as asynchronous task
|
# Running as asynchronous task
|
||||||
|
try:
|
||||||
task = AsyncTask(taskname, *args, **kwargs)
|
task = AsyncTask(taskname, *args, **kwargs)
|
||||||
task.run()
|
task.run()
|
||||||
|
except ImportError:
|
||||||
|
logger.warning(f"WARNING: '{taskname}' not started - Function not found")
|
||||||
else:
|
else:
|
||||||
# Retrieve local method from task name
|
# Split path
|
||||||
_func = eval(taskname)
|
try:
|
||||||
# Run it as synchronous task
|
app, mod, func = taskname.split('.')
|
||||||
|
app_mod = app + '.' + mod
|
||||||
|
except ValueError:
|
||||||
|
logger.warning(f"WARNING: '{taskname}' not started - Malformed function path")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Import module from app
|
||||||
|
try:
|
||||||
|
_mod = importlib.import_module(app_mod)
|
||||||
|
except ModuleNotFoundError:
|
||||||
|
logger.warning(f"WARNING: '{taskname}' not started - No module named '{app_mod}'")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Retrieve function
|
||||||
|
try:
|
||||||
|
_func = getattr(_mod, func)
|
||||||
|
except AttributeError:
|
||||||
|
# getattr does not work for local import
|
||||||
|
_func = None
|
||||||
|
|
||||||
|
try:
|
||||||
|
if not _func:
|
||||||
|
_func = eval(func)
|
||||||
|
except NameError:
|
||||||
|
logger.warning(f"WARNING: '{taskname}' not started - No function named '{func}'")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Workers are not running: run it as synchronous task
|
||||||
_func()
|
_func()
|
||||||
|
|
||||||
|
|
||||||
def get_task_list():
|
|
||||||
return [task for task in LOCAL_METHODS if task not in TASK_MANAGEMENT]
|
|
||||||
|
|
||||||
|
|
||||||
# Keep TASK_MANAGEMENT before task methods
|
|
||||||
TASK_MANAGEMENT = [key for key, value in locals().items() if callable(value) and value.__module__ == __name__]
|
|
||||||
#
|
|
||||||
|
|
||||||
|
|
||||||
def heartbeat():
|
def heartbeat():
|
||||||
"""
|
"""
|
||||||
Simple task which runs at 5 minute intervals,
|
Simple task which runs at 5 minute intervals,
|
||||||
@ -249,8 +258,3 @@ def send_email(subject, body, recipients, from_email=None):
|
|||||||
from_email,
|
from_email,
|
||||||
recipients,
|
recipients,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
# Keep LOCAL_METHODS at the end of the file
|
|
||||||
LOCAL_METHODS = [key for key, value in locals().items() if callable(value) and value.__module__ == __name__]
|
|
||||||
#
|
|
||||||
|
@ -828,7 +828,7 @@ class CurrencyRefreshView(RedirectView):
|
|||||||
from InvenTree.tasks import offload_task
|
from InvenTree.tasks import offload_task
|
||||||
|
|
||||||
# Define associated task from InvenTree.tasks list of methods
|
# Define associated task from InvenTree.tasks list of methods
|
||||||
taskname = 'update_exchange_rates'
|
taskname = 'InvenTree.tasks.update_exchange_rates'
|
||||||
|
|
||||||
# Run it
|
# Run it
|
||||||
offload_task(taskname, force_sync=True)
|
offload_task(taskname, force_sync=True)
|
||||||
|
Loading…
Reference in New Issue
Block a user