You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

212 lines
10 KiB

2 months ago
from flask import abort, request, render_template, url_for, jsonify
from webApp import *
from webApp import webApp
import gspread
from oauth2client.service_account import ServiceAccountCredentials
import json
import datetime
from config import config
import requests
2 months ago
# Авторизация Google API
def authorize_google():
# google_json = {}
# for key in config["GOOGLE"].keys():
# google_json[key] = config["GOOGLE"][key]
scope = ["https://spreadsheets.google.com/feeds", "https://www.googleapis.com/auth/drive"]
creds = ServiceAccountCredentials.from_json_keyfile_name("botforclinic-436512-0c117dd103a8.json", scope)
# creds = ServiceAccountCredentials.from_json_keyfile_dict(google_json, scope)
client = gspread.authorize(creds)
return client
def find_patients(data):
"""
Поиск пациента в таблице по данным.
"""
sheet = authorize_google().open("Пациенты клиники").sheet1
records = sheet.get_all_records() # Получаем все строки таблицы
print(data)
for i, record in enumerate(records, start=2): # Нумерация строк Google Таблицы начинается с 2
try:
print(str(record.get("Telegram ID", "")).strip(), str(record.get("ФИО", "")).strip().lower(), str(record.get("Дата рождения", "")).strip(), str(record.get("Номер телефона", "")).strip())
print(str(data.get("user_id", "")).strip(), str(data.get("fio", "")).strip().lower(), str(data.get("dob", "")).strip(), str(data.get("tel", "")).strip())
if (
str(record.get("Telegram ID", "")).strip() == str(data.get("user_id", "")).strip() and
str(record.get("ФИО", "")).strip().lower() == str(data.get("fio", "")).strip().lower() and
str(record.get("Дата рождения", "")).strip() == str(data.get("dob", "")).strip() and
str(record.get("Номер телефона", "")).strip() == str(data.get("tel", "")).strip()
):
return i, record # Возвращаем номер строки и запись
except Exception as e:
print(f"Ошибка при сравнении записи: {e}")
continue
return None, None
2 months ago
@webApp.route('/form_submit', methods=['POST'])
def form_submit():
"""
Обработка данных формы и обновление записи в Google Таблице.
"""
try:
data = json.loads(request.data)
data['current_time'] = datetime.datetime.now().strftime("%d.%m.%Y, %H:%M")
2 months ago
# Поиск пациента
row_number, patient_row = find_patients(data)
if not patient_row:
return jsonify({'success': False, 'error': "Пациент не найден"})
# Проверка кода верификации
expected_code = str(patient_row.get("Верификация", "")).strip()
received_code = str(data.get("verification_code", "")).strip()
if expected_code != received_code:
return jsonify({'success': False, 'error': "Код верификации не совпадает"})
# Обновление записи в таблице
sheet = authorize_google().open("Пациенты клиники").sheet1
# Определяем динамический столбец по заголовкам
headers = sheet.row_values(1)
verification_col = headers.index("Верификация") + 1 # Столбцы нумеруются с 1
sheet.update_cell(row_number, verification_col, "Пройдена")
return jsonify({'success': True})
except KeyError as e:
print(f"Ключ отсутствует в данных: {e}")
return jsonify({'success': False, 'error': f"Некорректные данные: {e}"})
except Exception as e:
print(f"Ошибка при обработке формы: {e}")
return jsonify({'success': False, 'error': str(e)})
@webApp.route('/tel_verification', methods=['POST'])
def send_registration_request():
raw_data = json.loads(request.data)
"""
Блок записи в Полимед
"""
try:
HEADER = {
"Content-Type": "application/json"
}
# Разделение ФИО на части
fio = raw_data.get("fio", "")
parts = fio.split(" ")
if len(parts) < 3:
return jsonify({'success': False, "error": "ФИО должно содержать 3 слова"})
first_name = parts[1]
middle_name = " ".join(parts[2:])
last_name = parts[0]
# Обработка номера телефона
raw_phone = raw_data.get("tel", "")
formatted_phone = ''.join(filter(str.isdigit, raw_phone))
if formatted_phone.startswith("7"):
formatted_phone = formatted_phone
# Обработка даты рождения
dob = raw_data.get("dob", "")
if not dob:
return jsonify({'success': False, "error": "Дата рождения отсутствует"})
birth_year = dob.split("-")[0] # Предполагается формат "YYYY-MM-DD"
# Данные для отправки в сервер Полимед
data = {
"telegram_id": raw_data.get("user_id"),
"first_name": first_name,
"second_name": middle_name,
"last_name": last_name,
"mobile_phone": formatted_phone,
"birthday": birth_year
}
print("Отправляемые данные на сервер:", data)
response = requests.post("http://192.168.1.10:8080/AppFindPac", headers=HEADER, json=data)
if response.status_code == 200:
result = response.json()
print("Результат JSON:", result)
if result.get('result', None):
if result.get('result', None) == 'OK':
# return jsonify({'success': True, 'message': "Скоро вам позвонят!"})
pass
else:
return jsonify({'success': False, "error": "Пользователь не найден среди пациентов клиники. <br> Если у Вас возникли вопросы по регистрации, Вы можете связаться с нами в рабочие часы по телефону: +7 (342)207-03-03."})
else:
return jsonify({'success': False, "error": "Ошибка формата запроса"})
else:
print(f"Ошибка при отправке данных. Статус-код: {response.status_code}")
return jsonify({'success': False, "error": "Ошибка отправки данных в Полимед"})
except Exception as e:
print(f"Ошибка обработки данных для Полимед: {e}")
return jsonify({'success': False, "error": "Ошибка обработки данных для Полимед"})
"""
Блок верификации через SMS
"""
try:
url = "https://sms.ru/code/call"
api_key = "2ED72E61-76C8-5637-3587-2792D47B698C"
# Отправка запроса на вызов с кодом верификации
response = requests.post(url, data={"phone": formatted_phone, "api_id": api_key})
print(response)
json_data = response.json()
verification_code = None
current_time = datetime.datetime.now().strftime("%d.%m.%Y, %H:%M")
# Авторизация и доступ к таблице
sheet = authorize_google().open("Пациенты клиники").sheet1
# Проверка успешного получения кода
if json_data and json_data["status"] == "OK":
verification_code = json_data.get("code")
# Поиск пациента
row_number, patient_row = find_patients(raw_data)
if patient_row:
# Обновление записи в таблице
sheet = authorize_google().open("Пациенты клиники").sheet1
# Определяем динамический столбец по заголовкам
headers = sheet.row_values(1)
verification_col = headers.index("Верификация") + 1 # Столбцы нумеруются с 1
sheet.update_cell(row_number, verification_col, verification_code)
else:
# Записываем данные и код верификации в таблицу
sheet.append_row([
fio,
raw_phone,
dob,
raw_data.get("user_id"), # Telegram ID пользователя
current_time, # Время отправки данных
verification_code # Код верификации
])
print(f"Код верификации, отправленный пользователю: {verification_code}")
return jsonify({'success': True})
else:
print("Звонок не может быть выполнен.")
print("Текст ошибки:", json_data.get("status_text"))
return jsonify({'success': False, "error": "Если звонок не поступил, это может быть связано с временными работами на сервере. <br> Пожалуйста, попробуйте зарегистрироваться позже!"})
2 months ago
except Exception as e:
print(f"Ошибка при обработке SMS верификации: {e}")
return jsonify({'success': False, "error": "Если звонок не поступил, это может быть связано с временными работами на сервере. <br> Пожалуйста, попробуйте зарегистрироваться позже!"})
2 months ago
@webApp.route('/')
def main_page_2_0():
return render_template('2.0/main_page.pug', user_id=request.args.get('user_id', None))