{{{
user_obj._perm_cache = self.get_user_permissions(user_obj) # returns the
set that is mutable
user_obj._perm_cache.update(self.get_group_permissions(user_obj)) #
therefore, the set is changed here
}}}
An alternative solution would be:
{{{
user_obj._perm_cache = set()
user_obj._perm_cache.update(self.get_user_permissions(user_obj))
user_obj._perm_cache.update(self.get_group_permissions(user_obj))
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/28713>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
* status: new => closed
* resolution: => fixed
Comment:
In [changeset:"d98210c25577e7f007605f4960672e887dd452e6" d98210c2]:
{{{
#!CommitTicketReference repository=""
revision="d98210c25577e7f007605f4960672e887dd452e6"
Fixed #28713 -- Prevented ModelBackend.get_all_permissions() from mutating
get_user_permissions().
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/28713#comment:1>
Comment (by Tim Graham <timograham@…>):
In [changeset:"325d3027dbd4fdb92a926621f2d8852f072ebcb6" 325d3027]:
{{{
#!CommitTicketReference repository=""
revision="325d3027dbd4fdb92a926621f2d8852f072ebcb6"
[2.0.x] Fixed #28713 -- Prevented ModelBackend.get_all_permissions() from
mutating get_user_permissions().
Backport of d98210c25577e7f007605f4960672e887dd452e6 from master
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/28713#comment:2>