Update generated backend for blog_app with entities: posts, comments, tags, user
This commit is contained in:
parent
e9eb6c3dd5
commit
577e157cd3
Binary file not shown.
@ -1,3 +1,4 @@
|
||||
# app/api/core/dependencies/dependencies.py
|
||||
from sqlalchemy.orm import Session
|
||||
from app.api.db.database import SessionLocal
|
||||
|
||||
|
Binary file not shown.
Binary file not shown.
@ -9,5 +9,5 @@ class ActivityTrackerMiddleware(BaseHTTPMiddleware):
|
||||
start_time = time()
|
||||
response: Response = await call_next(request)
|
||||
process_time = time() - start_time
|
||||
logger.info(f"Request processed in {process_time:.4f} seconds")
|
||||
logger.info(f"Processed {request.method} {request.url} in {process_time:.4f} seconds")
|
||||
return response
|
Binary file not shown.
Binary file not shown.
@ -1,5 +1,3 @@
|
||||
# app/api/v1/models/comments.py
|
||||
|
||||
from sqlalchemy import Column, ForeignKey, Integer, String, Text
|
||||
from sqlalchemy.orm import relationship
|
||||
from app.api.db.database import Base
|
||||
@ -12,7 +10,7 @@ class Comments(Base):
|
||||
user_id = Column(Integer, ForeignKey('users.id'))
|
||||
comment_text = Column(Text)
|
||||
created_at = Column(String)
|
||||
updated_at = Column(String, nullable=True)
|
||||
updated_at = Column(String)
|
||||
|
||||
post = relationship('Post', back_populates='comments')
|
||||
user = relationship('User', back_populates='comments')
|
||||
|
@ -1,4 +1,3 @@
|
||||
from typing import Optional
|
||||
from sqlalchemy import Column, ForeignKey, Integer, String, Text
|
||||
from sqlalchemy.orm import relationship
|
||||
from app.api.db.database import Base
|
||||
@ -10,8 +9,10 @@ class Posts(Base):
|
||||
title = Column(String, nullable=False)
|
||||
content = Column(Text, nullable=False)
|
||||
user_id = Column(Integer, ForeignKey('users.id'), nullable=False)
|
||||
category_id = Column(Integer, ForeignKey('categories.id'), nullable=False)
|
||||
|
||||
author = relationship('Users', back_populates='posts')
|
||||
user = relationship('User', back_populates='posts')
|
||||
category = relationship('Category', back_populates='posts')
|
||||
|
||||
def __repr__(self):
|
||||
return f'Post(id={self.id}, title={self.title}, content={self.content[:20]}...)'
|
||||
return f'<Post {self.title}>'
|
@ -9,7 +9,8 @@ class Tags(Base):
|
||||
name = Column(String, nullable=False, unique=True)
|
||||
description = Column(Text, nullable=True)
|
||||
|
||||
posts = relationship("Post", back_populates="tags", secondary="post_tags")
|
||||
# Relationships
|
||||
posts = relationship('Post', secondary='post_tags', back_populates='tags')
|
||||
|
||||
def __repr__(self):
|
||||
return f"Tag(id={self.id}, name='{self.name}', description='{self.description}')"
|
||||
return f'Tag(id={self.id}, name="{self.name}")'
|
@ -2,20 +2,22 @@ from sqlalchemy import Column, ForeignKey, Integer, String, Text
|
||||
from sqlalchemy.orm import relationship
|
||||
from app.api.db.database import Base
|
||||
|
||||
# Optional imports
|
||||
# from typing import Optional
|
||||
|
||||
class User(Base):
|
||||
__tablename__ = 'user'
|
||||
|
||||
id = Column(Integer, primary_key=True, index=True)
|
||||
# Add relevant foreign keys and entity-specific fields here
|
||||
# For example:
|
||||
# email = Column(String, unique=True, index=True, nullable=False)
|
||||
# hashed_password = Column(String, nullable=False)
|
||||
# Add relevant columns based on project context
|
||||
# email = Column(String, unique=True, nullable=False)
|
||||
# password = Column(String, nullable=False)
|
||||
# full_name = Column(String, nullable=False)
|
||||
# bio = Column(Text, nullable=True)
|
||||
|
||||
# Relationships
|
||||
# For example:
|
||||
# Add relationships if applicable
|
||||
# posts = relationship("Post", back_populates="author")
|
||||
|
||||
def __repr__(self):
|
||||
return f"User(id={self.id})"
|
||||
# Optional __repr__ method
|
||||
# def __repr__(self):
|
||||
# return f"User(id={self.id}, email='{self.email}', full_name='{self.full_name}')"
|
Binary file not shown.
@ -1,14 +1,15 @@
|
||||
from pydantic import BaseModel
|
||||
from typing import Optional
|
||||
|
||||
class CommentsBase(BaseModel):
|
||||
comment_text: str
|
||||
body: str
|
||||
post_id: int
|
||||
user_id: int
|
||||
|
||||
class Comments(CommentsBase):
|
||||
id: int
|
||||
post: dict
|
||||
user: dict
|
||||
post: Optional[dict] = None
|
||||
user: Optional[dict] = None
|
||||
|
||||
class Config:
|
||||
orm_mode = True
|
@ -9,7 +9,7 @@ class PostsBase(BaseModel):
|
||||
|
||||
class Posts(PostsBase):
|
||||
id: int
|
||||
owner_id: int
|
||||
user_id: int
|
||||
|
||||
class Config:
|
||||
orm_mode = True
|
@ -6,7 +6,7 @@ class TagsBase(BaseModel):
|
||||
|
||||
class Tags(TagsBase):
|
||||
id: int
|
||||
name: str
|
||||
posts: Optional[list]
|
||||
|
||||
class Config:
|
||||
orm_mode = True
|
Loading…
x
Reference in New Issue
Block a user