3

我正在使用django-piston编写一个 RESTful Web 服务并遇到问题。

在models.py中:

class Status(models.Model):
    user = models.ForeignKey(User)
    content = models.TextField(max_length=140)

class StatusReply(models.Model):
    user = models.ForeignKey(User)
    reply_to = models.ForeignKey(Status, related_name='replies')
    content = models.TextField(max_length=140)
    has_read = models.BooleanField(default=False, help_text="has the publisher of the status read the reply")

在 handlers.py 中:

class StatusHandler(BaseHandler):
    allowed_methods = ('GET', 'POST', 'DELETE' )
    model = Status
    fields = ('id', 
              ('user', ('id', 'username', 'name')), 
              'content', 
              ('replies', ('id', 
                           ('user', ('id', 'username', 'name')), 
                           'content',  
                           'has_read'),
              ),
             )

    @need_login
    def read(self, request, id, current_user): # the current_user arg is an instance of user created in @need_login
        try:
            status = Status.objects.get(pk=id)
        except ObjectDoesNotExist:
            return rc.NOT_FOUND
        else:
            if status.user == current_user: #if current_user is the publisher of the status, set all replies read
                status.replies.all().update(has_read=True)
            return status

在处理程序中,它通过 id 返回特定状态。现在我想返回之前的状态,status.replies.all().update(has_read=True)还要在数据库中进行更新操作。怎么做?提前致谢。

4

1 回答 1

2

不确定我是否了解您的需求。据我了解您的代码,status.replies.all().update(has_read=True)不会更改status,只会更改回复。如果这是真的,代码应该做你想做的事。如果不是,您可以复制status并返回该副本:

        if status.user == current_user: 
            old_status = status.make_copy()
            status.replies.all().update(has_read=True)
            return old_status
        return status

还是您只是希望该方法提前返回并异步更新数据库?然后你应该看看celery,也许这个很好的解释

于 2011-06-07T12:46:25.457 回答