-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathasync_client.py
More file actions
62 lines (52 loc) · 1.73 KB
/
async_client.py
File metadata and controls
62 lines (52 loc) · 1.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import json
from typing import Any, Dict
import httpx
class AsyncClient:
"""
Asynchronous client for making authenticated requests to Openapi endpoints.
Suitable for use with FastAPI, aiohttp, etc.
"""
def __init__(self, token: str):
self.client = httpx.AsyncClient()
self.auth_header: str = f"Bearer {token}"
self.headers: Dict[str, str] = {
"Authorization": self.auth_header,
"Content-Type": "application/json",
}
async def __aenter__(self):
"""Enable use as an asynchronous context manager."""
return self
async def __aexit__(self, exc_type, exc_val, exc_tb):
"""Ensure the underlying HTTP client is closed on exit (async)."""
await self.client.aclose()
async def aclose(self):
"""Manually close the underlying HTTP client (async)."""
await self.client.aclose()
async def request(
self,
method: str = "GET",
url: str = None,
payload: Dict[str, Any] = None,
params: Dict[str, Any] = None,
) -> Dict[str, Any]:
"""
Make an asynchronous HTTP request to the specified Openapi endpoint.
"""
payload = payload or {}
params = params or {}
url = url or ""
resp = await self.client.request(
method=method,
url=url,
headers=self.headers,
json=payload,
params=params,
)
data = resp.json()
# Handle cases where the API might return a JSON-encoded string instead of an object
if isinstance(data, str):
try:
data = json.loads(data)
except json.JSONDecodeError:
pass
return data