Backend Draft
This commit is contained in:
44
backend/accounts/serializers.py
Normal file
44
backend/accounts/serializers.py
Normal file
@@ -0,0 +1,44 @@
|
||||
from rest_framework import serializers
|
||||
from django.contrib.auth import get_user_model
|
||||
from tenants.serializers import TenantSerializer
|
||||
from rest_framework_simplejwt.serializers import TokenObtainPairSerializer
|
||||
|
||||
User = get_user_model()
|
||||
|
||||
class CustomTokenObtainPairSerializer(TokenObtainPairSerializer):
|
||||
@classmethod
|
||||
def get_token(cls, user):
|
||||
token = super().get_token(user)
|
||||
|
||||
# Add custom claims
|
||||
token['role'] = getattr(user, 'role', 'student')
|
||||
token['tenant_id'] = user.tenant.id if getattr(user, 'tenant', None) else None
|
||||
|
||||
return token
|
||||
|
||||
class UserSerializer(serializers.ModelSerializer):
|
||||
tenant = TenantSerializer(read_only=True)
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = ['id', 'username', 'email', 'first_name', 'last_name', 'role', 'tenant', 'is_active']
|
||||
read_only_fields = ['id']
|
||||
|
||||
class RegisterSerializer(serializers.ModelSerializer):
|
||||
password = serializers.CharField(write_only=True)
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = ['username', 'email', 'password', 'first_name', 'last_name', 'role']
|
||||
|
||||
def create(self, validated_data):
|
||||
user = User.objects.create_user(
|
||||
username=validated_data['username'],
|
||||
email=validated_data.get('email', ''),
|
||||
password=validated_data['password'],
|
||||
first_name=validated_data.get('first_name', ''),
|
||||
last_name=validated_data.get('last_name', ''),
|
||||
role=validated_data.get('role', 'student'),
|
||||
tenant=self.context['request'].tenant if 'request' in self.context else None
|
||||
)
|
||||
return user
|
||||
Reference in New Issue
Block a user