1

非常に通常の m2m 関係で Tastypie を使用しているときに問題が発生しました。私の(単純化された)モデルでは:

class Promos(models.Model):
    promo_id = UUIDField(auto=True, unique=True, primary_key=True, null = False)
    title = models.CharField(max_length=400, default='title', null = False)
    text = models.TextField(max_length = 10000, null = False, default='text')
    category = models.ManyToManyField(CatPromos, null=True)
    active = models.BooleanField(null = False, default=False)

class CatPromos(models.Model):
    description = models.CharField(max_length = 10, unique=True, default='NoCat')

私のリソースで:

class PromosResource(ModelResource):
    category =  fields.ForeignKey(CatPromosResource, 'category', full=True, null=True)
    class Meta:
        object_class = Promos
        queryset = Promos.objects.all()
        allowed_methods = ['get']
        include_resource_uri = True
        authentication = Authentication()
        authorization = Authorization()
        always_return_data = False
        filtering = {"category":ALL_WITH_RELATIONS}

    def get_object_list(self, request, *args, **kwargs):
        return Promos.objects.filter(active=True)   

class CatPromosResource(ModelResource):
    class Meta:
        object_class = CatPromos
        queryset = CatPromos.objects.all()
        allowed_methods = ['get']
        include_resource_uri = True
        authentication = Authentication()
        authorization = Authorization()
        always_return_data = False
        filtering = {"description":ALL}
        detail_uri_name = "_pk_val"

私が欲しいのは、プロモーションのリストを取得し、www.server.com/api/v1/promos?format=json&category__description=XXX のような説明でフィルタリングすることです

まず、「detail_uri_name」が CatPromosResource の Meta クラスに含まれていることに注意してください。Tastypie (最終バージョン) は、detail_uri_name に何らかの問題があるため、クラッシュし続けました。デフォルトは「pk」ですが、それを使用するオブジェクトには「_pk_val」が必要です。それは、いくつかのデバッグ後に気づきました。しかし、問題は、サーバーの上の URI で GET を呼び出すたびに、次のメッセージが表示されてクラッシュすることです。

"invalid literal for int() with base 10: ''", 
"traceback": "Traceback (most recent call last): 
File \"...python2.7/site-packages/tastypie/resources.py\", line 202, in wrapper
    response = callback(request, *args, **kwargs) 
File \"...python2.7/site-packages/tastypie/resources.py\", line 441, in dispatch_list
    return self.dispatch('list', request, **kwargs)
File \"...python2.7/site-packages/tastypie/resources.py\", line 474, in dispatch
    response = method(request, **kwargs)
File \".../python2.7/site-packages/tastypie/resources.py\", line 1135, in get_list       to_be_serialized[self._meta.collection_name] = [self.full_dehydrate(bundle) for bundle in bundles]
File \".../python2.7/site-packages/tastypie/resources.py\", line 739, in full_dehydrate
    bundle.data[field_name] = field_object.dehydrate(bundle)\  
File \".../python2.7/site-packages/tastypie/fields.py\", line 653, in dehydrate   
    return self.dehydrate_related(fk_bundle, self.fk_resource) 
File \".../python2.7/site-packages/tastypie/fields.py\", line 520, in dehydrate_related
    return related_resource.full_dehydrate(bundle) 
File \".../python2.7/site-packages/tastypie/resources.py\", line 739, in full_dehydrate
    bundle.data[field_name] = field_object.dehydrate(bundle)  
File \".../python2.7/site-packages/tastypie/fields.py\", line 121, in dehydrate    
    return self.convert(current_object)  
File \".../lib/python2.7/site-packages/tastypie/fields.py\", line 220, in convert    
    return int(value)\n\nValueError: invalid literal for int() with base 10: ''\n"}

私はここで迷っています。どうすればいいのかわからない。コードで呼び出しを追跡しましたが、解決方法がわかりません。この問題に直面する方法、または m2m 関連の関係で GET 呼び出しを実装する正しい方法を誰かが知っている場合は、私を助けてください。

4

1 に答える 1