DRFのMiddlewareではrequest.userが取れない

DRF、django-rest-frameworkが入っている状況で、Djangoのミドルウェアを使って、ログインユーザに対してなにかをしたいな〜と思っているのだが、何度やってもAnonymousUserになってしまう。

MIDDLEWARE = [
    ...
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'foo.bar.SomethingMiddleware',
    ...
]
class SomethingMiddleware(MiddlewareMixin):
    def process_request(self, request):
        print(request.user)

ソースを読んでいくと、どうやら、DRFの認証と、Djangoの認証処理の違いがあり、具体的には…

つまり、ミドルウェアでrequest.userを取ろうと思っても、DRFが入っている状況では無理、ということになる。

深堀りするきっかけとなったQA: python - Django and Middleware which uses request.user is always Anonymous - Stack Overflow

機能追加せんかね?というディスカッションもあった。ここにリクエストライフサイクルのめっちゃわかりやすい図がある: DRF Middleware proposal · encode/django-rest-framework · Discussion #7770

今回の実装では、ログインユーザのデータに基づいてリクエストを拒否しようかどうしようか、というものだったので、それってパーミッションだよね、ということでpermissionsとして実装することで事なきを得た。


ところでこれって、もともとの実装で django.contrib.auth.middleware.AuthenticationMiddleware がミドルウェアに入っていることが混乱の種なのでは???という気がする。が、実はどこかでは使っている可能性もあり、迂闊にはずすわけにもいかないので、持ち帰りで議論へ…


パーミッションにするにしても全部のエンドポイントに適用したいので、DEFAULT_PERMISSION_CLASSES を設定しようにも、実装済みのビューでは、permission_classes を設定しているところがあって、これって上書きされちゃうのか〜〜とまたトラップを踏んだ。

https://github.com/encode/django-rest-framework/blob/3.15.2/rest_framework/views.py#L111

サイト案内

運営してるひと: @sters9

最近は Go, Ruby, Rails, Kubernetes, GCP, Datadog あたりをしていますがもっといろいろやりたい!

サイト案内

開発環境の紹介

プライバシーポリシー

tools.gomiba.co

サイト内検索

アーカイブ

2024/12 (2) 2024/09 (3) 2024/07 (1) 2024/06 (3) 2024/05 (1) 2024/04 (7) 2024/03 (4) 2024/01 (3)

2023/12 (1) 2023/11 (3) 2023/10 (1) 2023/09 (1) 2023/08 (2) 2023/05 (4) 2023/04 (4) 2023/03 (4) 2023/02 (2) 2023/01 (1)

2022/12 (2) 2022/11 (4) 2022/10 (3) 2022/09 (2) 2022/08 (4) 2022/07 (5) 2022/06 (4) 2022/05 (9) 2022/04 (8) 2022/03 (10) 2022/02 (21) 2022/01 (8)

2021/12 (11) 2021/11 (1) 2021/10 (4) 2021/09 (2) 2021/08 (1) 2021/07 (2) 2021/06 (5) 2021/05 (10) 2021/04 (1) 2021/03 (8) 2021/02 (12) 2021/01 (8)

2020/05 (2) 2020/04 (2) 2020/02 (2) 2020/01 (1)

2019/12 (3) 2019/11 (2) 2019/10 (5) 2019/09 (3) 2019/07 (6) 2019/06 (4) 2019/04 (3) 2019/01 (2)

2018/12 (6) 2018/10 (4) 2018/09 (6) 2018/08 (7) 2018/07 (16) 2018/06 (7) 2018/05 (7) 2018/04 (5) 2018/03 (3) 2018/02 (10) 2018/01 (6)

2017/12 (8) 2017/11 (6) 2017/10 (10) 2017/09 (12) 2017/08 (12) 2017/07 (3) 2017/06 (1) 2017/01 (4)

2016/12 (5) 2016/10 (3) 2016/09 (1) 2016/07 (2) 2016/06 (1) 2016/04 (1) 2016/02 (1) 2016/01 (2)

2015/12 (1) 2015/10 (1) 2015/09 (3) 2015/06 (1) 2015/01 (1)

2014/08 (2) 2014/07 (3) 2014/05 (1) 2014/01 (7)

2013/12 (2) 2013/11 (4) 2013/10 (1) 2013/09 (1) 2013/08 (3) 2013/07 (4) 2013/06 (5) 2013/05 (2) 2013/04 (7) 2013/03 (1)