feat: CRUD for product barcode images
This commit is contained in:
		@@ -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
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user