Skip to content

Commit

Permalink
replace json response with ORJSON response (#417)
Browse files Browse the repository at this point in the history
* Changes:
- JSONResponse is internally represented by ORJSONResponse
  • Loading branch information
devkral authored Oct 21, 2024
1 parent 6d32153 commit aa1292a
Show file tree
Hide file tree
Showing 6 changed files with 25 additions and 25 deletions.
25 changes: 13 additions & 12 deletions docs/en/docs/responses.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ The available responses from `Esmerald` are:

* `Response`
* `JSON`
* `OrJSON`
* `ORJSON`
* `UJSON`
* `Template`
* `Redirect`
Expand All @@ -27,14 +27,14 @@ The available responses from `Esmerald` are:

## Important requirements

Some responses use extra dependencies, such as [UJSON](#ujson) and [OrJSON](#orjson). To use these
Some responses use extra dependencies, such as [UJSON](#ujson) and [ORJSON](#orjson). To use these
responses, you need to install:

```shell
$ pip install ujson orjson
```

This will allow you to use the [OrJSON](#orjson) and [UJSON](#ujson) as well as the
This will allow you to use the [ORJSON](#orjson) and [UJSON](#ujson) as well as the
[UJSONResponse](#ujsonresponse) and [ORJSONResponse](#orjsonresponse) in your projects.

### Response
Expand All @@ -61,7 +61,7 @@ Check out the [API Reference for Response](./references/responses/response.md) f
### JSON

The classic JSON response for 99% of the responses used nowaday. The `JSON` returns a
`JSONResponse`.
`JSONResponse` (ORJSON).

```python
{!> ../../../docs_src/responses/json.py !}
Expand All @@ -71,25 +71,20 @@ The classic JSON response for 99% of the responses used nowaday. The `JSON` retu

Check out the [API Reference for JSON](./references/responses/json.md) for more details.

#### JSONResponse
### JSONResponse (Lilya)

You can always use directly the `JSONResponse` from Lilya without using the Esmerald wrapper.

```python
from lilya.responses import JSONResponse as JSONResponse
```

or alternatively

```python
from esmerald.responses import JSONResponse
```

## API Reference

Check out the [API Reference for JSONResponse](./references/responses/json-response.md) for more details.

### OrJSON
### ORJSON

Super fast JSON serialization/deserialization response.

Expand All @@ -101,7 +96,7 @@ Super fast JSON serialization/deserialization response.
Please read the [important requirements](#important-requirements) before using this response.

!!! Check
More details about the ORJSOM can be [found here](https://github.com/ijl/orjson).
More details about the ORJSON can be [found here](https://github.com/ijl/orjson).

## API Reference

Expand All @@ -115,6 +110,12 @@ You can always use directly the `ORJSONResponse` from Esmerald without using the
from esmerald.responses.encoders import ORJSONResponse
```

or alternatively (we alias JSONResponse to ORJSONResponse because it is faster)

```python
from esmerald.responses import JSONResponse
```

## API Reference

Check out the [API Reference for ORJSONResponse](./references/responses/orjson-response.md) for more details.
Expand Down
2 changes: 1 addition & 1 deletion esmerald/responses/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,12 @@
Error,
FileResponse,
HTMLResponse,
JSONResponse,
LilyaResponse,
PlainText,
Response,
StreamingResponse,
)
from .encoders import ORJSONResponse as JSONResponse
from .template import TemplateResponse

__all__ = [
Expand Down
1 change: 0 additions & 1 deletion esmerald/responses/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -163,7 +163,6 @@ def __init__(
),
] = None,
) -> None:

super().__init__(
content=content,
status_code=status_code,
Expand Down
14 changes: 5 additions & 9 deletions esmerald/responses/encoders.py
Original file line number Diff line number Diff line change
@@ -1,15 +1,9 @@
from typing import Any

from lilya.responses import JSONResponse as JSONResponse
import orjson

from esmerald.responses.json import BaseJSONResponse

try:
import orjson
from orjson import OPT_OMIT_MICROSECONDS, OPT_SERIALIZE_NUMPY
except ImportError: # pragma: no cover
orjson = None

try:
import ujson
except ImportError: # pragma: no cover
Expand All @@ -24,11 +18,10 @@ class ORJSONResponse(BaseJSONResponse):
"""

def make_response(self, content: Any) -> bytes:
assert orjson is not None, "You must install the encoders or orjson to use ORJSONResponse"
return orjson.dumps(
content,
default=self.transform,
option=OPT_SERIALIZE_NUMPY | OPT_OMIT_MICROSECONDS,
option=orjson.OPT_SERIALIZE_NUMPY | orjson.OPT_OMIT_MICROSECONDS,
)


Expand All @@ -42,3 +35,6 @@ class UJSONResponse(BaseJSONResponse):
def make_response(self, content: Any) -> bytes:
assert ujson is not None, "You must install the encoders or ujson to use UJSONResponse"
return ujson.dumps(content, ensure_ascii=False).encode("utf-8")


__all__ = ["ORJSONResponse", "UJSONResponse"]
6 changes: 5 additions & 1 deletion esmerald/responses/json.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
from typing import Any, Dict, cast

from lilya.responses import JSONResponse

from esmerald.encoders import json_encoder
from esmerald.responses import JSONResponse as JSONResponse # noqa


class BaseJSONResponse(JSONResponse):
Expand All @@ -16,3 +17,6 @@ def transform(value: Any) -> Dict[str, Any]: # pragma: no cover
a dict().
"""
return cast(Dict[str, Any], json_encoder(value))


__all__ = ["BaseJSONResponse"]
2 changes: 1 addition & 1 deletion esmerald/routing/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@
from esmerald.injector import Inject
from esmerald.permissions.utils import continue_or_raise_permission_exception
from esmerald.requests import Request
from esmerald.responses import JSONResponse, Response
from esmerald.responses.base import JSONResponse, Response
from esmerald.routing.apis.base import View
from esmerald.transformers.model import (
TransformerModel,
Expand Down

0 comments on commit aa1292a

Please sign in to comment.