jat*_*ism 5 python django django-models django-piston
我正在为使用django-piston为Django应用程序编写的API进行最后润色.该API是能够通过其是请求或IP地址来搜索Request
或IPAddress
分别实例.每个请求可以有1个或多个IPAddress
与之关联.
因此,例如,我有一个API调用,它将显示IPAddress
与活动状态"活动","非活动"或"全部"(对于任何一个)匹配的所有对象.的Request
,其每一个IPAddress
实例相关联的可作为IPAddress.request
.
我遇到的问题是,这Request.inputter
是User
配置请求的人的实例的外键.当我从为此API调用创建的处理程序返回结果时,User
将显示实例中的所有字段,包括password
.
这是不好的; 我不想要这个.
所以这是我的处理程序:
class SearchByIPStatusHandler(BaseHandler):
model = IPAddress
allowed_methods = ('GET',)
anonymous = AnonymousIPHandler
def read(self, request, status):
"""
Returns IP addresses based on activity status.
Status: 'active', 'inactive', 'all'
"""
if status == 'all':
return self.model.objects.all()
else:
active = True if (status=='active') else False
return self.model.objects.filter(active=active)
Run Code Online (Sandbox Code Playgroud)
这是以下结果的示例/api/show/all/
:
<response>
<resource>
<updated>2010-02-05 17:08:53.651729</updated>
<expires>2010-02-12 17:08:23</expires>
<created>2010-02-05 17:08:53.625318</created>
<nexthop>255.255.255.255</nexthop>
<netmask>255.255.255.254</netmask>
<address>2.4.6.80/31</address>
<active>True</active>
<id>4</id>
<request>
<updated>2010-02-05 17:08:53.382381</updated>
<created>2010-02-05 17:08:53.382313</created>
<expires>2010-02-12 17:08:23</expires>
<incident>20100212-badthings-01</incident>
<reason>bad things happened</reason>
<inputter>
<username>jathan</username>
<first_name>Jathan</first_name>
<last_name>McCollum</last_name>
<is_active>True</is_active>
<email>email@fake.notreal</email>
<is_superuser>True</is_superuser>
<is_staff>True</is_staff>
<last_login>2010-02-05 18:55:51.877746</last_login>
<password>[ENCRYPTED STRING I REDACTED]</password>
<id>1</id>
<date_joined>2010-01-28 09:56:32</date_joined>
</inputter>
<requester>joeuser</requester>
<active>True</active>
</request>
</resource>
</response>
Run Code Online (Sandbox Code Playgroud)
我真正想要的结果是inputter.username
,而不是所有其他的东西.我已尝试exclude
在处理程序上实现属性的各种迭代无济于事.如果我只是跳过整个请求字段,那么工作正常,如下所示:
处理程序:
exclude = ('request', )
Run Code Online (Sandbox Code Playgroud)
结果如下:
<response>
<resource>
<updated>2010-02-05 17:08:53.651729</updated>
<expires>2010-02-12 17:08:23</expires>
<created>2010-02-05 17:08:53.625318</created>
<nexthop>255.255.255.255</nexthop>
<netmask>255.255.255.254</netmask>
<address>2.4.6.80/31</address>
<active>True</active>
<id>4</id>
</resource>
</response>
Run Code Online (Sandbox Code Playgroud)
但这些结果也不是我想要的.
最后,我的问题是:
如何从处理程序结果中排除嵌套字段?它甚至可能吗?
我尝试了以下各种迭代,所有迭代都没有结果或意外结果:
# try to exclude request.inputter
exclude = ( ('request', ('inputter', ), ) )
# try to exclude request.inputter.password
exclude = ( ('request', ('inputter', ('password', ) ) ) )
Run Code Online (Sandbox Code Playgroud)
我认为我误解或误用了在这种情况下进行字段排除的方式,因此非常感谢对此主题的任何启示.
小智 3
您可以通过处理程序的子句指定所需的字段来获得所需的结果fields =
。
来自外键的模型字段可以这样指定:
('foreign_model_field', ('nested_field1', 'nested_field2'))
Run Code Online (Sandbox Code Playgroud)
对于您的情况,以下内容应该有效(为了简洁起见,省略了一些字段):
fields = ('updated', 'expires', 'created',
('request', ('incident', 'reason', ('inputter', ('username',)))))
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
1877 次 |
最近记录: |