$39 GRAYBYTE WORDPRESS FILE MANAGER $87

SERVER : in-mum-web1330.main-hosting.eu #1 SMP Mon Feb 10 22:45:17 UTC 2025
SERVER IP : 93.127.173.71 | ADMIN IP 216.73.216.143
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/python37/lib64/python3.7/site-packages/aiohttp/

HOME
Current File : /opt/alt/python37/lib64/python3.7/site-packages/aiohttp//web_log.py
import datetime
import functools
import logging
import os
import re
from collections import namedtuple
from typing import Any, Callable, Dict, Iterable, List, Tuple  # noqa

from .abc import AbstractAccessLogger
from .web_request import BaseRequest
from .web_response import StreamResponse

KeyMethod = namedtuple("KeyMethod", "key method")


class AccessLogger(AbstractAccessLogger):
    """Helper object to log access.

    Usage:
        log = logging.getLogger("spam")
        log_format = "%a %{User-Agent}i"
        access_logger = AccessLogger(log, log_format)
        access_logger.log(request, response, time)

    Format:
        %%  The percent sign
        %a  Remote IP-address (IP-address of proxy if using reverse proxy)
        %t  Time when the request was started to process
        %P  The process ID of the child that serviced the request
        %r  First line of request
        %s  Response status code
        %b  Size of response in bytes, including HTTP headers
        %T  Time taken to serve the request, in seconds
        %Tf Time taken to serve the request, in seconds with floating fraction
            in .06f format
        %D  Time taken to serve the request, in microseconds
        %{FOO}i  request.headers['FOO']
        %{FOO}o  response.headers['FOO']
        %{FOO}e  os.environ['FOO']

    """

    LOG_FORMAT_MAP = {
        "a": "remote_address",
        "t": "request_start_time",
        "P": "process_id",
        "r": "first_request_line",
        "s": "response_status",
        "b": "response_size",
        "T": "request_time",
        "Tf": "request_time_frac",
        "D": "request_time_micro",
        "i": "request_header",
        "o": "response_header",
    }

    LOG_FORMAT = '%a %t "%r" %s %b "%{Referer}i" "%{User-Agent}i"'
    FORMAT_RE = re.compile(r"%(\{([A-Za-z0-9\-_]+)\}([ioe])|[atPrsbOD]|Tf?)")
    CLEANUP_RE = re.compile(r"(%[^s])")
    _FORMAT_CACHE = {}  # type: Dict[str, Tuple[str, List[KeyMethod]]]

    def __init__(self, logger: logging.Logger, log_format: str = LOG_FORMAT) -> None:
        """Initialise the logger.

        logger is a logger object to be used for logging.
        log_format is a string with apache compatible log format description.

        """
        super().__init__(logger, log_format=log_format)

        _compiled_format = AccessLogger._FORMAT_CACHE.get(log_format)
        if not _compiled_format:
            _compiled_format = self.compile_format(log_format)
            AccessLogger._FORMAT_CACHE[log_format] = _compiled_format

        self._log_format, self._methods = _compiled_format

    def compile_format(self, log_format: str) -> Tuple[str, List[KeyMethod]]:
        """Translate log_format into form usable by modulo formatting

        All known atoms will be replaced with %s
        Also methods for formatting of those atoms will be added to
        _methods in appropriate order

        For example we have log_format = "%a %t"
        This format will be translated to "%s %s"
        Also contents of _methods will be
        [self._format_a, self._format_t]
        These method will be called and results will be passed
        to translated string format.

        Each _format_* method receive 'args' which is list of arguments
        given to self.log

        Exceptions are _format_e, _format_i and _format_o methods which
        also receive key name (by functools.partial)

        """
        # list of (key, method) tuples, we don't use an OrderedDict as users
        # can repeat the same key more than once
        methods = list()

        for atom in self.FORMAT_RE.findall(log_format):
            if atom[1] == "":
                format_key1 = self.LOG_FORMAT_MAP[atom[0]]
                m = getattr(AccessLogger, "_format_%s" % atom[0])
                key_method = KeyMethod(format_key1, m)
            else:
                format_key2 = (self.LOG_FORMAT_MAP[atom[2]], atom[1])
                m = getattr(AccessLogger, "_format_%s" % atom[2])
                key_method = KeyMethod(format_key2, functools.partial(m, atom[1]))

            methods.append(key_method)

        log_format = self.FORMAT_RE.sub(r"%s", log_format)
        log_format = self.CLEANUP_RE.sub(r"%\1", log_format)
        return log_format, methods

    @staticmethod
    def _format_i(
        key: str, request: BaseRequest, response: StreamResponse, time: float
    ) -> str:
        if request is None:
            return "(no headers)"

        # suboptimal, make istr(key) once
        return request.headers.get(key, "-")

    @staticmethod
    def _format_o(
        key: str, request: BaseRequest, response: StreamResponse, time: float
    ) -> str:
        # suboptimal, make istr(key) once
        return response.headers.get(key, "-")

    @staticmethod
    def _format_a(request: BaseRequest, response: StreamResponse, time: float) -> str:
        if request is None:
            return "-"
        ip = request.remote
        return ip if ip is not None else "-"

    @staticmethod
    def _format_t(request: BaseRequest, response: StreamResponse, time: float) -> str:
        now = datetime.datetime.utcnow()
        start_time = now - datetime.timedelta(seconds=time)
        return start_time.strftime("[%d/%b/%Y:%H:%M:%S +0000]")

    @staticmethod
    def _format_P(request: BaseRequest, response: StreamResponse, time: float) -> str:
        return "<%s>" % os.getpid()

    @staticmethod
    def _format_r(request: BaseRequest, response: StreamResponse, time: float) -> str:
        if request is None:
            return "-"
        return "{} {} HTTP/{}.{}".format(
            request.method,
            request.path_qs,
            request.version.major,
            request.version.minor,
        )

    @staticmethod
    def _format_s(request: BaseRequest, response: StreamResponse, time: float) -> int:
        return response.status

    @staticmethod
    def _format_b(request: BaseRequest, response: StreamResponse, time: float) -> int:
        return response.body_length

    @staticmethod
    def _format_T(request: BaseRequest, response: StreamResponse, time: float) -> str:
        return str(round(time))

    @staticmethod
    def _format_Tf(request: BaseRequest, response: StreamResponse, time: float) -> str:
        return "%06f" % time

    @staticmethod
    def _format_D(request: BaseRequest, response: StreamResponse, time: float) -> str:
        return str(round(time * 1000000))

    def _format_line(
        self, request: BaseRequest, response: StreamResponse, time: float
    ) -> Iterable[Tuple[str, Callable[[BaseRequest, StreamResponse, float], str]]]:
        return [(key, method(request, response, time)) for key, method in self._methods]

    def log(self, request: BaseRequest, response: StreamResponse, time: float) -> None:
        try:
            fmt_info = self._format_line(request, response, time)

            values = list()
            extra = dict()
            for key, value in fmt_info:
                values.append(value)

                if key.__class__ is str:
                    extra[key] = value
                else:
                    k1, k2 = key  # type: ignore[misc]
                    dct = extra.get(k1, {})  # type: ignore[var-annotated,has-type]
                    dct[k2] = value  # type: ignore[index,has-type]
                    extra[k1] = dct  # type: ignore[has-type,assignment]

            self.logger.info(self._log_format % tuple(values), extra=extra)
        except Exception:
            self.logger.exception("Error in logging")

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
28 Feb 2025 12.45 AM
root / 996
0755
.hash
--
25 Jan 2024 4.26 PM
root / 996
0755
__pycache__
--
25 Jan 2024 4.26 PM
root / 996
0755
__init__.py
6.709 KB
14 Nov 2021 8.05 PM
root / 996
0644
_cparser.pxd
4.881 KB
14 Nov 2021 8.05 PM
root / 996
0644
_find_header.c
183.174 KB
14 Nov 2021 8.05 PM
root / 996
0644
_find_header.h
0.166 KB
14 Nov 2021 8.05 PM
root / 996
0644
_find_header.pxd
0.066 KB
14 Nov 2021 8.05 PM
root / 996
0644
_headers.pxi
1.96 KB
14 Nov 2021 8.05 PM
root / 996
0644
_helpers.c
207.99 KB
14 Nov 2021 8.05 PM
root / 996
0644
_helpers.cpython-37m-x86_64-linux-gnu.so
66.117 KB
14 Nov 2023 11.36 AM
root / 996
0755
_helpers.pyi
0.197 KB
14 Nov 2021 8.05 PM
root / 996
0644
_helpers.pyx
1.024 KB
14 Nov 2021 8.05 PM
root / 996
0644
_http_parser.c
955.261 KB
14 Nov 2021 8.05 PM
root / 996
0644
_http_parser.cpython-37m-x86_64-linux-gnu.so
523.539 KB
14 Nov 2023 11.36 AM
root / 996
0755
_http_parser.pyx
25.948 KB
14 Nov 2021 8.05 PM
root / 996
0644
_http_writer.c
216.084 KB
14 Nov 2021 8.05 PM
root / 996
0644
_http_writer.cpython-37m-x86_64-linux-gnu.so
61.203 KB
14 Nov 2023 11.36 AM
root / 996
0755
_http_writer.pyx
4.468 KB
14 Nov 2021 8.05 PM
root / 996
0644
_websocket.c
135.176 KB
14 Nov 2021 8.05 PM
root / 996
0644
_websocket.cpython-37m-x86_64-linux-gnu.so
37.367 KB
14 Nov 2023 11.36 AM
root / 996
0755
_websocket.pyx
1.524 KB
14 Nov 2021 8.05 PM
root / 996
0644
abc.py
5.384 KB
14 Nov 2021 8.05 PM
root / 996
0644
base_protocol.py
2.637 KB
14 Nov 2021 8.05 PM
root / 996
0644
client.py
43.873 KB
14 Nov 2021 8.05 PM
root / 996
0644
client_exceptions.py
9.06 KB
14 Nov 2021 8.05 PM
root / 996
0644
client_proto.py
8.004 KB
14 Nov 2021 8.05 PM
root / 996
0644
client_reqrep.py
36.021 KB
14 Nov 2021 8.05 PM
root / 996
0644
client_ws.py
10.293 KB
14 Nov 2021 8.05 PM
root / 996
0644
connector.py
49.662 KB
14 Nov 2021 8.05 PM
root / 996
0644
cookiejar.py
13.252 KB
14 Nov 2021 8.05 PM
root / 996
0644
formdata.py
5.979 KB
14 Nov 2021 8.05 PM
root / 996
0644
hdrs.py
4.613 KB
14 Nov 2021 8.05 PM
root / 996
0644
helpers.py
25.628 KB
14 Nov 2021 8.05 PM
root / 996
0644
http.py
1.781 KB
14 Nov 2021 8.05 PM
root / 996
0644
http_exceptions.py
2.525 KB
14 Nov 2021 8.05 PM
root / 996
0644
http_parser.py
31.826 KB
14 Nov 2021 8.05 PM
root / 996
0644
http_websocket.py
24.765 KB
14 Nov 2021 8.05 PM
root / 996
0644
http_writer.py
5.836 KB
14 Nov 2021 8.05 PM
root / 996
0644
locks.py
1.125 KB
14 Nov 2021 8.05 PM
root / 996
0644
log.py
0.317 KB
14 Nov 2021 8.05 PM
root / 996
0644
multipart.py
31.677 KB
14 Nov 2021 8.05 PM
root / 996
0644
payload.py
13.379 KB
14 Nov 2021 8.05 PM
root / 996
0644
payload_streamer.py
2.063 KB
14 Nov 2021 8.05 PM
root / 996
0644
py.typed
0.007 KB
14 Nov 2021 8.05 PM
root / 996
0644
pytest_plugin.py
11.496 KB
14 Nov 2021 8.05 PM
root / 996
0644
resolver.py
4.973 KB
14 Nov 2021 8.05 PM
root / 996
0644
streams.py
20.352 KB
14 Nov 2021 8.05 PM
root / 996
0644
tcp_helpers.py
0.939 KB
14 Nov 2021 8.05 PM
root / 996
0644
test_utils.py
20.722 KB
14 Nov 2021 8.05 PM
root / 996
0644
tracing.py
14.946 KB
14 Nov 2021 8.05 PM
root / 996
0644
typedefs.py
1.725 KB
14 Nov 2021 8.05 PM
root / 996
0644
web.py
17.509 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_app.py
16.863 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_exceptions.py
9.869 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_fileresponse.py
10.531 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_log.py
7.388 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_middlewares.py
4.04 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_protocol.py
22.02 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_request.py
27.234 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_response.py
26.921 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_routedef.py
5.898 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_runner.py
10.927 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_server.py
2.01 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_urldispatcher.py
38.62 KB
14 Nov 2021 8.05 PM
root / 996
0644
web_ws.py
16.854 KB
14 Nov 2021 8.05 PM
root / 996
0644
worker.py
8.573 KB
14 Nov 2021 8.05 PM
root / 996
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF