| Server IP : 213.136.93.164 / Your IP : 216.73.216.104 Web Server : Apache System : Linux m14200.contabo.net 5.14.0-611.54.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Wed May 6 18:03:03 EDT 2026 x86_64 User : ki692510 ( 1047) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : /opt/imunify360/venv/lib64/python3.11/site-packages/defence360agent/plugins/ |
Upload File : |
from logging import getLogger
from defence360agent.api import inactivity
from defence360agent.contracts.config import SimpleRpc
from defence360agent.contracts.plugins import MessageSink
from defence360agent.utils import clip, fail_agent_service, recurring_check
logger = getLogger(__name__)
class IdleTimeOutCheck(MessageSink):
async def create_sink(self, loop):
self._loop = loop
if SimpleRpc.SOCKET_ACTIVATION:
inactivity.track.reset_timer()
self._task = loop.create_task(
recurring_check(
period=clip(
SimpleRpc.INACTIVITY_TIMEOUT // 5, low=1, high=60
),
)(
self._check_timeout,
)()
)
else:
self._task = None
async def shutdown(self):
if self._task:
self._task.cancel()
# CancelledError is handled by @recurring_check():
await self._task
async def _check_timeout(self):
logger.info("Periodical check %s ", inactivity.track)
if inactivity.track.is_timeout():
logger.warning("Shutting down due to inactivity.")
fail_agent_service()