butler_ddochi/custom_auth/models.py
icurfer ea11832a53
Some checks failed
Build And Test / build-and-push (push) Failing after 53s
init
2024-12-13 17:12:03 +09:00

43 lines
1.6 KiB
Python

from django.contrib.auth.models import AbstractUser
from django.db import models
import base64
from cryptography.fernet import Fernet
class CustomUser(AbstractUser):
"""사용자 모델 - 기존 필드 + SSH Private Key 관리 필드"""
# 기존 필드 유지
grade = models.CharField(max_length=50, blank=True, null=True)
nhnc_id = models.CharField(max_length=100, blank=True, null=True)
nhnc_api_tenant_id = models.CharField(max_length=100, blank=True, null=True)
"""사용자 모델 - SSH Private Key 관리 필드"""
encrypted_private_key = models.BinaryField(blank=True, null=True) # 암호화된 SSH 키
def encrypt_private_key(self, private_key: str) -> bytes:
"""SSH Private Key 암호화"""
cipher = Fernet(self.get_encryption_key())
return cipher.encrypt(private_key.encode())
def decrypt_private_key(self) -> str:
"""SSH Private Key 복호화"""
if self.encrypted_private_key:
cipher = Fernet(self.get_encryption_key())
return cipher.decrypt(self.encrypted_private_key).decode()
return ""
def save_private_key(self, private_key: str):
"""SSH Private Key 저장 (암호화 후)"""
self.encrypted_private_key = self.encrypt_private_key(private_key)
self.save()
def get_encryption_key(self) -> bytes:
"""Fernet 키 생성 (username 기반)"""
username_encoded = self.username.encode() # 사용자 이름을 바이트로 인코딩
base64_key = base64.urlsafe_b64encode(username_encoded.ljust(32)[:32])
return base64_key
def __str__(self):
return self.username