0

我有一个 UserResource 定义为:

class UserResource(ModelResource):
    class Meta:
        queryset = User.objects.all()
        resource_name = 'user'                                                                                                                       

        # No one is allowed to see all users
        list_allowed_methods = []
        detail_allowed_methods = ['get', 'put', 'patch']

        # Hide staff
        excludes = ('is_staff')

    def apply_authorization_limits(self, request, object_list):
        return object_list.filter(pk=request.user.pk)

    def prepend_urls(self):
        return [ url(r'^(?P<resource_name>%s)/$' % self._meta.resource_name, self.wrap_view('dispatch_detail'), name='api_dispatch_detail') ]

我希望 URI /user/ 只返回当前用户的详细信息,根本没有列表。我的解决方案给出了“在这个 uri 中找到了多个资源”错误,并且确实 dispatch_list 也在那里。我怎样才能让 /user/ 只返回和处理当前用户的详细信息?

谢谢

4

3 回答 3

1

你应该写你自己的视图来包裹住美味派 dispatch_detail

class UserResource(ModelResource):
  [...]

  def prepend_urls(self):
    return [ url(r'^(?P<resource_name>%s)/$' % self._meta.resource_name, self.wrap_view('current_user'), name='api_current_user') ]

  def current_user(self, request, **kwargs):
    user = getattr(request, 'user', None)
    if user and not user.is_anonymous():
        return self.dispatch_detail(request, pk=str(request.user.id))
于 2013-03-28T10:16:41.557 回答
0

要获取当前登录用户的对象,您可以从请求对象中提取它。

user = request.user

或者

user = User.Objects.get(username=user.username)

或使用@gyln 的答案

user = get_object_or_404(User, username=user.username)

显然,如果您这样做,请确保用户在视图中经过身份验证。

object.filter即使只有一个结果,使用该函数也将始终返回一个列表;而该objects.get方法只会返回一个结果。

于 2013-03-27T12:13:46.197 回答
0

尝试:

user = get_object_or_404(User, username=username)
于 2013-03-27T10:03:53.573 回答