python3-commons 0.6.11__tar.gz → 0.6.13__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {python3_commons-0.6.11/src/python3_commons.egg-info → python3_commons-0.6.13}/PKG-INFO +1 -1
- {python3_commons-0.6.11 → python3_commons-0.6.13}/pyproject.toml +1 -1
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/api_client.py +32 -5
- {python3_commons-0.6.11 → python3_commons-0.6.13/src/python3_commons.egg-info}/PKG-INFO +1 -1
- {python3_commons-0.6.11 → python3_commons-0.6.13}/.coveragerc +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/.github/workflows/python-publish.yaml +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/.gitignore +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/AUTHORS.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/CHANGELOG.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/LICENSE +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/README.md +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/README.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/Makefile +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/_static/.gitignore +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/authors.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/changelog.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/conf.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/index.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/docs/license.rst +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/requirements.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/requirements_dev.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/requirements_test.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/setup.cfg +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/setup.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/__init__.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/audit.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/conf.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/db.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/fs.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/helpers.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/logging/__init__.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/logging/filters.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/logging/formatters.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/object_storage.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/__init__.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/json.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/msgpack.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/msgspec.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/SOURCES.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/dependency_links.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/requires.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/top_level.txt +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/tests/conftest.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/tests/test_audit.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/tests/test_helpers.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/tests/test_msgpack.py +0 -0
- {python3_commons-0.6.11 → python3_commons-0.6.13}/tests/test_msgspec.py +0 -0
@@ -2,9 +2,9 @@ from contextlib import asynccontextmanager
|
|
2
2
|
from datetime import datetime, UTC
|
3
3
|
from json import dumps
|
4
4
|
from typing import AsyncGenerator, Literal, Mapping, Sequence
|
5
|
+
from uuid import uuid4
|
5
6
|
|
6
|
-
from aiohttp import ClientSession, client_exceptions
|
7
|
-
from aiohttp.web_response import Response
|
7
|
+
from aiohttp import ClientResponse, ClientSession, client_exceptions
|
8
8
|
from pydantic import HttpUrl
|
9
9
|
|
10
10
|
from python3_commons import audit
|
@@ -13,6 +13,26 @@ from python3_commons.helpers import request_to_curl
|
|
13
13
|
from python3_commons.serializers.json import CustomJSONEncoder
|
14
14
|
|
15
15
|
|
16
|
+
async def _store_response_for_audit(
|
17
|
+
response: ClientResponse,
|
18
|
+
audit_name: str,
|
19
|
+
uri_path: str,
|
20
|
+
method: str,
|
21
|
+
request_id: str
|
22
|
+
):
|
23
|
+
response_text = await response.text()
|
24
|
+
|
25
|
+
now = datetime.now(tz=UTC)
|
26
|
+
date_path = now.strftime('%Y/%m/%d')
|
27
|
+
timestamp = now.strftime('%H%M%S_%f')
|
28
|
+
|
29
|
+
await audit.write_audit_data(
|
30
|
+
s3_settings,
|
31
|
+
f'{date_path}/{audit_name}/{uri_path}/{method}_{timestamp}_{request_id}_response.txt',
|
32
|
+
response_text.encode('utf-8')
|
33
|
+
)
|
34
|
+
|
35
|
+
|
16
36
|
@asynccontextmanager
|
17
37
|
async def request(
|
18
38
|
client: ClientSession,
|
@@ -24,13 +44,14 @@ async def request(
|
|
24
44
|
json: Mapping | Sequence | str | None = None,
|
25
45
|
data: bytes | None = None,
|
26
46
|
audit_name: str | None = None
|
27
|
-
) -> AsyncGenerator[
|
47
|
+
) -> AsyncGenerator[ClientResponse]:
|
28
48
|
now = datetime.now(tz=UTC)
|
29
49
|
date_path = now.strftime('%Y/%m/%d')
|
30
50
|
timestamp = now.strftime('%H%M%S_%f')
|
51
|
+
request_id = str(uuid4())[-12:]
|
31
52
|
uri_path = uri[:-1] if uri.endswith('/') else uri
|
32
53
|
uri_path = uri_path[1:] if uri_path.startswith('/') else uri_path
|
33
|
-
url = f'{base_url}{uri}'
|
54
|
+
url = f'{u[:-1] if (u := str(base_url).endswith('/')) else u}{uri}'
|
34
55
|
|
35
56
|
if audit_name:
|
36
57
|
curl_request = None
|
@@ -44,7 +65,7 @@ async def request(
|
|
44
65
|
if curl_request:
|
45
66
|
await audit.write_audit_data(
|
46
67
|
s3_settings,
|
47
|
-
f'{date_path}/{audit_name}/{uri_path}/{method}_{timestamp}_request.txt',
|
68
|
+
f'{date_path}/{audit_name}/{uri_path}/{method}_{timestamp}_{request_id}_request.txt',
|
48
69
|
curl_request.encode('utf-8')
|
49
70
|
)
|
50
71
|
client_method = getattr(client, method)
|
@@ -52,6 +73,9 @@ async def request(
|
|
52
73
|
try:
|
53
74
|
if method == 'get':
|
54
75
|
async with client_method(url, params=query) as response:
|
76
|
+
if audit_name:
|
77
|
+
await _store_response_for_audit(response, audit_name, uri_path, method, request_id)
|
78
|
+
|
55
79
|
yield response
|
56
80
|
else:
|
57
81
|
if json:
|
@@ -63,6 +87,9 @@ async def request(
|
|
63
87
|
headers = {'Content-Type': 'application/json'}
|
64
88
|
|
65
89
|
async with client_method(url, params=query, data=data, headers=headers) as response:
|
90
|
+
if audit_name:
|
91
|
+
await _store_response_for_audit(response, audit_name, uri_path, method, request_id)
|
92
|
+
|
66
93
|
yield response
|
67
94
|
except client_exceptions.ClientOSError as e:
|
68
95
|
if e.errno == 32:
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/__init__.py
RENAMED
File without changes
|
File without changes
|
{python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/msgpack.py
RENAMED
File without changes
|
{python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons/serializers/msgspec.py
RENAMED
File without changes
|
File without changes
|
{python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/dependency_links.txt
RENAMED
File without changes
|
File without changes
|
{python3_commons-0.6.11 → python3_commons-0.6.13}/src/python3_commons.egg-info/top_level.txt
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|