Как создавать записи, когда модель имеет отношение «один ко многим» с помощью TastyPie? - PullRequest
0 голосов
/ 01 ноября 2018

Я делаю POST-запросы, используя TastyPie. Модель задачи имеет самоссылочную связь один-ко-многим через поле parent_task_id.

Модель:

class Task(models.Model):
    title = models.CharField(max_length=100)
    description = models.TextField()
    parent_task_id = models.ForeignKey(
            "self",
            on_delete=models.CASCADE,
            null=True, blank=True)

В моем api.py

class TaskResource(ModelResource):
    parent_task_id_id = fields.ToOneField('self', 'id', null=True, full=True)

    class Meta:
        queryset = Task.objects.all()
        authorization = Authorization()
        allowed_methods = ['post']
        resource_name = "create_task"

Мне не удается создать задачу, когда я указываю parent_task_id с помощью почтальона.

{
    "title": "ABCDERT",
    "description": "world this week",
    "due_date": "2018-11-12 1:2:1",
    "parent_task_id_id": "2"
}

Это сообщение об ошибке, которое я получаю, когда делаю это:

  "error_message": "An incorrect URL was provided '2' for the 'CreateTaskResource' resource.",

1 Ответ

0 голосов
/ 07 ноября 2018

Вы должны указать uri parent_task вместо id, например

{ "title": "ABCDERT", "description": "world this week", "due_date": "2018-11-12 1:2:1", "parent_task_id_id": "/create_task/2" }

Кроме того, некорректно определять поле Foreignkey в ресурсе таким образом,

class TaskResource(ModelResource): parent_task_id_id = fields.ToOneField('self', 'id', null=True, full=True) Вы можете увидеть документы для подробностей.

Я настраиваю ваш пример, например: Модель:

class Task(models.Model):
    title = models.CharField(max_length=100)
    description = models.TextField()
    parent_task = models.ForeignKey("self", on_delete=models.CASCADE, null=True, blank=True)

api.py

class TaskResource(ModelResource):
    parent_task = fields.ToOneField('self', 'parent_task', null=True,
        full=True)
    class Meta:
        queryset = Task.objects.all()
        authorization = Authorization()
        allowed_methods = ['post', 'get']
        filtering = {'id': ALL, 'parent_task': ALL_WITH_RELATIONS}
        resource_name = "task"
  1. Создать задачу

POST тело типа:

{ "title": "task2", "description": "world this week", "due_date": "2018-11-12 1:2:1", "parent_task":"/api/v1/task/1/" }

  1. запрос на иностранный ключ

GET параметр типа:

0.0.0.0:8000/api/v1/task/?parent_task__id=1

...