Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 24 additions & 4 deletions market/services.py
Original file line number Diff line number Diff line change
Expand Up @@ -79,10 +79,30 @@ def upload_service_images(entity: Any, image_file) -> None:
# 엔티티 타입 별 쿼리 생성
if isinstance(entity, Service):
ServiceImage.objects.create(market_service=entity, image=image_file)
elif isinstance(entity, ServiceOption):
ServiceOptionImage.objects.create(
service_option=entity, image=image_file
)

except ValidationError as e:
raise ValidationError(f"Validation Error: {str(e)}")
except Exception as e:
raise e

@staticmethod
@transaction.atomic
def upload_service_option_images(entity: Any, image_files) -> None:
"""
서비스 소개 이미지를 S3에 업로드 및 데이터베이스에 저장하는 함수
"""
try:
# 파일 유효성 검증
validate_image_files(image_files)

# 엔티티 타입 별 쿼리 생성
if isinstance(entity, ServiceOption):
bulk_images: List[ServiceOptionImage] = []
for image_file in image_files:
bulk_images.append(
ServiceOptionImage(service_option=entity, image=image_file)
)
ServiceOptionImage.objects.bulk_create(bulk_images)

except ValidationError as e:
raise ValidationError(f"Validation Error: {str(e)}")
Expand Down
4 changes: 2 additions & 2 deletions market/views/image_upload_view.py
Original file line number Diff line number Diff line change
Expand Up @@ -93,8 +93,8 @@ def post(self, request, **kwargs):
if not image_files:
raise ValidationError("There are no image files to upload")

self.service.upload_service_images(
entity=market_service_option, image_file=image_files
self.service.upload_service_option_images(
entity=market_service_option, image_files=image_files
)

return Response(
Expand Down
10 changes: 5 additions & 5 deletions order/serializers/order_retrieve_serializer.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
from rest_framework import serializers

from market.serializers.service_serializers.service_create_retrieve_serializer import (
ServiceRetrieveSerializer,
)
from market.serializers.service_serializers.service_material.service_material_retrieve_serializer import (
ServiceMaterialRetrieveSerializer,
)
Expand All @@ -23,7 +26,7 @@


class OrderRetrieveSerializer(serializers.ModelSerializer):
service_uuid = serializers.SerializerMethodField(read_only=True)
service = ServiceRetrieveSerializer(read_only=True)
reformer = serializers.SerializerMethodField(read_only=True)
materials = ServiceMaterialRetrieveSerializer(many=True, read_only=True)
additional_options = ServiceOptionRetrieveSerializer(many=True, read_only=True)
Expand All @@ -33,9 +36,6 @@ class OrderRetrieveSerializer(serializers.ModelSerializer):
delivery_status = serializers.SerializerMethodField(read_only=True)
images = OrderImageSerializer(source="order_image", many=True, read_only=True)

def get_service_uuid(self, obj):
return obj.service.service_uuid

def get_reformer(self, obj):
reformer = obj.service.market.reformer
if reformer:
Expand All @@ -57,7 +57,7 @@ def get_delivery_status(self, obj):
class Meta:
model = Order
fields = [
"service_uuid",
"service",
"reformer",
"order_uuid",
"order_date",
Expand Down
2 changes: 1 addition & 1 deletion order/tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -369,7 +369,7 @@ def test_get_order_list(self, _):

# Then
self.assertEqual(response.status_code, status.HTTP_200_OK)
self.assertIn("service_uuid", response.data[0])
self.assertIn("service", response.data[0])
self.assertIn("order_uuid", response.data[0])
self.assertIn("order_date", response.data[0])
self.assertIn("orderer_information", response.data[0])
Expand Down
Loading