File: index.rst

package info (click to toggle)
litestar 2.19.0-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 12,500 kB
  • sloc: python: 70,169; makefile: 254; javascript: 105; sh: 60
file content (61 lines) | stat: -rw-r--r-- 2,661 bytes parent folder | download
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
Data Transfer Object Tutorial
=============================

.. admonition:: Who is this tutorial for?
    :class: info

    This tutorial is intended to familiarize you with the basic concepts of Litestar's
    Data Transfer Objects (DTOs). It is assumed that you are already familiar with
    Litestar and fundamental concepts such as route handlers. If not, it is recommended
    to first follow the
    `Developing a basic TODO application <../todo-app>`_ tutorial.

In this tutorial, we will walk through the process of modelling a simple data structure, and demonstrate how Litestar's
DTO factories can be used to help us build flexible applications. Lets get started!

.. literalinclude:: /examples/data_transfer_objects/factory/tutorial/initial_pattern.py
    :language: python
    :caption: ``app.py``

In this script, we define a data model, a route handler and an application instance.

Our data model is a Python :func:`dataclass <dataclasses.dataclass>` called ``Person`` which has three attributes:
``name``, ``age``, and ``email``.

The function called ``get_person`` that is decorated with :class:`@get() <litestar.handlers.get>` is a route handler
with path ``/person/{name:str}``, that serves `GET <https://developer.mozilla.org/en-US/docs/Web/HTTP/Methods/GET>`_
requests. In the path, ``{name:str}`` represents a path parameter called ``name`` with a string type. The route handler
receives the name from the path parameter and returns a ``Person`` object.

Finally, we create an application instance and register the route handler with it.

In Litestar, this pattern works "out-of-the-box" - that is, returning :func:`dataclass <dataclasses.dataclass>`
instances from handlers is natively supported. Litestar will take that dataclass instance, and transform it into
:class:`bytes` that can be sent over the network.

Lets run it and see for ourselves!

Save the above script as ``app.py``, run it using the ``litestar run`` command, and then visit
`<http://localhost:8000/person/peter>`_ in your browser. You should see the
following:

.. image:: images/initial_pattern.png
    :align: center

However, real-world applications are rarely this simple. What if we want to restrict the information about users that we
expose after they have been created? For example, we may want to hide the user's email address from the response. This
is where Data Transfer Objects come in.

.. toctree::
    :hidden:

    01-simple-dto-exclude
    02-nested-exclude
    03-nested-collection-exclude
    04-max-nested-depth
    05-renaming-fields
    06-receiving-data
    07-read-only-fields
    08-dto-data
    09-updating
    10-layered-dto-declarations