Django - Сохранение в нескольких моделях из одного API - PullRequest
0 голосов
/ 06 мая 2020

У меня есть две модели: «Blog_model» и «File_model», где «blog_id» из «Blog_model» - это внешний ключ для «File_Model». Идея состоит в том, чтобы сохранить несколько файлов для одного блога. Вот структура модели для справки.

class Blog_model(models.Model):
    type = models.CharField(max_length = 50, default = "FOOD")
    count = models.PositiveIntegerField(default = 0)
    title = models.CharField(max_length = 500, unique = True)
    substance = models.CharField(max_length = 5000, default = "")
    thumbnail = models.ImageField(upload_to = get_media_file_name, default = "")
    text = models.TextField()
    create_time = models.DateTimeField(auto_now_add = True)
    update_time = models.DateTimeField(auto_now = True)


class File_model(models.Model):
    blog_id = models.ForeignKey(Blog_model, on_delete = models.CASCADE)
    file_name = models.FileField(upload_to = get_media_file_name)
    upload_time = models.DateTimeField(auto_now_add = True)

    def __str__(self):
        return str(self.file_name)

Теперь я хочу создать новый блог, используя единый API, который будет содержать подробную информацию о блогах, а также имена файлов. Я представляю себе структуру API примерно так -

{
"type": "FOOD",
"title": "Some Blog",
"Substance": "Some blog about food",
"text": "This is some blog about food",
"thumbnail": <InMemoryUploadedFile: Capture.PNG (image/png)>
"files": [<InMemoryUploadedFile: food1.jpg (image/jpeg)>, <InMemoryUploadedFile: food2.jpg (image/jpeg)>, <InMemoryUploadedFile: food3.jpg (image/jpeg)>]
}

Пожалуйста, предложите, как достичь цели.
Вы также можете предложить правильную структуру API, если вышеупомянутое кажется неправильным.
Любое предложение приветствуется.
Это сериализатор и представление, которое я использую для этой цели.

-----------------------------------
serializers.py
-----------------------------------

class File_modelCreateSerializer(serializers.ModelSerializer):
    # upload_time = serializers.DateTimeField(format = date_time_format)

    class Meta:
        model = File_model
        fields = ["file_name"]


class Blog_modelCreateSerializer(serializers.ModelSerializer):
    files = File_modelCreateSerializer(many = True, required = False)

    class Meta:
        model = Blog_model
        fields = ["type", "title", "substance", "thumbnail", "text", "files"]

    def create(self, validated_data):
        # files = validated_data.pop("files")       # Getting no key named "files" in validated_data
        new_blog = Blog_model.objects.create(**validated_data)

        # for f in files:
        #     File_model.objects.create(blog_id = new_blog, **f)

        return new_blog


-----------------------------------
views.py
-----------------------------------

# class Blog_modelCreateView(generics.CreateAPIView):   
#     serializer_class = Blog_modelCreateSerializer

class Blog_modelCreateView(APIView):
    parser_classes = (MultiPartParser, FormParser)

    def post(self, request, *args, **kwargs):
        blog_serializer = Blog_modelCreateSerializer(data = request.data)
        if blog_serializer.is_valid():
            blog_serializer.save()
            return Response(blog_serializer.data)
        else:
            return Response(blog_serializer.errors)

1 Ответ

1 голос
/ 06 мая 2020

На самом деле View и Serializer связаны с моделью. Но вы можете использовать декоратор @action.

См. Django REST Framework: маршрутизация для дополнительных действий

Если вы хотите связать сериализатор файлов с блогом, попробуйте следующее.

class BlogViewSet(ModelViewSet):
    def get_serializer(self):
        if self.action == 'files':
           return FileSerializer
    ...
    @action(url_path='files')
    def file(self):
        qs = File.objects.all()
        ...
...