Home / File/ tutorial002_py310.py — fastapi Source File

tutorial002_py310.py — fastapi Source File

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

File python FastAPI Responses 2 imports 8 functions 5 classes

Entity Profile

Dependency Diagram

graph LR
  7bc09ac4_0d8b_e939_5642_9fd3f47511cc["tutorial002_py310.py"]
  534f6e44_61b8_3c38_8b89_6934a6df9802["__init__.py"]
  7bc09ac4_0d8b_e939_5642_9fd3f47511cc --> 534f6e44_61b8_3c38_8b89_6934a6df9802
  bf11c16a_04e7_1fd0_b317_a1196fc34aad["sqlmodel"]
  7bc09ac4_0d8b_e939_5642_9fd3f47511cc --> bf11c16a_04e7_1fd0_b317_a1196fc34aad
  style 7bc09ac4_0d8b_e939_5642_9fd3f47511cc fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

from fastapi import Depends, FastAPI, HTTPException, Query
from sqlmodel import Field, Session, SQLModel, create_engine, select


class HeroBase(SQLModel):
    name: str = Field(index=True)
    age: int | None = Field(default=None, index=True)


class Hero(HeroBase, table=True):
    id: int | None = Field(default=None, primary_key=True)
    secret_name: str


class HeroPublic(HeroBase):
    id: int


class HeroCreate(HeroBase):
    secret_name: str


class HeroUpdate(HeroBase):
    name: str | None = None
    age: int | None = None
    secret_name: str | None = None


sqlite_file_name = "database.db"
sqlite_url = f"sqlite:///{sqlite_file_name}"

connect_args = {"check_same_thread": False}
engine = create_engine(sqlite_url, connect_args=connect_args)


def create_db_and_tables():
    SQLModel.metadata.create_all(engine)


def get_session():
    with Session(engine) as session:
        yield session


app = FastAPI()


@app.on_event("startup")
def on_startup():
    create_db_and_tables()


@app.post("/heroes/", response_model=HeroPublic)
def create_hero(hero: HeroCreate, session: Session = Depends(get_session)):
    db_hero = Hero.model_validate(hero)
    session.add(db_hero)
    session.commit()
    session.refresh(db_hero)
    return db_hero


@app.get("/heroes/", response_model=list[HeroPublic])
def read_heroes(
    session: Session = Depends(get_session),
    offset: int = 0,
    limit: int = Query(default=100, le=100),
):
    heroes = session.exec(select(Hero).offset(offset).limit(limit)).all()
    return heroes


@app.get("/heroes/{hero_id}", response_model=HeroPublic)
def read_hero(hero_id: int, session: Session = Depends(get_session)):
    hero = session.get(Hero, hero_id)
    if not hero:
        raise HTTPException(status_code=404, detail="Hero not found")
    return hero


@app.patch("/heroes/{hero_id}", response_model=HeroPublic)
def update_hero(
    hero_id: int, hero: HeroUpdate, session: Session = Depends(get_session)
):
    hero_db = session.get(Hero, hero_id)
    if not hero_db:
        raise HTTPException(status_code=404, detail="Hero not found")
    hero_data = hero.model_dump(exclude_unset=True)
    hero_db.sqlmodel_update(hero_data)
    session.add(hero_db)
    session.commit()
    session.refresh(hero_db)
    return hero_db


@app.delete("/heroes/{hero_id}")
def delete_hero(hero_id: int, session: Session = Depends(get_session)):
    hero = session.get(Hero, hero_id)
    if not hero:
        raise HTTPException(status_code=404, detail="Hero not found")
    session.delete(hero)
    session.commit()
    return {"ok": True}

Domain

Subdomains

Dependencies

Frequently Asked Questions

What does tutorial002_py310.py do?
tutorial002_py310.py is a source file in the fastapi codebase, written in python. It belongs to the FastAPI domain, Responses subdomain.
What functions are defined in tutorial002_py310.py?
tutorial002_py310.py defines 8 function(s): create_db_and_tables, create_hero, delete_hero, get_session, on_startup, read_hero, read_heroes, update_hero.
What does tutorial002_py310.py depend on?
tutorial002_py310.py imports 2 module(s): __init__.py, sqlmodel.
Where is tutorial002_py310.py in the architecture?
tutorial002_py310.py is located at docs_src/sql_databases/tutorial002_py310.py (domain: FastAPI, subdomain: Responses, directory: docs_src/sql_databases).

Analyze Your Own Codebase

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

Try Supermodel Free