|
| 1 | +from typing import Dict, List, Optional, Union |
| 2 | + |
| 3 | +from aws_lambda_powertools.shared.cookies import Cookie |
| 4 | + |
| 5 | + |
| 6 | +class Response: |
| 7 | + """Response data class that provides greater control over what is returned from the proxy event""" |
| 8 | + |
| 9 | + def __init__( |
| 10 | + self, |
| 11 | + status_code: int, |
| 12 | + content_type: Optional[str] = None, |
| 13 | + body: Union[str, bytes, None] = None, |
| 14 | + headers: Optional[Dict[str, Union[str, List[str]]]] = None, |
| 15 | + cookies: Optional[List[Cookie]] = None, |
| 16 | + compress: Optional[bool] = None, |
| 17 | + ): |
| 18 | + """ |
| 19 | +
|
| 20 | + Parameters |
| 21 | + ---------- |
| 22 | + status_code: int |
| 23 | + Http status code, example 200 |
| 24 | + content_type: str |
| 25 | + Optionally set the Content-Type header, example "application/json". Note this will be merged into any |
| 26 | + provided http headers |
| 27 | + body: Union[str, bytes, None] |
| 28 | + Optionally set the response body. Note: bytes body will be automatically base64 encoded |
| 29 | + headers: dict[str, Union[str, List[str]]] |
| 30 | + Optionally set specific http headers. Setting "Content-Type" here would override the `content_type` value. |
| 31 | + cookies: list[Cookie] |
| 32 | + Optionally set cookies. |
| 33 | + """ |
| 34 | + self.status_code = status_code |
| 35 | + self.body = body |
| 36 | + self.base64_encoded = False |
| 37 | + self.headers: Dict[str, Union[str, List[str]]] = headers if headers else {} |
| 38 | + self.cookies = cookies or [] |
| 39 | + self.compress = compress |
| 40 | + if content_type: |
| 41 | + self.headers.setdefault("Content-Type", content_type) |
0 commit comments