|
1 | 1 | from nxtbn.users.utils.jwt_utils import JWTManager
|
2 | 2 | from django.contrib.auth.models import AnonymousUser
|
| 3 | +from django.contrib.auth import get_user_model |
3 | 4 |
|
4 |
| -class GraphQLJWTMiddleware: |
| 5 | +class NXTBNGraphQLAuthenticationMiddleware: |
5 | 6 | def __init__(self):
|
6 | 7 | self.jwt_manager = JWTManager()
|
7 | 8 |
|
8 | 9 | def resolve(self, next, root, info, **args):
|
9 | 10 | request = info.context
|
10 | 11 |
|
11 |
| - token = self.get_token_from_request(request) |
| 12 | + # First check JWT token |
| 13 | + user = self.get_user_from_jwt(request) |
| 14 | + |
| 15 | + # If no JWT token, fall back to session-based authentication |
| 16 | + if not user.is_authenticated: |
| 17 | + user = self.get_user_from_session(request) |
12 | 18 |
|
13 |
| - if token: |
14 |
| - user = self.jwt_manager.verify_jwt_token(token) |
15 |
| - if user: |
16 |
| - info.context.user = user |
17 |
| - else: |
18 |
| - info.context.user = AnonymousUser() |
19 |
| - else: |
20 |
| - info.context.user = AnonymousUser() |
| 19 | + # If no valid user from either method, set as AnonymousUser |
| 20 | + if not user.is_authenticated: |
| 21 | + user = AnonymousUser() |
| 22 | + |
| 23 | + info.context.user = user |
21 | 24 |
|
22 | 25 | # Continue processing the query
|
23 | 26 | return next(root, info, **args)
|
24 | 27 |
|
| 28 | + def get_user_from_jwt(self, request): |
| 29 | + token = self.get_token_from_request(request) |
| 30 | + if token: |
| 31 | + return self.jwt_manager.verify_jwt_token(token) or AnonymousUser() |
| 32 | + return AnonymousUser() |
| 33 | + |
| 34 | + def get_user_from_session(self, request): |
| 35 | + return request.user if request.user.is_authenticated else AnonymousUser() |
| 36 | + |
25 | 37 | def get_token_from_request(self, request):
|
26 |
| - """Extract the token from the Authorization header or cookies.""" |
27 |
| - # Check Authorization header |
28 | 38 | auth_header = request.headers.get("Authorization")
|
29 | 39 | if auth_header and auth_header.startswith("Bearer "):
|
30 | 40 | return auth_header.split(" ")[1]
|
31 | 41 |
|
32 |
| - # Fallback to cookies |
33 | 42 | return request.COOKIES.get("access_token")
|
0 commit comments