-
Notifications
You must be signed in to change notification settings - Fork 11
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
72 changed files
with
1,573 additions
and
1,159 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
import time | ||
from functools import partial | ||
from typing import Annotated | ||
|
||
from fastapi import Depends, Request | ||
from http_client import HttpClient, RequestBuilder | ||
from http_client.request_response import USER_AGENT_HEADER | ||
|
||
from frontik import request_context | ||
from frontik.auth import DEBUG_AUTH_HEADER_NAME | ||
from frontik.debug import DEBUG_HEADER_NAME | ||
from frontik.timeout_tracking import get_timeout_checker | ||
from frontik.util import make_url | ||
|
||
OUTER_TIMEOUT_MS_HEADER = 'X-Outer-Timeout-Ms' | ||
|
||
|
||
def modify_http_client_request(request: Request, balanced_request: RequestBuilder) -> None: | ||
balanced_request.headers['x-request-id'] = request_context.get_request_id() | ||
balanced_request.headers[OUTER_TIMEOUT_MS_HEADER] = f'{balanced_request.request_timeout * 1000:.0f}' | ||
|
||
outer_timeout = request.headers.get(OUTER_TIMEOUT_MS_HEADER.lower()) | ||
if outer_timeout: | ||
timeout_checker = get_timeout_checker( | ||
request.headers.get(USER_AGENT_HEADER.lower()), | ||
float(outer_timeout), | ||
request['start_time'], | ||
) | ||
timeout_checker.check(balanced_request) | ||
|
||
if request['pass_debug']: | ||
balanced_request.headers[DEBUG_HEADER_NAME] = 'true' | ||
|
||
# debug_timestamp is added to avoid caching of debug responses | ||
balanced_request.path = make_url(balanced_request.path, debug_timestamp=int(time.time())) | ||
|
||
for header_name in ('Authorization', DEBUG_AUTH_HEADER_NAME): | ||
authorization = request.headers.get(header_name.lower()) | ||
if authorization is not None: | ||
balanced_request.headers[header_name] = authorization | ||
|
||
|
||
def get_http_client(modify_request_hook=None): | ||
def _get_http_client(request: Request) -> HttpClient: | ||
hook = modify_request_hook or partial(modify_http_client_request, request) | ||
|
||
http_client = request['http_client_factory'].get_http_client( | ||
modify_http_request_hook=hook, | ||
debug_enabled=request['debug_enabled'], | ||
) | ||
|
||
return http_client | ||
|
||
return _get_http_client | ||
|
||
|
||
HttpClientT = Annotated[HttpClient, Depends(get_http_client())] |
Oops, something went wrong.