Home / File/ tutorial001_py39.py — fastapi Source File

tutorial001_py39.py — fastapi Source File

Architecture documentation for tutorial001_py39.py, a python file in the fastapi codebase. 3 imports, 0 dependents.

File python FastAPI Applications 3 imports 2 functions 3 classes

Entity Profile

Dependency Diagram

graph LR
  d49c7609_2f45_09fa_af5f_de5d6d4d7067["tutorial001_py39.py"]
  0dda2280_3359_8460_301c_e98c77e78185["typing"]
  d49c7609_2f45_09fa_af5f_de5d6d4d7067 --> 0dda2280_3359_8460_301c_e98c77e78185
  534f6e44_61b8_3c38_8b89_6934a6df9802["__init__.py"]
  d49c7609_2f45_09fa_af5f_de5d6d4d7067 --> 534f6e44_61b8_3c38_8b89_6934a6df9802
  6913fbd4_39df_d14b_44bb_522e99b65b90["pydantic"]
  d49c7609_2f45_09fa_af5f_de5d6d4d7067 --> 6913fbd4_39df_d14b_44bb_522e99b65b90
  style d49c7609_2f45_09fa_af5f_de5d6d4d7067 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

from typing import Union

from fastapi import APIRouter, FastAPI
from pydantic import BaseModel, HttpUrl

app = FastAPI()


class Invoice(BaseModel):
    id: str
    title: Union[str, None] = None
    customer: str
    total: float


class InvoiceEvent(BaseModel):
    description: str
    paid: bool


class InvoiceEventReceived(BaseModel):
    ok: bool


invoices_callback_router = APIRouter()


@invoices_callback_router.post(
    "{$callback_url}/invoices/{$request.body.id}", response_model=InvoiceEventReceived
)
def invoice_notification(body: InvoiceEvent):
    pass


@app.post("/invoices/", callbacks=invoices_callback_router.routes)
def create_invoice(invoice: Invoice, callback_url: Union[HttpUrl, None] = None):
    """
    Create an invoice.

    This will (let's imagine) let the API user (some external developer) create an
    invoice.

    And this path operation will:

    * Send the invoice to the client.
    * Collect the money from the client.
    * Send a notification back to the API user (the external developer), as a callback.
        * At this point is that the API will somehow send a POST request to the
            external API with the notification of the invoice event
            (e.g. "payment successful").
    """
    # Send the invoice, collect the money, send the notification (the callback)
    return {"msg": "Invoice received"}

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does tutorial001_py39.py do?
tutorial001_py39.py is a source file in the fastapi codebase, written in python. It belongs to the FastAPI domain, Applications subdomain.
What functions are defined in tutorial001_py39.py?
tutorial001_py39.py defines 2 function(s): create_invoice, invoice_notification.
What does tutorial001_py39.py depend on?
tutorial001_py39.py imports 3 module(s): __init__.py, pydantic, typing.
Where is tutorial001_py39.py in the architecture?
tutorial001_py39.py is located at docs_src/openapi_callbacks/tutorial001_py39.py (domain: FastAPI, subdomain: Applications, directory: docs_src/openapi_callbacks).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free