| Server IP : 109.234.162.214 / Your IP : 216.73.216.112 Web Server : Apache System : Linux servd162214.srv.odns.fr 4.18.0-372.26.1.lve.1.el8.x86_64 #1 SMP Fri Sep 16 14:08:19 EDT 2022 x86_64 User : carpe ( 1178) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /opt/imunify360/venv/lib/python3.11/site-packages/defence360agent/subsys/ |
Upload File : |
"""Notify systemd about process state"""
import logging
import os
from defence360agent.contracts.config import ANTIVIRUS_MODE
logger = logging.getLogger(__name__)
class AgentState(object):
"""Allowed agent state for notifying systemd."""
READY = "READY=1"
STARTING = "STATUS=Starting main process"
MIGRATING = "STATUS=Applying database migrations"
DAEMONIZED = "STATUS=Demonized"
def notify(state):
"""
Send notification to systemd, allowed formats described here
https://www.freedesktop.org/software/systemd/man/sd_notify.html
For example:
notify("STATUS=Almost ready")
"""
if ANTIVIRUS_MODE:
return
try:
import sdnotify
# We've made this import inside function deliberately because some
# systems don't have systemd and stdnotify thus
except ImportError as e:
logger.info("Can't import sdnotify, reason: %s", e)
else:
if "NOTIFY_SOCKET" not in os.environ:
logger.warning(
"$NOTIFY_SOCKET environment variable is not set. It is set by"
" service manager for supervised processes for status and"
" start-up completion notification. Nowhere to send the"
" status."
)
else:
try:
n = sdnotify.SystemdNotifier(debug=True)
n.notify(state)
except Exception as e: # NOSONAR
logger.exception(
"some problem has occurred during notifying of"
" systemd: %s",
e,
)