IBM Abdulsalam
commited on
Commit
·
ba86161
1
Parent(s):
b58ddbb
latest
Browse files- __pycache__/app.cpython-310.pyc +0 -0
- __pycache__/crud.cpython-310.pyc +0 -0
- __pycache__/database.cpython-310.pyc +0 -0
- __pycache__/main.cpython-310.pyc +0 -0
- __pycache__/models.cpython-310.pyc +0 -0
- __pycache__/schemas.cpython-310.pyc +0 -0
- app/.app.py.swp +0 -0
- app/.db.py.swp +0 -0
- app/__init__.py +0 -0
- app/__pycache__/__init__.cpython-310.pyc +0 -0
- app/__pycache__/app.cpython-310.pyc +0 -0
- app/__pycache__/db.cpython-310.pyc +0 -0
- app/__pycache__/schemas.cpython-310.pyc +0 -0
- app/__pycache__/users.cpython-310.pyc +0 -0
- app/app.py +50 -0
- app/db.py +49 -0
- app.py → app/llm.py +0 -0
- app/schemas.py +15 -0
- app/users.py +56 -0
- config.py +0 -8
- crud.py +0 -37
- database.py +0 -28
- docker-compose.yml +0 -39
- main.py +4 -61
- models.py +0 -26
- requirements.txt +1 -1
- schemas.py +0 -36
__pycache__/app.cpython-310.pyc
DELETED
Binary file (3.21 kB)
|
|
__pycache__/crud.cpython-310.pyc
DELETED
Binary file (1.54 kB)
|
|
__pycache__/database.cpython-310.pyc
DELETED
Binary file (490 Bytes)
|
|
__pycache__/main.cpython-310.pyc
DELETED
Binary file (2.24 kB)
|
|
__pycache__/models.cpython-310.pyc
DELETED
Binary file (1.06 kB)
|
|
__pycache__/schemas.cpython-310.pyc
DELETED
Binary file (1.56 kB)
|
|
app/.app.py.swp
ADDED
Binary file (1.02 kB). View file
|
|
app/.db.py.swp
ADDED
Binary file (1.02 kB). View file
|
|
app/__init__.py
ADDED
File without changes
|
app/__pycache__/__init__.cpython-310.pyc
ADDED
Binary file (127 Bytes). View file
|
|
app/__pycache__/app.cpython-310.pyc
ADDED
Binary file (1.21 kB). View file
|
|
app/__pycache__/db.cpython-310.pyc
ADDED
Binary file (1.72 kB). View file
|
|
app/__pycache__/schemas.cpython-310.pyc
ADDED
Binary file (617 Bytes). View file
|
|
app/__pycache__/users.cpython-310.pyc
ADDED
Binary file (2.16 kB). View file
|
|
app/app.py
ADDED
@@ -0,0 +1,50 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from contextlib import asynccontextmanager
|
2 |
+
|
3 |
+
from fastapi import Depends, FastAPI
|
4 |
+
|
5 |
+
from .db import User, create_db_and_tables
|
6 |
+
from .schemas import UserCreate, UserRead, UserUpdate
|
7 |
+
from .users import auth_backend, current_active_user, fastapi_users
|
8 |
+
from .llm import *
|
9 |
+
|
10 |
+
@asynccontextmanager
|
11 |
+
async def lifespan(app: FastAPI):
|
12 |
+
# Not needed if you setup a migration system like Alembic
|
13 |
+
await create_db_and_tables()
|
14 |
+
yield
|
15 |
+
|
16 |
+
|
17 |
+
app = FastAPI(lifespan=lifespan)
|
18 |
+
|
19 |
+
app.include_router(
|
20 |
+
fastapi_users.get_auth_router(auth_backend), prefix="/auth/jwt", tags=["auth"]
|
21 |
+
)
|
22 |
+
app.include_router(
|
23 |
+
llm_router,
|
24 |
+
tags=["llm"]
|
25 |
+
)
|
26 |
+
app.include_router(
|
27 |
+
fastapi_users.get_register_router(UserRead, UserCreate),
|
28 |
+
prefix="/auth",
|
29 |
+
tags=["auth"],
|
30 |
+
)
|
31 |
+
app.include_router(
|
32 |
+
fastapi_users.get_reset_password_router(),
|
33 |
+
prefix="/auth",
|
34 |
+
tags=["auth"],
|
35 |
+
)
|
36 |
+
app.include_router(
|
37 |
+
fastapi_users.get_verify_router(UserRead),
|
38 |
+
prefix="/auth",
|
39 |
+
tags=["auth"],
|
40 |
+
)
|
41 |
+
app.include_router(
|
42 |
+
fastapi_users.get_users_router(UserRead, UserUpdate),
|
43 |
+
prefix="/users",
|
44 |
+
tags=["users"],
|
45 |
+
)
|
46 |
+
|
47 |
+
|
48 |
+
@app.get("/authenticated-route")
|
49 |
+
async def authenticated_route(user: User = Depends(current_active_user)):
|
50 |
+
return {"message": f"Hello {user.email}!"}
|
app/db.py
ADDED
@@ -0,0 +1,49 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
from typing import AsyncGenerator
|
2 |
+
from app import app
|
3 |
+
from fastapi import Depends
|
4 |
+
from fastapi_users.db import SQLAlchemyBaseUserTableUUID, SQLAlchemyUserDatabase
|
5 |
+
from sqlalchemy.ext.asyncio import AsyncSession, async_sessionmaker, create_async_engine
|
6 |
+
from sqlalchemy.orm import DeclarativeBase
|
7 |
+
|
8 |
+
from sqlalchemy import URL
|
9 |
+
|
10 |
+
db_url = URL.create(
|
11 |
+
"postgresql",
|
12 |
+
username="avnadmin",
|
13 |
+
password="AVNS_u12fHxoNLBbzD8TGpqN", # plain (unescaped) text
|
14 |
+
host="pg-opengenai-opengenai.b.aivencloud.com",
|
15 |
+
database="defaultdb",
|
16 |
+
port=14535,
|
17 |
+
)
|
18 |
+
|
19 |
+
|
20 |
+
DATABASE_URL = db_url
|
21 |
+
#DATABASE_URL = "sqlite+aiosqlite:///./test.db"
|
22 |
+
|
23 |
+
|
24 |
+
class Base(DeclarativeBase):
|
25 |
+
pass
|
26 |
+
|
27 |
+
|
28 |
+
class User(SQLAlchemyBaseUserTableUUID, Base):
|
29 |
+
pass
|
30 |
+
|
31 |
+
|
32 |
+
engine = create_async_engine(DATABASE_URL)
|
33 |
+
async_session_maker = async_sessionmaker(engine, expire_on_commit=False)
|
34 |
+
|
35 |
+
|
36 |
+
async def create_db_and_tables():
|
37 |
+
async with engine.begin() as conn:
|
38 |
+
await conn.run_sync(Base.metadata.create_all)
|
39 |
+
|
40 |
+
|
41 |
+
async def get_async_session() -> AsyncGenerator[AsyncSession, None]:
|
42 |
+
async with async_session_maker() as session:
|
43 |
+
yield session
|
44 |
+
|
45 |
+
|
46 |
+
async def get_user_db(session: AsyncSession = Depends(get_async_session)):
|
47 |
+
yield SQLAlchemyUserDatabase(session, User)
|
48 |
+
|
49 |
+
|
app.py → app/llm.py
RENAMED
File without changes
|
app/schemas.py
ADDED
@@ -0,0 +1,15 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import uuid
|
2 |
+
|
3 |
+
from fastapi_users import schemas
|
4 |
+
|
5 |
+
|
6 |
+
class UserRead(schemas.BaseUser[uuid.UUID]):
|
7 |
+
pass
|
8 |
+
|
9 |
+
|
10 |
+
class UserCreate(schemas.BaseUserCreate):
|
11 |
+
pass
|
12 |
+
|
13 |
+
|
14 |
+
class UserUpdate(schemas.BaseUserUpdate):
|
15 |
+
pass
|
app/users.py
ADDED
@@ -0,0 +1,56 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import uuid
|
2 |
+
from typing import Optional
|
3 |
+
|
4 |
+
from fastapi import Depends, Request
|
5 |
+
from fastapi_users import BaseUserManager, FastAPIUsers, UUIDIDMixin
|
6 |
+
from fastapi_users.authentication import (
|
7 |
+
AuthenticationBackend,
|
8 |
+
BearerTransport,
|
9 |
+
JWTStrategy,
|
10 |
+
)
|
11 |
+
from fastapi_users.db import SQLAlchemyUserDatabase
|
12 |
+
|
13 |
+
from app.db import User, get_user_db
|
14 |
+
|
15 |
+
SECRET = "SECRET"
|
16 |
+
|
17 |
+
|
18 |
+
class UserManager(UUIDIDMixin, BaseUserManager[User, uuid.UUID]):
|
19 |
+
reset_password_token_secret = SECRET
|
20 |
+
verification_token_secret = SECRET
|
21 |
+
|
22 |
+
async def on_after_register(self, user: User, request: Optional[Request] = None):
|
23 |
+
print(f"User {user.id} has registered.")
|
24 |
+
|
25 |
+
async def on_after_forgot_password(
|
26 |
+
self, user: User, token: str, request: Optional[Request] = None
|
27 |
+
):
|
28 |
+
print(f"User {user.id} has forgot their password. Reset token: {token}")
|
29 |
+
|
30 |
+
async def on_after_request_verify(
|
31 |
+
self, user: User, token: str, request: Optional[Request] = None
|
32 |
+
):
|
33 |
+
print(f"Verification requested for user {user.id}. Verification token: {token}")
|
34 |
+
|
35 |
+
|
36 |
+
async def get_user_manager(user_db: SQLAlchemyUserDatabase = Depends(get_user_db)):
|
37 |
+
yield UserManager(user_db)
|
38 |
+
|
39 |
+
|
40 |
+
bearer_transport = BearerTransport(tokenUrl="auth/jwt/login")
|
41 |
+
|
42 |
+
|
43 |
+
def get_jwt_strategy() -> JWTStrategy:
|
44 |
+
return JWTStrategy(secret=SECRET, lifetime_seconds=3600)
|
45 |
+
|
46 |
+
|
47 |
+
auth_backend = AuthenticationBackend(
|
48 |
+
name="jwt",
|
49 |
+
transport=bearer_transport,
|
50 |
+
get_strategy=get_jwt_strategy,
|
51 |
+
)
|
52 |
+
|
53 |
+
fastapi_users = FastAPIUsers[User, uuid.UUID](get_user_manager, [auth_backend])
|
54 |
+
|
55 |
+
current_active_user = fastapi_users.current_user(active=True)
|
56 |
+
|
config.py
DELETED
@@ -1,8 +0,0 @@
|
|
1 |
-
import os
|
2 |
-
#from pydantic import BaseSettings, Field
|
3 |
-
from pydantic_settings import BaseSettings
|
4 |
-
from pydantic import Field
|
5 |
-
class Settings(BaseSettings):
|
6 |
-
db_url: str = Field(..., env='DATABASE_URL')
|
7 |
-
|
8 |
-
settings = Settings()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
crud.py
DELETED
@@ -1,37 +0,0 @@
|
|
1 |
-
from sqlalchemy.orm import Session
|
2 |
-
|
3 |
-
import models
|
4 |
-
import schemas
|
5 |
-
|
6 |
-
|
7 |
-
def get_user(db: Session, user_id: int):
|
8 |
-
return db.query(models.User).filter(models.User.id == user_id).first()
|
9 |
-
|
10 |
-
|
11 |
-
def get_user_by_email(db: Session, email: str):
|
12 |
-
return db.query(models.User).filter(models.User.email == email).first()
|
13 |
-
|
14 |
-
|
15 |
-
def get_users(db: Session, skip: int = 0, limit: int = 100):
|
16 |
-
return db.query(models.User).offset(skip).limit(limit).all()
|
17 |
-
|
18 |
-
|
19 |
-
def create_user(db: Session, user: schemas.UserCreate):
|
20 |
-
fake_hashed_password = user.password + "notreallyhashed"
|
21 |
-
db_user = models.User(email=user.email, hashed_password=fake_hashed_password)
|
22 |
-
db.add(db_user)
|
23 |
-
db.commit()
|
24 |
-
db.refresh(db_user)
|
25 |
-
return db_user
|
26 |
-
|
27 |
-
|
28 |
-
def get_items(db: Session, skip: int = 0, limit: int = 100):
|
29 |
-
return db.query(models.Item).offset(skip).limit(limit).all()
|
30 |
-
|
31 |
-
|
32 |
-
def create_user_item(db: Session, item: schemas.ItemCreate, user_id: int):
|
33 |
-
db_item = models.Item(**item.model_dump(), owner_id=user_id)
|
34 |
-
db.add(db_item)
|
35 |
-
db.commit()
|
36 |
-
db.refresh(db_item)
|
37 |
-
return db_item
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
database.py
DELETED
@@ -1,28 +0,0 @@
|
|
1 |
-
from sqlalchemy import create_engine
|
2 |
-
from sqlalchemy.ext.declarative import declarative_base
|
3 |
-
from sqlalchemy.orm import sessionmaker
|
4 |
-
#from config import settings
|
5 |
-
|
6 |
-
import os
|
7 |
-
#db_url = os.environ.get("DATABASE_URL", "")
|
8 |
-
|
9 |
-
from sqlalchemy import URL
|
10 |
-
|
11 |
-
db_url = URL.create(
|
12 |
-
"postgresql",
|
13 |
-
username="avnadmin",
|
14 |
-
password="AVNS_u12fHxoNLBbzD8TGpqN", # plain (unescaped) text
|
15 |
-
host="pg-opengenai-opengenai.b.aivencloud.com",
|
16 |
-
database="defaultdb",
|
17 |
-
port=14535,
|
18 |
-
)
|
19 |
-
#database = databases.Database(settings.db_url)
|
20 |
-
SQLALCHEMY_DATABASE_URL = db_url # "ibmabdulsalam.mysql.pythonanywhere-services.com" #"sqlite:///./sql_app.db"
|
21 |
-
#SQLALCHEMY_DATABASE_URL = db_url #"postgresql://user:password@postgresserver/db"
|
22 |
-
|
23 |
-
engine = create_engine(
|
24 |
-
SQLALCHEMY_DATABASE_URL, pool_size=10
|
25 |
-
)#, connect_args={"check_same_thread": False}
|
26 |
-
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)
|
27 |
-
|
28 |
-
Base = declarative_base()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
docker-compose.yml
DELETED
@@ -1,39 +0,0 @@
|
|
1 |
-
version: "3"
|
2 |
-
|
3 |
-
services:
|
4 |
-
backend:
|
5 |
-
build: ./app/Dockerfile
|
6 |
-
command: uvicorn main:app --host 0.0.0.0
|
7 |
-
networks:
|
8 |
-
- caw
|
9 |
-
ports:
|
10 |
-
- "7860:7860"
|
11 |
-
volumes:
|
12 |
-
- ./config.yaml:/app/config.yaml
|
13 |
-
environment:
|
14 |
-
DATABASE_URL: postgresql://postgres:postgres@postgres:5432/postgres
|
15 |
-
database:
|
16 |
-
image: postgres:latest
|
17 |
-
networks:
|
18 |
-
- caw
|
19 |
-
environment:
|
20 |
-
POSTGRES_DB: postgres
|
21 |
-
POSTGRES_USER: postgres
|
22 |
-
POSTGRES_PASSWORD: postgres
|
23 |
-
volumes:
|
24 |
-
- database:/var/lib/postgresql/data
|
25 |
-
ports:
|
26 |
-
- "5432:5432"
|
27 |
-
cache:
|
28 |
-
image: redis:latest
|
29 |
-
networks:
|
30 |
-
- caw
|
31 |
-
ports:
|
32 |
-
- "6379:6379"
|
33 |
-
|
34 |
-
volumes:
|
35 |
-
database:
|
36 |
-
|
37 |
-
|
38 |
-
networks:
|
39 |
-
caw:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
main.py
CHANGED
@@ -1,62 +1,5 @@
|
|
1 |
-
from fastapi import Depends, FastAPI, HTTPException
|
2 |
-
from sqlalchemy.orm import Session
|
3 |
-
import crud
|
4 |
-
import models
|
5 |
-
import schemas
|
6 |
-
from database import SessionLocal, engine
|
7 |
-
from app import llm_router
|
8 |
-
from fastapi import APIRouter, FastAPI
|
9 |
-
models.Base.metadata.create_all(bind=engine)
|
10 |
|
11 |
-
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
-
yield db
|
16 |
-
finally:
|
17 |
-
db.close()
|
18 |
-
|
19 |
-
user_router = APIRouter(prefix="/user")
|
20 |
-
|
21 |
-
@user_router.post("/users/", response_model=schemas.User, tags=["users"])
|
22 |
-
def create_user(user: schemas.UserCreate, db: Session = Depends(get_db)):
|
23 |
-
db_user = crud.get_user_by_email(db, email=user.email)
|
24 |
-
if db_user:
|
25 |
-
raise HTTPException(status_code=400, detail="Email already registered")
|
26 |
-
return crud.create_user(db=db, user=user)
|
27 |
-
|
28 |
-
|
29 |
-
@user_router.get("/users/", response_model=list[schemas.User], tags=["users"])
|
30 |
-
def read_users(skip: int = 0, limit: int = 100, db: Session = Depends(get_db)):
|
31 |
-
users = crud.get_users(db, skip=skip, limit=limit)
|
32 |
-
return users
|
33 |
-
|
34 |
-
|
35 |
-
@user_router.get("/users/{user_id}", response_model=schemas.User, tags=["users"] )
|
36 |
-
def read_user(user_id: int, db: Session = Depends(get_db)):
|
37 |
-
db_user = crud.get_user(db, user_id=user_id)
|
38 |
-
if db_user is None:
|
39 |
-
raise HTTPException(status_code=404, detail="User not found")
|
40 |
-
return db_user
|
41 |
-
|
42 |
-
|
43 |
-
@user_router.post("/users/{user_id}/items/", response_model=schemas.Item, tags=["users"] )
|
44 |
-
def create_item_for_user(
|
45 |
-
user_id: int, item: schemas.ItemCreate, db: Session = Depends(get_db)
|
46 |
-
):
|
47 |
-
return crud.create_user_item(db=db, item=item, user_id=user_id)
|
48 |
-
|
49 |
-
|
50 |
-
@user_router.get("/items/", response_model=list[schemas.Item], tags=["users"] )
|
51 |
-
def read_items(skip: int = 0, limit: int = 100, db: Session = Depends(get_db)):
|
52 |
-
items = crud.get_items(db, skip=skip, limit=limit)
|
53 |
-
return items
|
54 |
-
|
55 |
-
|
56 |
-
app = FastAPI(
|
57 |
-
docs_url="/",
|
58 |
-
title="OpenGenAI",
|
59 |
-
description="Your Excellect AI Physician")
|
60 |
-
|
61 |
-
app.include_router(user_router)
|
62 |
-
app.include_router(llm_router)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
|
2 |
+
import uvicorn
|
3 |
+
#from app.app import app
|
4 |
+
if __name__ == "__main__":
|
5 |
+
uvicorn.run("app.app:app", host="0.0.0.0", log_level="info")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
models.py
DELETED
@@ -1,26 +0,0 @@
|
|
1 |
-
from sqlalchemy import Boolean, Column, ForeignKey, Integer, String
|
2 |
-
from sqlalchemy.orm import relationship
|
3 |
-
|
4 |
-
from database import Base
|
5 |
-
|
6 |
-
|
7 |
-
class User(Base):
|
8 |
-
__tablename__ = "users"
|
9 |
-
|
10 |
-
id = Column(Integer, primary_key=True, index=True)
|
11 |
-
email = Column(String, unique=True, index=True)
|
12 |
-
hashed_password = Column(String)
|
13 |
-
is_active = Column(Boolean, default=True)
|
14 |
-
|
15 |
-
items = relationship("Item", back_populates="owner")
|
16 |
-
|
17 |
-
|
18 |
-
class Item(Base):
|
19 |
-
__tablename__ = "items"
|
20 |
-
|
21 |
-
id = Column(Integer, primary_key=True, index=True)
|
22 |
-
title = Column(String, index=True)
|
23 |
-
description = Column(String, index=True)
|
24 |
-
owner_id = Column(Integer, ForeignKey("users.id"))
|
25 |
-
|
26 |
-
owner = relationship("User", back_populates="items")
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
requirements.txt
CHANGED
@@ -5,4 +5,4 @@ pymysql
|
|
5 |
mysqlclient==1.3.12
|
6 |
tensorflow
|
7 |
transformers
|
8 |
-
psycopg2-binary
|
|
|
5 |
mysqlclient==1.3.12
|
6 |
tensorflow
|
7 |
transformers
|
8 |
+
psycopg2-binary
|
schemas.py
DELETED
@@ -1,36 +0,0 @@
|
|
1 |
-
from typing import Union
|
2 |
-
from pydantic import BaseModel
|
3 |
-
|
4 |
-
|
5 |
-
class ItemBase(BaseModel):
|
6 |
-
title: str
|
7 |
-
description: Union[str, None] = None
|
8 |
-
|
9 |
-
|
10 |
-
class ItemCreate(ItemBase):
|
11 |
-
pass
|
12 |
-
|
13 |
-
|
14 |
-
class Item(ItemBase):
|
15 |
-
id: int
|
16 |
-
owner_id: int
|
17 |
-
|
18 |
-
class Config:
|
19 |
-
from_attributes = True
|
20 |
-
|
21 |
-
|
22 |
-
class UserBase(BaseModel):
|
23 |
-
email: str
|
24 |
-
|
25 |
-
|
26 |
-
class UserCreate(UserBase):
|
27 |
-
password: str
|
28 |
-
|
29 |
-
|
30 |
-
class User(UserBase):
|
31 |
-
id: int
|
32 |
-
is_active: bool
|
33 |
-
items: list[Item] = []
|
34 |
-
|
35 |
-
class Config:
|
36 |
-
from_attributes = True
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|