$99 GRAYBYTE WORDPRESS FILE MANAGER $62

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

/opt/alt/python311/lib/python3.11/site-packages/botocore/

HOME
Current File : /opt/alt/python311/lib/python3.11/site-packages/botocore//compress.py
# Copyright 2023 Amazon.com, Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
# http://aws.amazon.com/apache2.0/
#
# or in the "license" file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.
"""
NOTE: All functions in this module are considered private and are
subject to abrupt breaking changes. Please do not use them directly.

"""

import io
import logging
from gzip import GzipFile
from gzip import compress as gzip_compress

from botocore.compat import urlencode
from botocore.utils import determine_content_length

logger = logging.getLogger(__name__)


def maybe_compress_request(config, request_dict, operation_model):
    """Attempt to compress the request body using the modeled encodings."""
    if _should_compress_request(config, request_dict, operation_model):
        for encoding in operation_model.request_compression['encodings']:
            encoder = COMPRESSION_MAPPING.get(encoding)
            if encoder is not None:
                logger.debug('Compressing request with %s encoding.', encoding)
                request_dict['body'] = encoder(request_dict['body'])
                _set_compression_header(request_dict['headers'], encoding)
                return
            else:
                logger.debug('Unsupported compression encoding: %s', encoding)


def _should_compress_request(config, request_dict, operation_model):
    if (
        config.disable_request_compression is not True
        and config.signature_version != 'v2'
        and operation_model.request_compression is not None
    ):
        if not _is_compressible_type(request_dict):
            body_type = type(request_dict['body'])
            log_msg = 'Body type %s does not support compression.'
            logger.debug(log_msg, body_type)
            return False

        if operation_model.has_streaming_input:
            streaming_input = operation_model.get_streaming_input()
            streaming_metadata = streaming_input.metadata
            return 'requiresLength' not in streaming_metadata

        body_size = _get_body_size(request_dict['body'])
        min_size = config.request_min_compression_size_bytes
        return min_size <= body_size

    return False


def _is_compressible_type(request_dict):
    body = request_dict['body']
    # Coerce dict to a format compatible with compression.
    if isinstance(body, dict):
        body = urlencode(body, doseq=True, encoding='utf-8').encode('utf-8')
        request_dict['body'] = body
    is_supported_type = isinstance(body, (str, bytes, bytearray))
    return is_supported_type or hasattr(body, 'read')


def _get_body_size(body):
    size = determine_content_length(body)
    if size is None:
        logger.debug(
            'Unable to get length of the request body: %s. '
            'Skipping compression.',
            body,
        )
        size = 0
    return size


def _gzip_compress_body(body):
    if isinstance(body, str):
        return gzip_compress(body.encode('utf-8'))
    elif isinstance(body, (bytes, bytearray)):
        return gzip_compress(body)
    elif hasattr(body, 'read'):
        if hasattr(body, 'seek') and hasattr(body, 'tell'):
            current_position = body.tell()
            compressed_obj = _gzip_compress_fileobj(body)
            body.seek(current_position)
            return compressed_obj
        return _gzip_compress_fileobj(body)


def _gzip_compress_fileobj(body):
    compressed_obj = io.BytesIO()
    with GzipFile(fileobj=compressed_obj, mode='wb') as gz:
        while True:
            chunk = body.read(8192)
            if not chunk:
                break
            if isinstance(chunk, str):
                chunk = chunk.encode('utf-8')
            gz.write(chunk)
    compressed_obj.seek(0)
    return compressed_obj


def _set_compression_header(headers, encoding):
    ce_header = headers.get('Content-Encoding')
    if ce_header is None:
        headers['Content-Encoding'] = encoding
    else:
        headers['Content-Encoding'] = f'{ce_header},{encoding}'


