Files
msa-django-auth/users/admin.py
icurfer 293003cf1c
All checks were successful
Build And Test / build-and-push (push) Successful in 1m57s
ssh key저장 기능 추가
2025-05-20 13:25:12 +09:00

70 lines
2.2 KiB
Python

from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from .models import CustomUser
from rest_framework_simplejwt.tokens import RefreshToken
class CustomUserAdmin(UserAdmin):
model = CustomUser
list_display = (
'email', 'name', 'grade', 'desc',
'is_active', 'is_staff', 'jwt_preview',
'encrypted_private_key_name' # ✅ 키 이름 컬럼 추가
)
list_filter = ('grade', 'is_active', 'is_staff')
search_fields = ('email', 'name')
ordering = ('email',)
readonly_fields = (
'created_at', 'last_login', 'jwt_preview',
'encrypted_private_key_name', # ✅ 키 이름 읽기 전용
'encrypted_private_key_preview'
)
fieldsets = (
(None, {'fields': ('email', 'password')}),
('Personal Info', {'fields': ('name', 'grade', 'desc')}),
('Permissions', {'fields': (
'is_active', 'is_staff', 'is_superuser',
'groups', 'user_permissions'
)}),
('Important dates', {'fields': ('last_login',)}),
('JWT Token Preview', {'fields': ('jwt_preview',)}),
('SSH Key Info', { # ✅ 키 정보 그룹
'fields': (
'encrypted_private_key_name',
'encrypted_private_key_preview'
)
}),
)
add_fieldsets = (
(None, {
'classes': ('wide',),
'fields': (
'email', 'name', 'grade', 'desc',
'password1', 'password2',
'is_active', 'is_staff', 'is_superuser'
),
}),
)
def jwt_preview(self, obj):
try:
refresh = RefreshToken.for_user(obj)
access_token = str(refresh.access_token)
return access_token[:30] + "..."
except Exception:
return "N/A"
jwt_preview.short_description = "JWT Access Preview"
def encrypted_private_key_preview(self, obj):
if obj.encrypted_private_key:
return str(obj.encrypted_private_key)[:30] + "..."
return "없음"
encrypted_private_key_preview.short_description = "SSH Key (암호화)"
admin.site.register(CustomUser, CustomUserAdmin)