TrueUser.objects.filter/get
に設定された User オブジェクトのみを返す呼び出しの方法が必要です。is_active
次のように、カスタム Manager を定義して、それを User モデルにモンキー パッチしようとしました。
class CustomUserManager(UserManager):
def get_query_set(self):
return super(CustomUserManager, self).get_query_set().
filter(is_active=True)
User.objects = CustomUserManager()
User.objects_all = UserManager()
しかし、User.objects.get() を呼び出そうとすると、次のようになります。
AttributeError: 'NoneType' object has no attribute '_meta'
先に進む前に、このようなモンキー パッチは保守性の点で非常に悪い形式であることを知っていると言いたいと思います。
誰かがそれを望むなら、ここに完全なスタックトレースがあります:
File "<console>", line 1, in <module>
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/manager.py", line 131, in get
return self.get_query_set().get(*args, **kwargs)
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/query.py", line 358, in get
clone = self.filter(*args, **kwargs)
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/query.py", line 621, in filter
return self._filter_or_exclude(False, *args, **kwargs)
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/query.py", line 639, in _filter_or_exclude
clone.query.add_q(Q(*args, **kwargs))
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/sql/query.py", line 1250, in add_q
can_reuse=used_aliases, force_having=force_having)
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/sql/query.py", line 1114, in add_filter
opts = self.get_meta()
File "/Users/zarathustra/Virtual_Envs/fierce-spring-7383/venv/lib/python2.7/site-packages/django/db/models/sql/query.py", line 233, in get_meta
return self.model._meta
AttributeError: 'NoneType' object has no attribute '_meta'