end
This commit is contained in:
parent
86b87f5cd3
commit
4b64e994c9
55
UserStatus/models.py
Normal file
55
UserStatus/models.py
Normal 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
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
89
main.py
89
main.py
@ -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")
|
||||||
|
|
||||||
@ -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}))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user