DmitrMakeev
commited on
Update app.py
Browse files
app.py
CHANGED
@@ -1627,155 +1627,78 @@ def gc_forms():
|
|
1627 |
|
1628 |
|
1629 |
|
1630 |
-
|
1631 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1632 |
cursor = conn.cursor()
|
1633 |
-
|
1634 |
email = contact_data.get('email')
|
1635 |
if not email:
|
1636 |
logging.error(f"Missing email in contact data: {contact_data}")
|
1637 |
return
|
1638 |
-
|
1639 |
cursor.execute("SELECT id FROM contacts WHERE email = ?", (email,))
|
1640 |
contact = cursor.fetchone()
|
1641 |
-
|
1642 |
-
|
1643 |
-
|
1644 |
-
|
1645 |
-
|
1646 |
-
transformed_data[field] = json.dumps(value)
|
1647 |
-
else:
|
1648 |
-
transformed_data[field] = str(value)
|
1649 |
|
1650 |
if contact:
|
1651 |
-
update_query = """
|
1652 |
-
|
1653 |
-
name = ?, phone = ?, email = ?, vk_id = ?, chat_id = ?, ws_st = ?, ws_stop = ?,
|
1654 |
-
web_st = ?, fin_prog = ?, b_city = ?, b_fin = ?, b_ban = ?, b_ign = ?, b_baners = ?,
|
1655 |
-
b_butt = ?, b_mess = ?, shop_st = ?, curator = ?, pr1 = ?, pr2 = ?, pr3 = ?, pr4 = ?,
|
1656 |
-
pr5 = ?, ad_url = ?, key_pr = ?, n_con = ?, canal = ?, data_t = ?
|
1657 |
-
WHERE id = ?
|
1658 |
-
"""
|
1659 |
-
cursor.execute(update_query, (
|
1660 |
-
transformed_data["name"], transformed_data["phone"], transformed_data["email"], transformed_data["vk_id"], transformed_data["chat_id"],
|
1661 |
-
transformed_data["ws_st"], transformed_data["ws_stop"], transformed_data["web_st"], transformed_data["fin_prog"], transformed_data["b_city"],
|
1662 |
-
transformed_data["b_fin"], transformed_data["b_ban"], transformed_data["b_ign"], transformed_data["b_baners"], transformed_data["b_butt"],
|
1663 |
-
transformed_data["b_mess"], transformed_data["shop_st"], transformed_data["curator"], transformed_data["pr1"], transformed_data["pr2"],
|
1664 |
-
transformed_data["pr3"], transformed_data["pr4"], transformed_data["pr5"], transformed_data["ad_url"], transformed_data["key_pr"],
|
1665 |
-
transformed_data["n_con"], transformed_data["canal"], transformed_data["data_t"], contact[0]
|
1666 |
-
))
|
1667 |
else:
|
1668 |
-
insert_query = """
|
1669 |
-
|
1670 |
-
|
1671 |
-
key_pr, n_con, canal, data_t)
|
1672 |
-
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
1673 |
-
"""
|
1674 |
-
cursor.execute(insert_query, (
|
1675 |
-
transformed_data["name"], transformed_data["phone"], transformed_data["email"], transformed_data["vk_id"], transformed_data["chat_id"],
|
1676 |
-
transformed_data["ws_st"], transformed_data["ws_stop"], transformed_data["web_st"], transformed_data["fin_prog"], transformed_data["b_city"],
|
1677 |
-
transformed_data["b_fin"], transformed_data["b_ban"], transformed_data["b_ign"], transformed_data["b_baners"], transformed_data["b_butt"],
|
1678 |
-
transformed_data["b_mess"], transformed_data["shop_st"], transformed_data["curator"], transformed_data["pr1"], transformed_data["pr2"],
|
1679 |
-
transformed_data["pr3"], transformed_data["pr4"], transformed_data["pr5"], transformed_data["ad_url"], transformed_data["key_pr"],
|
1680 |
-
transformed_data["n_con"], transformed_data["canal"], transformed_data["data_t"]
|
1681 |
-
))
|
1682 |
-
|
1683 |
conn.commit()
|
1684 |
conn.close()
|
1685 |
|
1686 |
-
|
1687 |
@app.route('/add_data_ver', methods=['GET'])
|
1688 |
def add_data_ver():
|
1689 |
-
|
1690 |
-
|
1691 |
-
|
1692 |
-
|
1693 |
-
|
1694 |
-
|
1695 |
-
name = request.args.get('name')
|
1696 |
-
phone = request.args.get('phone')
|
1697 |
-
email = request.args.get('email')
|
1698 |
-
pr1 = request.args.get('pr1', '')
|
1699 |
-
pr2 = request.args.get('pr2', '')
|
1700 |
-
pr3 = request.args.get('pr3', '')
|
1701 |
-
pr4 = request.args.get('pr4', '')
|
1702 |
-
pr5 = request.args.get('pr5', '')
|
1703 |
-
canal = request.args.get('canal', '')
|
1704 |
-
|
1705 |
-
if not name or not phone or not email:
|
1706 |
-
return "Parameters 'name', 'phone', and 'email' are required.", 400
|
1707 |
-
|
1708 |
-
# Clean up phone number by removing any leading plus sign
|
1709 |
-
if phone.startswith('+'):
|
1710 |
-
phone = phone[1:]
|
1711 |
-
|
1712 |
-
ws_statys = verify_phone_number(phone)
|
1713 |
-
|
1714 |
-
utc_now = datetime.utcnow()
|
1715 |
-
msk_tz = pytz.timezone('Europe/Moscow')
|
1716 |
-
msk_now = utc_now.replace(tzinfo=pytz.utc).astimezone(msk_tz)
|
1717 |
-
data_t = msk_now.strftime('%Y-%m-%d %H:%M:%S')
|
1718 |
-
|
1719 |
-
user_data = {
|
1720 |
-
"name": name,
|
1721 |
-
"phone": phone,
|
1722 |
-
"email": email,
|
1723 |
-
"ws_st": ws_statys,
|
1724 |
-
"pr1": pr1,
|
1725 |
-
"pr2": pr2,
|
1726 |
-
"pr3": pr3,
|
1727 |
-
"pr4": pr4,
|
1728 |
-
"pr5": pr5,
|
1729 |
-
"canal": canal,
|
1730 |
-
"data_t": data_t,
|
1731 |
-
"vk_id": "",
|
1732 |
-
"chat_id": "",
|
1733 |
-
"ws_stop": "",
|
1734 |
-
"web_st": 0,
|
1735 |
-
"fin_prog": 0,
|
1736 |
-
"b_city": "",
|
1737 |
-
"b_fin": "",
|
1738 |
-
"b_ban": "",
|
1739 |
-
"b_ign": "",
|
1740 |
-
"b_baners": "",
|
1741 |
-
"b_butt": "",
|
1742 |
-
"b_mess": "",
|
1743 |
-
"shop_st": "",
|
1744 |
-
"curator": "",
|
1745 |
-
"ad_url": "",
|
1746 |
-
"key_pr": "",
|
1747 |
-
"n_con": ""
|
1748 |
-
}
|
1749 |
-
|
1750 |
-
for db_name in DATABASES:
|
1751 |
-
conn = sqlite3.connect(db_name)
|
1752 |
-
cursor = conn.cursor()
|
1753 |
-
cursor.execute('SELECT * FROM contacts WHERE phone = ? OR email = ?', (phone, email))
|
1754 |
-
existing_contact = cursor.fetchone()
|
1755 |
-
|
1756 |
-
if existing_contact:
|
1757 |
-
update_query = "UPDATE contacts SET "
|
1758 |
-
update_values = []
|
1759 |
-
for column, value in user_data.items():
|
1760 |
-
update_query += f"{column} = ?, "
|
1761 |
-
update_values.append(value)
|
1762 |
-
update_query = update_query.rstrip(", ") + " WHERE phone = ? OR email = ?"
|
1763 |
-
update_values.extend([phone, email])
|
1764 |
-
cursor.execute(update_query, update_values)
|
1765 |
-
else:
|
1766 |
-
columns = ', '.join(user_data.keys())
|
1767 |
-
placeholders = ', '.join('?' for _ in user_data)
|
1768 |
-
insert_query = f"INSERT INTO contacts ({columns}) VALUES ({placeholders})"
|
1769 |
-
insert_values = list(user_data.values())
|
1770 |
-
cursor.execute(insert_query, insert_values)
|
1771 |
|
1772 |
-
|
1773 |
-
|
|
|
1774 |
|
1775 |
-
|
|
|
|
|
1776 |
except Exception as e:
|
1777 |
-
|
1778 |
-
return
|
1779 |
|
1780 |
|
1781 |
|
|
|
1627 |
|
1628 |
|
1629 |
|
1630 |
+
# Функция для верификации номера телефона
|
1631 |
+
def verify_phone_number(phone_number):
|
1632 |
+
|
1633 |
+
|
1634 |
+
if verifikation_start == "1":
|
1635 |
+
|
1636 |
+
full_url_ver = f"{wa_url}{wa_ak}{ws_url_ver}{wa_api_key}"
|
1637 |
+
|
1638 |
+
payload = json.dumps({
|
1639 |
+
"phoneNumber": phone_number
|
1640 |
+
})
|
1641 |
+
headers = {
|
1642 |
+
'Content-Type': 'application/json'
|
1643 |
+
}
|
1644 |
+
|
1645 |
+
response = requests.post(full_url_ver, headers=headers, data=payload)
|
1646 |
+
|
1647 |
+
if response.status_code == 200:
|
1648 |
+
result = response.json()
|
1649 |
+
return result # Вернуть весь ответ, как есть
|
1650 |
+
else:
|
1651 |
+
return {"existsWhatsapp": False}
|
1652 |
+
else:
|
1653 |
+
return {"existsWhatsapp": False}
|
1654 |
+
|
1655 |
+
|
1656 |
+
# Функция для добавления или обновления контакта в базе данных
|
1657 |
+
def add_or_update_contact(contact_data):
|
1658 |
+
conn = sqlite3.connect(DATABASE_NAME)
|
1659 |
cursor = conn.cursor()
|
1660 |
+
|
1661 |
email = contact_data.get('email')
|
1662 |
if not email:
|
1663 |
logging.error(f"Missing email in contact data: {contact_data}")
|
1664 |
return
|
1665 |
+
|
1666 |
cursor.execute("SELECT id FROM contacts WHERE email = ?", (email,))
|
1667 |
contact = cursor.fetchone()
|
1668 |
+
|
1669 |
+
fields = ["name", "phone", "email", "vk_id", "chat_id", "ws_st", "ws_stop", "web_st", "fin_prog", "b_city",
|
1670 |
+
"b_fin", "b_ban", "b_ign", "b_baners", "b_butt", "b_mess", "shop_st", "curator", "pr1", "pr2",
|
1671 |
+
"pr3", "pr4", "pr5", "ad_url", "key_pr", "n_con", "canal", "data_t"]
|
1672 |
+
transformed_data = {field: contact_data.get(field, "") for field in fields}
|
|
|
|
|
|
|
1673 |
|
1674 |
if contact:
|
1675 |
+
update_query = "UPDATE contacts SET " + ", ".join([f"{field} = ?" for field in fields]) + " WHERE id = ?"
|
1676 |
+
cursor.execute(update_query, (*transformed_data.values(), contact[0]))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1677 |
else:
|
1678 |
+
insert_query = "INSERT INTO contacts (" + ", ".join(fields) + ") VALUES (" + ", ".join(["?" for _ in fields]) + ")"
|
1679 |
+
cursor.execute(insert_query, tuple(transformed_data.values()))
|
1680 |
+
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1681 |
conn.commit()
|
1682 |
conn.close()
|
1683 |
|
|
|
1684 |
@app.route('/add_data_ver', methods=['GET'])
|
1685 |
def add_data_ver():
|
1686 |
+
contact_data = {
|
1687 |
+
'name': request.args.get('name'),
|
1688 |
+
'phone': request.args.get('phone'),
|
1689 |
+
'email': request.args.get('email')
|
1690 |
+
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1691 |
|
1692 |
+
phone_verification_response = verify_phone_number(contact_data['phone'])
|
1693 |
+
if phone_verification_response is not None:
|
1694 |
+
contact_data['phone_verification'] = phone_verification_response # Сохраняем полный ответ в данных контакта
|
1695 |
|
1696 |
+
try:
|
1697 |
+
add_or_update_contact(contact_data)
|
1698 |
+
return jsonify({'status': 'success'})
|
1699 |
except Exception as e:
|
1700 |
+
logging.error(f"Error adding/updating contact: {e}")
|
1701 |
+
return jsonify({'status': 'error', 'message': str(e)}), 500
|
1702 |
|
1703 |
|
1704 |
|