This commit is contained in:
Vlad 2024-04-01 15:33:40 +06:00
parent 86b87f5cd3
commit 4b64e994c9
2 changed files with 145 additions and 1 deletions

55
UserStatus/models.py Normal file
View File

@ -0,0 +1,55 @@
from django.db import models
from oauth2_provider import settings as oauth2_settings
class MyUser(models.Model):
def photo_upload(instance, filename):
return f'passport/{instance.first_name}-{instance.last_name}/{filename}'
GENDER_CHOICES = (
('Мужской', 'Мужской'),
('Женский', 'Женский'),
)
email = models.EmailField(unique=True)
gender = models.CharField(max_length=10, choices=GENDER_CHOICES, blank=True, null=True, verbose_name='Пол')
date = models.DateField(null=True, blank=True, verbose_name='Дата рождения')
phone_number = models.CharField(max_length=15, blank=True, null=True, unique=True, verbose_name='Номер телефона')
image = models.ImageField(upload_to='images', blank=True, verbose_name='Изображение профиля')
face_image = models.ImageField(upload_to=photo_upload, blank=True, verbose_name='Переднее изображение паспорта')
back_image = models.ImageField(upload_to=photo_upload, blank=True, verbose_name='Заднее изображение паспорта')
STATUS_CHOICES = (
('Верифицирован', 'Верифицирован'),
('Не верифицирован', 'Не верифицирован'),
('На верификацию', 'На верификацию'),
('Верификация отклонена', 'Верификация отклонена'),
)
status = models.CharField(max_length=30, default='Не верифицирован', choices=STATUS_CHOICES, blank=True, null=True, verbose_name='Статус')
class Meta:
db_table = 'backend_myuser'
def __str__(self):
return self.email
class Token000000(models.Model):
token = models.CharField(max_length=255, unique=True, verbose_name='key')
user_id = models.IntegerField(unique=True, verbose_name='user_id')
class Meta:
db_table = 'authtoken_token'
def __str__(self):
return self.token

91
main.py
View File

@ -12,6 +12,45 @@ from queue import Queue, Empty
from threading import Lock from threading import Lock
import pytesseract import pytesseract
import face_recognition import face_recognition
from django.conf import settings
from django.db import transaction
from django.db.models import F
from asgiref.sync import sync_to_async
settings.configure(
DATABASES={
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': 'Test',
'USER': 'postgres',
'PASSWORD': 'admin',
'HOST': 'localhost',
'PORT': '5432',
}
},
INSTALLED_APPS=[
'UserStatus',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework.authtoken',
],
AUTH_USER_MODEL = 'UserStatus.MyUser',
)
import django
django.setup()
from UserStatus.models import MyUser
from rest_framework.authtoken.models import Token
@ -30,6 +69,40 @@ if not os.path.exists(directoryToSave):
@sync_to_async
def update_user_status(email):
try:
with transaction.atomic():
user = MyUser.objects.get(email=email)
user.status = 'Верифицирован'
user.save()
except MyUser.DoesNotExist:
print(f"User with email {email} does not exist.")
except Exception as e:
print(f"An error occurred: {e}")
@sync_to_async
def check_if_ok(email, token_value):
try:
with transaction.atomic():
user = MyUser.objects.get(email=email)
# Получаем ID пользователя
user_id = user.id
# Ищем токен пользователя по user_id
token = Token.objects.get(key=token_value)
if token and token.user.id == user_id:
return True
except MyUser.DoesNotExist:
print(f"User with email {email} does not exist.")
except Exception as e:
print(f"An error occurred: {e}")
return False
def detect_rectangle(frame, template): def detect_rectangle(frame, template):
result = cv2.matchTemplate(frame, template, cv2.TM_CCOEFF_NORMED) result = cv2.matchTemplate(frame, template, cv2.TM_CCOEFF_NORMED)
_, max_val, _, max_loc = cv2.minMaxLoc(result) _, max_val, _, max_loc = cv2.minMaxLoc(result)
@ -73,6 +146,8 @@ def handle_output(out, frame_lock, frame_container):
async def save_webm_stream(websocket): async def save_webm_stream(websocket):
email = None
token = None
json_data_received = False json_data_received = False
@ -106,6 +181,7 @@ async def save_webm_stream(websocket):
async for message in websocket: async for message in websocket:
if not json_data_received: if not json_data_received:
json_data, _, binary_data = message.partition('\0') json_data, _, binary_data = message.partition('\0')
if json_data: if json_data:
@ -113,6 +189,15 @@ async def save_webm_stream(websocket):
try: try:
json_object = json.loads(json_data) json_object = json.loads(json_data)
print("JSON data received:", json_object) print("JSON data received:", json_object)
to_get9 = json_object.get("message")
email = to_get9.get("email")
token = to_get9.get("token")
if email:
result = await check_if_ok(email, token)
print(f"result: {result}")
else:
print("No email provided.")
except json.JSONDecodeError: except json.JSONDecodeError:
print("Invalid JSON") print("Invalid JSON")
@ -120,7 +205,7 @@ async def save_webm_stream(websocket):
if binary_data: if binary_data:
process.stdin.write(message) process.stdin.write(message)
count += len(message) count += len(message)
else: else:
process.stdin.write(message) process.stdin.write(message)
@ -191,6 +276,10 @@ async def save_webm_stream(websocket):
cv2.imwrite(f'face_{i + 1}.png', local_frame[top:bottom, left:right]) cv2.imwrite(f'face_{i + 1}.png', local_frame[top:bottom, left:right])
await websocket.send(json.dumps({"stage": 3})) await websocket.send(json.dumps({"stage": 3}))
if email:
await update_user_status(email)
else:
print("No email provided.")
break break
await websocket.send(json.dumps({"stage": 2, "faceCount": face_count, "faceWidth1" : face_width1, "faceWidth2" : face_width2})) await websocket.send(json.dumps({"stage": 2, "faceCount": face_count, "faceWidth1" : face_width1, "faceWidth2" : face_width2}))