Initial commit
This commit is contained in:
24
backend/api/models.py
Normal file
24
backend/api/models.py
Normal file
@@ -0,0 +1,24 @@
|
||||
from django.db import models
|
||||
from django.conf import settings
|
||||
|
||||
|
||||
class WebAuthnCredential(models.Model):
|
||||
"""Stores a registered WebAuthn (passkey/biometric) credential for a user."""
|
||||
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, related_name='webauthn_credentials')
|
||||
credential_id = models.TextField(unique=True) # base64url-encoded
|
||||
public_key = models.BinaryField() # COSE-encoded public key bytes
|
||||
sign_count = models.PositiveIntegerField(default=0)
|
||||
created_at = models.DateTimeField(auto_now_add=True)
|
||||
|
||||
def __str__(self):
|
||||
return f"WebAuthnCredential(user={self.user.username})"
|
||||
|
||||
|
||||
class WebAuthnChallenge(models.Model):
|
||||
"""Temporary storage for a pending WebAuthn challenge (expires after use)."""
|
||||
user = models.ForeignKey(settings.AUTH_USER_MODEL, on_delete=models.CASCADE, related_name='webauthn_challenges')
|
||||
challenge = models.TextField() # base64url-encoded random bytes
|
||||
created_at = models.DateTimeField(auto_now_add=True)
|
||||
|
||||
class Meta:
|
||||
indexes = [models.Index(fields=['user', 'created_at'])]
|
||||
Reference in New Issue
Block a user