salt/salt/returners/django_return.py
2022-09-08 12:33:16 -05:00

103 lines
2.6 KiB
Python

"""
.. deprecated:: 3006
.. warning::
This module has been deprecated and will be removed after January 2024.
A returner that will inform a Django system that
returns are available using Django's signal system.
https://docs.djangoproject.com/en/dev/topics/signals/
It is up to the Django developer to register necessary
handlers with the signals provided by this returner
and process returns as necessary.
The easiest way to use signals is to import them from
this returner directly and then use a decorator to register
them.
An example Django module that registers a function called
'returner_callback' with this module's 'returner' function:
.. code-block:: python
import salt.returners.django_return
from django.dispatch import receiver
@receiver(salt.returners.django_return, sender=returner)
def returner_callback(sender, ret):
print('I received {0} from {1}'.format(ret, sender))
"""
# Import Python libraries
import logging
# Import Salt libraries
import salt.returners
import salt.utils.jid
from salt.utils.versions import warn_until_date
log = logging.getLogger(__name__)
HAS_DJANGO = False
try:
from django import dispatch # pylint: disable=E0611
HAS_DJANGO = True
except ImportError:
HAS_DJANGO = False
# Define this module's virtual name
__virtualname__ = "django"
def __virtual__():
warn_until_date(
"20240101",
"The django returner is broken and deprecated, and will be removed"
" after {date}.",
)
if not HAS_DJANGO:
return False, "Could not import django returner; django is not installed."
return True
def returner(ret):
"""
Signal a Django server that a return is available
"""
signaled = dispatch.Signal(providing_args=["ret"]).send(sender="returner", ret=ret)
for signal in signaled:
log.debug(
"Django returner function 'returner' signaled %s which responded with %s",
signal[0],
signal[1],
)
def save_load(jid, load, minions=None):
"""
Save the load to the specified jid
"""
signaled = dispatch.Signal(providing_args=["jid", "load"]).send(
sender="save_load", jid=jid, load=load
)
for signal in signaled:
log.debug(
"Django returner function 'save_load' signaled %s which responded with %s",
signal[0],
signal[1],
)
def prep_jid(nocache=False, passed_jid=None):
"""
Do any work necessary to prepare a JID, including sending a custom ID
"""
return passed_jid if passed_jid is not None else salt.utils.jid.gen_jid(__opts__)