2016-08-07 2 views
0

Так что я пытаюсь получить мое местоположение, фильтр URL, как api/v1/labels/?brand_location=Australia для фильтрации брендов с Австралии только бренды, чтобы вернуться, но продолжать получать сообщение об ошибке:Invalid подстановки ресурсов данных при условии (несовпадающие типа)

{"error": "Invalid resource lookup data provided (mismatched type)."} 

Но когда использование api/v1/labels/?brand_location/=Australia он работает, но удаляет фильтр только в Австралии, он возвращает полный ответ, не исключая местоположения.

Так что мои вопросы:

  1. Как я могу удалить слэш? И получить его для фильтрации только в Австралии.
  2. Это правильный путь? При использовании внешних ключей с django tastypie?

Мой код ниже:

Models.py

class Brand(models.Model): 

    brand_location = models.ForeignKey('Location', null=True, blank=True, default="") 


class Location(models.Model): 

    state_or_country = models.CharField(unique=True, max_length=200, blank=True, default="", verbose_name=_('Location'), 

api.py

class LocationResource(ModelResource): 
    class Meta: 
     excludes = ['modified', 'id', 'created'] 

     queryset = Location.objects.all() 

     resource_name = 'locations' 

class LabelResource(ModelResource): 

    brand_location = fields.ForeignKey(LocationResource, 'brand_location', full=True) 

    class Meta: 

     filtering = { 
      "brand_location": ALL 
     } 

     queryset = Brand.objects.all() 

     resource_name = 'labels' 

Отрывок JSON ответ

{ 
    "labels": [ 
    { 
     "brand_location": { 
     "state_or_country": "Australia" 
     } 
    } 
    ], 
    "meta": { 
    "limit": 6, 
    "next": "/unlabel-network/unlabel-network-api/v1/labels/?limit=6&brand_location%2F=Australia&offset=6", 
    "offset": 0, 
    "previous": null, 
    "total_count": 128 
    } 
} 

ответ

0

api/v1/labels/?brand_location=Australia ищет Location.id=Australia.

Разрешить фильтрацию глубже:

filtering = { 
    "brand_location": ALL_WITH_RELATIONS 
} 

и искать state_or_country поле:

api/v1/labels/?brand_location__state_or_country=Australia 
+0

Это новый ошибка, которую я получаю, когда использую указанный выше URL-адрес: {«error»: «Поиск не допускается более одного уровня в поле« brand_location ».} – Amechi

0

мне просто нужно добавить filtering к моему LocationResource Затем добавьте ALL_WITH_RELATIONS в мой фильтрации Dict на мой LabelResource

class LocationResource(ModelResource): 
    class Meta: 
     excludes = ['modified', 'id', 'created'] 

     queryset = Location.objects.all() 

     resource_name = 'locations' 

     filtering = { 
      "state_or_country": ALL 
     } 

class LabelResource(ModelResource): 

    brand_location = fields.ForeignKey(LocationResource, 'brand_location', full=True) 

    class Meta: 

     filtering = { 
      "brand_location": ALL, 
      "brand_location": ALL_WITH_RELATIONS 
     } 

     queryset = Brand.objects.all() 

     resource_name = 'labels'