feat: CRUD for product barcode images

This commit is contained in:
2024-11-01 17:23:58 +04:00
parent cbe3697f1b
commit 5ed42d99dc
11 changed files with 210 additions and 4 deletions

View File

@@ -1,11 +1,14 @@
from fastapi import HTTPException
from typing import Optional
from fastapi import HTTPException, UploadFile
from sqlalchemy import select, func, Integer, update, or_
from sqlalchemy.orm import selectinload, Query
import utils.barcodes
from backend import config
from barcodes.images_uploader import BarcodeImagesUploader
from external.s3_uploader.uploader import S3Uploader
from models.product import Product, ProductImage
from models.product import Product, ProductImage, ProductBarcodeImage
from schemas.base import PaginationSchema
from schemas.product import *
from services.base import BaseService
@@ -107,7 +110,8 @@ class ProductService(BaseService):
)
.options(
selectinload(Product.barcodes)
.noload(ProductBarcode.product)
.noload(ProductBarcode.product),
selectinload(Product.barcode_image),
)
.where(
Product.client_id == client_id
@@ -257,4 +261,68 @@ class ProductService(BaseService):
return ProductGenerateBarcodeResponse(ok=True, message='Штрих-код успешно сгенерирован', barcode=barcode)
except Exception as e:
return ProductGenerateBarcodeResponse(ok=False, message=str(e))
async def get_model_by_id(self, product_id: int) -> Product:
product: Optional[Product] = await self.session.get(Product, product_id)
if not product:
raise Exception('Не удалось найти товар с указанным ID')
return product
async def delete_model_barcode_image(self, uploader: BarcodeImagesUploader, product_id: int) -> None:
barcode_image: Optional[ProductBarcodeImage] = await self.session.get(ProductBarcodeImage, product_id)
if barcode_image:
uploader.delete(barcode_image.filename)
await self.session.delete(barcode_image)
await self.session.commit()
async def upload_barcode_image(self, product_id: int, upload_file: UploadFile) -> ProductUploadBarcodeImageResponse:
try:
await self.get_model_by_id(product_id)
uploader = BarcodeImagesUploader()
await self.delete_model_barcode_image(uploader, product_id)
filename = await uploader.upload(upload_file)
barcode_image_url = uploader.get_url(filename)
product_barcode_image = ProductBarcodeImage(
product_id=product_id,
filename=filename,
)
self.session.add(product_barcode_image)
await self.session.commit()
return ProductUploadBarcodeImageResponse(
ok=True,
message='Штрих-код для товара успешно загружен',
barcode_image_url=barcode_image_url,
)
except Exception as e:
print(e)
return ProductUploadBarcodeImageResponse(ok=False, message=str(e))
async def delete_barcode_image(self, product_id: int) -> ProductDeleteBarcodeImageResponse:
try:
await self.get_model_by_id(product_id)
uploader = BarcodeImagesUploader()
await self.delete_model_barcode_image(uploader, product_id)
return ProductDeleteBarcodeImageResponse(
ok=True,
message='Штрих-код для товара успешно удален',
)
except Exception as e:
return ProductDeleteBarcodeImageResponse(ok=False, message=str(e))
async def get_barcode_image(self, product_id: int) -> ProductGetBarcodeImageResponse:
product: Optional[Product] = await self.session.get(Product, product_id)
if not product:
raise HTTPException(404, 'Не удалось найти товар с указанным ID')
barcode_image: Optional[ProductBarcodeImage] = await self.session.get(ProductBarcodeImage, product_id)
if not barcode_image:
return ProductGetBarcodeImageResponse(barcode_image_url="")
uploader = BarcodeImagesUploader()
url = uploader.get_url(barcode_image.filename)
return ProductGetBarcodeImageResponse(barcode_image_url=url)
# endregion