crappy
This commit is contained in:
		@@ -1,5 +1,5 @@
 | 
			
		||||
from sqlalchemy import Column, Integer, String, DateTime, ForeignKey, BigInteger
 | 
			
		||||
from sqlalchemy.orm import relationship, backref
 | 
			
		||||
from sqlalchemy.orm import relationship
 | 
			
		||||
 | 
			
		||||
from models import BaseModel
 | 
			
		||||
 | 
			
		||||
@@ -12,6 +12,8 @@ class Client(BaseModel):
 | 
			
		||||
 | 
			
		||||
    products = relationship('Product', back_populates='client')
 | 
			
		||||
 | 
			
		||||
    details = relationship('ClientDetails', uselist=False, back_populates='client', cascade='all, delete')
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientDetails(BaseModel):
 | 
			
		||||
    __tablename__ = 'client_details'
 | 
			
		||||
@@ -19,7 +21,7 @@ class ClientDetails(BaseModel):
 | 
			
		||||
    id = Column(Integer, autoincrement=True, primary_key=True, index=True)
 | 
			
		||||
 | 
			
		||||
    client_id = Column(Integer, ForeignKey('clients.id'), unique=True, nullable=False, comment='ID клиента')
 | 
			
		||||
    client = relationship('Client', backref=backref('details', uselist=False))
 | 
			
		||||
    client = relationship('Client', back_populates='details', cascade='all, delete', uselist=False)
 | 
			
		||||
 | 
			
		||||
    address = Column(String)
 | 
			
		||||
    phone_number = Column(String)
 | 
			
		||||
 
 | 
			
		||||
@@ -5,8 +5,7 @@ from sqlalchemy.ext.asyncio import AsyncSession
 | 
			
		||||
 | 
			
		||||
from backend.session import get_session
 | 
			
		||||
from models import User
 | 
			
		||||
from schemas.client import ClientSearchRequest, ClientUpdateDetailsRequest, ClientUpdateDetailsResponse, \
 | 
			
		||||
    ClientGetAllResponse
 | 
			
		||||
from schemas.client import *
 | 
			
		||||
from services.auth import get_current_user
 | 
			
		||||
from services.client import ClientService
 | 
			
		||||
 | 
			
		||||
@@ -48,3 +47,41 @@ async def get_all_clients(
 | 
			
		||||
        session: Annotated[AsyncSession, Depends(get_session)],
 | 
			
		||||
):
 | 
			
		||||
    return await ClientService(session).get_all()
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@client_router.post(
 | 
			
		||||
    '/create',
 | 
			
		||||
    operation_id='create_client',
 | 
			
		||||
    response_model=ClientCreateResponse
 | 
			
		||||
)
 | 
			
		||||
async def create_client(
 | 
			
		||||
        request: ClientCreateRequest,
 | 
			
		||||
        user: Annotated[User, Depends(get_current_user)],
 | 
			
		||||
        session: Annotated[AsyncSession, Depends(get_session)]
 | 
			
		||||
):
 | 
			
		||||
    return await ClientService(session).create(request, user)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@client_router.post(
 | 
			
		||||
    '/update',
 | 
			
		||||
    operation_id='update_client',
 | 
			
		||||
    response_model=ClientUpdateResponse
 | 
			
		||||
)
 | 
			
		||||
async def update_client(
 | 
			
		||||
        request: ClientUpdateRequest,
 | 
			
		||||
        user: Annotated[User, Depends(get_current_user)],
 | 
			
		||||
        session: Annotated[AsyncSession, Depends(get_session)]
 | 
			
		||||
):
 | 
			
		||||
    return await ClientService(session).update(request, user)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@client_router.post(
 | 
			
		||||
    '/delete',
 | 
			
		||||
    operation_id='delete_client',
 | 
			
		||||
    response_model=ClientDeleteResponse
 | 
			
		||||
)
 | 
			
		||||
async def delete_client(
 | 
			
		||||
        request: ClientDeleteRequest,
 | 
			
		||||
        session: Annotated[AsyncSession, Depends(get_session)]
 | 
			
		||||
):
 | 
			
		||||
    return await ClientService(session).delete(request)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
from typing import List
 | 
			
		||||
 | 
			
		||||
from schemas.base import CustomModelCamel
 | 
			
		||||
from schemas.base import CustomModelCamel, OkMessageSchema
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientDetailsSchema(CustomModelCamel):
 | 
			
		||||
@@ -20,11 +20,6 @@ class ClientSearchRequest(CustomModelCamel):
 | 
			
		||||
    name: str
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientCreateRequest(CustomModelCamel):
 | 
			
		||||
    name: str
 | 
			
		||||
    address: str
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientSearchResponse(CustomModelCamel):
 | 
			
		||||
    clients: List[ClientSchema]
 | 
			
		||||
 | 
			
		||||
@@ -40,3 +35,27 @@ class ClientUpdateDetailsResponse(CustomModelCamel):
 | 
			
		||||
 | 
			
		||||
class ClientGetAllResponse(CustomModelCamel):
 | 
			
		||||
    clients: List[ClientSchema]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientCreateResponse(OkMessageSchema):
 | 
			
		||||
    pass
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientCreateRequest(CustomModelCamel):
 | 
			
		||||
    data: ClientSchema
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientUpdateRequest(CustomModelCamel):
 | 
			
		||||
    data: ClientSchema
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientUpdateResponse(OkMessageSchema):
 | 
			
		||||
    pass
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientDeleteRequest(CustomModelCamel):
 | 
			
		||||
    client_id: int
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class ClientDeleteResponse(OkMessageSchema):
 | 
			
		||||
    pass
 | 
			
		||||
 
 | 
			
		||||
@@ -72,3 +72,37 @@ class ClientService(BaseService):
 | 
			
		||||
        for client in query.all():
 | 
			
		||||
            clients.append(ClientSchema.model_validate(client))
 | 
			
		||||
        return ClientSearchResponse(clients=clients)
 | 
			
		||||
 | 
			
		||||
    async def create(self, request: ClientCreateRequest, user: User) -> ClientCreateResponse:
 | 
			
		||||
        try:
 | 
			
		||||
            client = await self.get_by_name(request.data.name)
 | 
			
		||||
            if client:
 | 
			
		||||
                return ClientCreateResponse(ok=False, message='Client already exists')
 | 
			
		||||
            await self.create_client_raw(user, request.data.name, request.data.details)
 | 
			
		||||
            await self.session.commit()
 | 
			
		||||
            return ClientCreateResponse(ok=True, message='Client created')
 | 
			
		||||
        except Exception as e:
 | 
			
		||||
            return ClientCreateResponse(ok=False, message=str(e))
 | 
			
		||||
 | 
			
		||||
    async def update(self, request: ClientUpdateRequest, user: User) -> ClientUpdateResponse:
 | 
			
		||||
        try:
 | 
			
		||||
            client = await self.get_by_id(request.data.id)
 | 
			
		||||
            if not client:
 | 
			
		||||
                return ClientUpdateResponse(ok=False, message='Client not found')
 | 
			
		||||
            await self.session.execute(update(Client).where(Client.id == client.id).values(name=request.data.name))
 | 
			
		||||
            await self.update_details(user, client, request.data.details)
 | 
			
		||||
            await self.session.commit()
 | 
			
		||||
            return ClientUpdateResponse(ok=True, message='Client updated')
 | 
			
		||||
        except Exception as e:
 | 
			
		||||
            return ClientUpdateResponse(ok=False, message=str(e))
 | 
			
		||||
 | 
			
		||||
    async def delete(self, request: ClientDeleteRequest) -> ClientDeleteResponse:
 | 
			
		||||
        try:
 | 
			
		||||
            client = await self.get_by_id(request.client_id)
 | 
			
		||||
            if not client:
 | 
			
		||||
                return ClientDeleteResponse(ok=False, message='Client not found')
 | 
			
		||||
            await self.session.delete(client)
 | 
			
		||||
            await self.session.commit()
 | 
			
		||||
            return ClientDeleteResponse(ok=True, message='Client deleted')
 | 
			
		||||
        except Exception as e:
 | 
			
		||||
            return ClientDeleteResponse(ok=False, message=str(e))
 | 
			
		||||
 
 | 
			
		||||
@@ -1,9 +1,8 @@
 | 
			
		||||
from typing import Annotated
 | 
			
		||||
import string
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def get_v():
 | 
			
		||||
    return 123
 | 
			
		||||
def main():
 | 
			
		||||
    pass
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
ockho: Annotated[int, get_v]
 | 
			
		||||
print(ockho)
 | 
			
		||||
if __name__ == '__main__':
 | 
			
		||||
    main()
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user