COMPRESSION_MAPPING = {'gzip': _gzip_compress_body}

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
5 Sep 2025 9.32 AM
root / 996
0755
__pycache__
--
8 May 2024 6.34 PM
root / root
0755
crt
--
8 May 2024 6.34 PM
root / root
0755
data
--
8 May 2024 6.34 PM
root / root
0755
docs
--
8 May 2024 6.34 PM
root / root
0755
retries
--
8 May 2024 6.34 PM
root / root
0755
vendored
--
8 May 2024 6.34 PM
root / root
0755
__init__.py
4.8 KB
8 May 2024 6.34 PM
root / root
0644
args.py
29.922 KB
8 May 2024 6.34 PM
root / root
0644
auth.py
42.776 KB
8 May 2024 6.34 PM
root / root
0644
awsrequest.py
22.613 KB
8 May 2024 6.34 PM
root / root
0644
cacert.pem
260.368 KB
8 May 2024 6.34 PM
root / root
0644
client.py
50.54 KB
8 May 2024 6.34 PM
root / root
0644
compat.py
10.831 KB
8 May 2024 6.34 PM
root / root
0644
compress.py
4.326 KB
8 May 2024 6.34 PM
root / root
0644
config.py
15.235 KB
8 May 2024 6.34 PM
root / root
0644
configloader.py
9.804 KB
8 May 2024 6.34 PM
root / root
0644
configprovider.py
36.357 KB
8 May 2024 6.34 PM
root / root
0644
credentials.py
82.808 KB
8 May 2024 6.34 PM
root / root
0644
discovery.py
10.815 KB
8 May 2024 6.34 PM
root / root
0644
endpoint.py
16.056 KB
8 May 2024 6.34 PM
root / root
0644
endpoint_provider.py
22.396 KB
8 May 2024 6.34 PM
root / root
0644
errorfactory.py
3.635 KB
8 May 2024 6.34 PM
root / root
0644
eventstream.py
19.97 KB
8 May 2024 6.34 PM
root / root
0644
exceptions.py
22.27 KB
8 May 2024 6.34 PM
root / root
0644
handlers.py
53.992 KB
8 May 2024 6.34 PM
root / root
0644
history.py
1.703 KB
8 May 2024 6.34 PM
root / root
0644
hooks.py
24.473 KB
8 May 2024 6.34 PM
root / root
0644
httpchecksum.py
15.91 KB
8 May 2024 6.34 PM
root / root
0644
httpsession.py
18.146 KB
8 May 2024 6.34 PM
root / root
0644
loaders.py
18.392 KB
8 May 2024 6.34 PM
root / root
0644
model.py
29.901 KB
8 May 2024 6.34 PM
root / root
0644
monitoring.py
20.114 KB
8 May 2024 6.34 PM
root / root
0644
paginate.py
26.75 KB
8 May 2024 6.34 PM
root / root
0644
parsers.py
44.538 KB
8 May 2024 6.34 PM
root / root
0644
regions.py
31.666 KB
8 May 2024 6.34 PM
root / root
0644
response.py
7.058 KB
8 May 2024 6.34 PM
root / root
0644
retryhandler.py
14.355 KB
8 May 2024 6.34 PM
root / root
0644
serialize.py
32.346 KB
8 May 2024 6.34 PM
root / root
0644
session.py
48.031 KB
8 May 2024 6.34 PM
root / root
0644
signers.py
30.239 KB
8 May 2024 6.34 PM
root / root
0644
stub.py
14.797 KB
8 May 2024 6.34 PM
root / root
0644
tokens.py
10.654 KB
8 May 2024 6.34 PM
root / root
0644
translate.py
3.326 KB
8 May 2024 6.34 PM
root / root
0644
useragent.py
17.876 KB
8 May 2024 6.34 PM
root / root
0644
utils.py
131.899 KB
8 May 2024 6.34 PM
root / root
0644
validate.py
13.444 KB
8 May 2024 6.34 PM
root / root
0644
waiter.py
13.955 KB
8 May 2024 6.34 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF