DmitrMakeev commited on
Commit
f45c287
·
verified ·
1 Parent(s): 81bb96f

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +149 -73
app.py CHANGED
@@ -624,13 +624,106 @@ DATABASE_NAME = 'data_gc.db'
624
 
625
 
626
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
627
 
628
 
629
- def update_or_insert_user(db_name, user_data, mapping_template):
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
630
  conn = sqlite3.connect(db_name)
631
  cursor = conn.cursor()
632
 
633
- # Получение email пользователя из данных
634
  email = user_data.get('email')
635
  if not email:
636
  logging.error(f"User data missing email: {user_data}")
@@ -638,25 +731,20 @@ def update_or_insert_user(db_name, user_data, mapping_template):
638
 
639
  logging.debug(f"Processing user with email: {email}")
640
 
641
- # Проверка существования пользователя в базе данных по email
642
  cursor.execute("SELECT web_st, b_mess FROM contacts WHERE email = ?", (email,))
643
  user = cursor.fetchone()
644
  logging.debug(f"User found: {user}")
645
 
646
- # Вынесение увеличения значения web_st в отдельный блок
647
- web_st_value = 1 # Инициализация значения web_st
648
- current_messages = "" # Инициализация текущих сообщений
649
  if user:
650
- # Проверка текущего значения web_st и его инкрементация
651
  current_web_st = user[0] if user[0] is not None and user[0] != "" else 0
652
  web_st_value = int(current_web_st) + 1
653
  logging.debug(f"Calculated web_st_value: {web_st_value}")
654
 
655
- # Получение текущих сообщений
656
  current_messages = user[1] if user[1] is not None else ""
657
  logging.debug(f"Current messages: {current_messages}")
658
 
659
- # Обновление значения web_st
660
  cursor.execute("UPDATE contacts SET web_st = ? WHERE email = ?", (web_st_value, email))
661
  conn.commit()
662
  conn.close()
@@ -665,19 +753,16 @@ def update_or_insert_user(db_name, user_data, mapping_template):
665
  conn.close()
666
  logging.debug(f"User {email} not found, proceeding with insert")
667
 
668
- # Открываем соединение снова для остальных операций
669
  conn = sqlite3.connect(db_name)
670
  cursor = conn.cursor()
671
 
672
- # Преобразование данных пользователя на основе шаблона сопоставления
673
  transformed_data = {}
674
- for json_key, db_column in mapping_template.items():
675
  value = user_data.get(json_key, "")
676
 
677
  if isinstance(value, list):
678
- # Проверяем тип элементов списка
679
  if all(isinstance(item, str) for item in value):
680
- transformed_data[db_column] = "; ".join(value) # Сохраняем сообщения в строку
681
  else:
682
  logging.error(f"Expected list of strings for key {json_key}, but got: {value}")
683
  transformed_data[db_column] = ""
@@ -685,61 +770,55 @@ def update_or_insert_user(db_name, user_data, mapping_template):
685
  transformed_data[db_column] = str(value)
686
  logging.debug(f"Transformed data: {transformed_data}")
687
 
688
- # Заполнение обязательных полей значениями по умолчанию
689
- required_fields = [
690
- "vk_id", "chat_id", "ws_st", "ws_stop", "web_st", "fin_prog",
691
- "b_city", "b_fin", "b_ban", "b_ign", "b_baners", "b_butt", "b_mess",
692
- "shop_st", "curator", "pr1", "pr2", "pr3", "pr4", "pr5", "gc_url",
693
- "key_pr", "n_con", "canal", "data_t", 'utm_source', 'utm_medium', 'utm_campaign', 'utm_term', 'utm_content'
694
- ]
695
- for field in required_fields:
696
- if field not in transformed_data:
697
- transformed_data[field] = ""
698
- logging.debug(f"Transformed data after adding required fields: {transformed_data}")
699
-
700
- # Обработка номера телефона, если он есть
701
- if 'phone' in user_data:
702
- phone = user_data['phone']
703
- if phone.startswith('+'):
704
- phone = phone[1:]
705
- transformed_data['phone'] = phone
706
- logging.debug(f"Transformed data after phone processing: {transformed_data}")
707
-
708
- # Добавление значения web_st в данные для вставки
709
- transformed_data['web_st'] = web_st_value
710
-
711
- # Обработка сообщений
712
- new_messages = transformed_data.get('b_mess', "")
713
- if current_messages:
714
- transformed_data['b_mess'] = current_messages + "; " + new_messages
715
- else:
716
- transformed_data['b_mess'] = new_messages
717
- logging.debug(f"Transformed data after message processing: {transformed_data}")
 
 
 
 
 
 
 
 
 
 
 
 
718
 
719
- # Обновление данных пользователя в базе данных
720
- if user:
721
- update_query = "UPDATE contacts SET "
722
- update_values = []
723
- for column, value in transformed_data.items():
724
- update_query += f"{column} = ?, "
725
- update_values.append(value)
726
- update_query = update_query.rstrip(", ") + " WHERE email = ?"
727
- update_values.append(email)
728
- logging.debug(f"Update query: {update_query} with values: {update_values}")
729
- cursor.execute(update_query, update_values)
730
- else:
731
- columns = ', '.join(transformed_data.keys())
732
- placeholders = ', '.join('?' for _ in transformed_data)
733
- insert_query = f"INSERT INTO contacts ({columns}) VALUES ({placeholders})"
734
- insert_values = list(transformed_data.values())
735
- logging.debug(f"Insert query: {insert_query} with values: {insert_values}")
736
- cursor.execute(insert_query, insert_values)
737
-
738
- # Подтверждение изменений и закрытие соединения
739
  conn.commit()
740
  conn.close()
741
  logging.debug(f"User with email {email} processed successfully")
742
 
 
 
743
 
744
  @app.route('/send_request', methods=['POST'])
745
  def send_request():
@@ -757,9 +836,6 @@ def send_request():
757
  else:
758
  return jsonify({'error': 'Failed to fetch data from the API'}), response.status_code
759
 
760
-
761
-
762
-
763
  @app.route('/send_get_request', methods=['GET'])
764
  def send_get_request():
765
  token = request.args.get('token')
@@ -768,17 +844,15 @@ def send_get_request():
768
 
769
  try:
770
  response = requests.get(url, headers={'X-Token': token})
771
- response.raise_for_status() # Проверка на ошибки HTTP
772
  data = response.json()
773
 
774
- # Убедитесь, что report существует в данных
775
  if data is None or 'report' not in data:
776
  return jsonify({'error': 'No report data found'}), 500
777
 
778
  report = data.get('report', {})
779
  messages = data.get('messages', {})
780
 
781
- # Проверка на None перед использованием
782
  if report is None:
783
  return jsonify({'error': 'No report data found in the response'}), 500
784
 
@@ -810,9 +884,6 @@ def send_get_request():
810
  except requests.exceptions.RequestException as e:
811
  return jsonify({'error': f'API request failed: {str(e)}'}), 500
812
 
813
-
814
-
815
-
816
  @app.route('/webhookbz', methods=['POST'])
817
  def webhookbz():
818
  api_sys_control = request.args.get('api_sys')
@@ -875,6 +946,11 @@ def webhookbz():
875
 
876
 
877
 
 
 
 
 
 
878
 
879
 
880
 
 
624
 
625
 
626
 
627
+ # URL Google Формы как переменная
628
+ GOOGLE_FORM_URL = (
629
+ "https://docs.google.com/formResponse/d/e/1FAIpQLSc-JbmXvgpgGq6KrkXsYSsfMACVMyIDnNqrHy6jImGeSRcpiQ/formResponse"
630
+ "?usp=pp_url&entry.1556100878={name}&entry.1477412341={email}&entry.1634985541={phone}&entry.1736544219={vk_id}"
631
+ "&entry.62153872={chat_id}&entry.1913752768={ws_st}&entry.1768186232={ws_stop}&entry.1198983592={web_st}"
632
+ "&entry.994770784={fin_prog}&entry.910932310={b_city}&entry.1923801792={b_fin}&entry.2005444720={b_ban}"
633
+ "&entry.741087361={b_ign}&entry.1316159837={b_baners}&entry.355123557={b_butt}&entry.395996312={b_mess}"
634
+ "&entry.646571729={shop_st}&entry.578527800={curator}&entry.1936838964={pr1}&entry.1375537366={pr2}"
635
+ "&entry.1249356084={pr3}&entry.752547226={pr4}&entry.704766458={pr5}&entry.1837661={gc_url}&entry.398837750={key_pr}"
636
+ "&entry.225564240={n_con}&entry.1642320872={canal}&entry.1581826411={data_t}&entry.311131724={utm_source}"
637
+ "&entry.1904279859={utm_medium}&entry.740234546={utm_campaign}&entry.880981295={utm_term}&entry.431306383={utm_content}"
638
+ )
639
+
640
+ # Определяем шаблон для маппинга
641
+ mapping_template_log = {
642
+ 'name': 'name',
643
+ 'email': 'email',
644
+ 'phone': 'phone',
645
+ 'vk_id': 'vk_id',
646
+ 'chat_id': 'chat_id',
647
+ 'ws_st': 'ws_st',
648
+ 'ws_stop': 'ws_stop',
649
+ 'web_st': 'web_st',
650
+ 'fin_prog': 'fin_prog',
651
+ 'b_city': 'b_city',
652
+ 'b_fin': 'b_fin',
653
+ 'b_ban': 'b_ban',
654
+ 'b_ign': 'b_ign',
655
+ 'b_baners': 'b_baners',
656
+ 'b_butt': 'b_butt',
657
+ 'b_mess': 'b_mess',
658
+ 'shop_st': 'shop_st',
659
+ 'curator': 'curator',
660
+ 'pr1': 'pr1',
661
+ 'pr2': 'pr2',
662
+ 'pr3': 'pr3',
663
+ 'pr4': 'pr4',
664
+ 'pr5': 'pr5',
665
+ 'gc_url': 'gc_url',
666
+ 'key_pr': 'key_pr',
667
+ 'n_con': 'n_con',
668
+ 'canal': 'canal',
669
+ 'data_t': 'data_t',
670
+ 'utm_source': 'utm_source',
671
+ 'utm_medium': 'utm_medium',
672
+ 'utm_campaign': 'utm_campaign',
673
+ 'utm_term': 'utm_term',
674
+ 'utm_content': 'utm_content'
675
+ }
676
 
677
 
678
+
679
+ def send_data_to_google_form(data):
680
+ # Используем переменную GOOGLE_FORM_URL для формирования ссылки
681
+ google_form_url = GOOGLE_FORM_URL.format(
682
+ name=data.get('name', ''),
683
+ email=data.get('email', ''),
684
+ phone=data.get('phone', ''),
685
+ vk_id=data.get('vk_id', ''),
686
+ chat_id=data.get('chat_id', ''),
687
+ ws_st=data.get('ws_st', ''),
688
+ ws_stop=data.get('ws_stop', ''),
689
+ web_st=data.get('web_st', ''),
690
+ fin_prog=data.get('fin_prog', ''),
691
+ b_city=data.get('b_city', ''),
692
+ b_fin=data.get('b_fin', ''),
693
+ b_ban=data.get('b_ban', ''),
694
+ b_ign=data.get('b_ign', ''),
695
+ b_baners=data.get('b_baners', ''),
696
+ b_butt=data.get('b_butt', ''),
697
+ b_mess=data.get('b_mess', ''),
698
+ shop_st=data.get('shop_st', ''),
699
+ curator=data.get('curator', ''),
700
+ pr1=data.get('pr1', ''),
701
+ pr2=data.get('pr2', ''),
702
+ pr3=data.get('pr3', ''),
703
+ pr4=data.get('pr4', ''),
704
+ pr5=data.get('pr5', ''),
705
+ gc_url=data.get('gc_url', ''),
706
+ key_pr=data.get('key_pr', ''),
707
+ n_con=data.get('n_con', ''),
708
+ canal=data.get('canal', ''),
709
+ data_t=data.get('data_t', ''),
710
+ utm_source=data.get('utm_source', ''),
711
+ utm_medium=data.get('utm_medium', ''),
712
+ utm_campaign=data.get('utm_campaign', ''),
713
+ utm_term=data.get('utm_term', ''),
714
+ utm_content=data.get('utm_content', '')
715
+ )
716
+
717
+ response = requests.post(google_form_url)
718
+ if response.status_code != 200:
719
+ logging.error(f"Failed to send data to Google Form: {response.status_code}, {response.text}")
720
+ else:
721
+ logging.info(f"Data sent to Google Form successfully: {response.status_code}")
722
+
723
+ def update_or_insert_user(db_name, user_data, mapping_template_log):
724
  conn = sqlite3.connect(db_name)
725
  cursor = conn.cursor()
726
 
 
727
  email = user_data.get('email')
728
  if not email:
729
  logging.error(f"User data missing email: {user_data}")
 
731
 
732
  logging.debug(f"Processing user with email: {email}")
733
 
 
734
  cursor.execute("SELECT web_st, b_mess FROM contacts WHERE email = ?", (email,))
735
  user = cursor.fetchone()
736
  logging.debug(f"User found: {user}")
737
 
738
+ web_st_value = 1
739
+ current_messages = ""
 
740
  if user:
 
741
  current_web_st = user[0] if user[0] is not None and user[0] != "" else 0
742
  web_st_value = int(current_web_st) + 1
743
  logging.debug(f"Calculated web_st_value: {web_st_value}")
744
 
 
745
  current_messages = user[1] if user[1] is not None else ""
746
  logging.debug(f"Current messages: {current_messages}")
747
 
 
748
  cursor.execute("UPDATE contacts SET web_st = ? WHERE email = ?", (web_st_value, email))
749
  conn.commit()
750
  conn.close()
 
753
  conn.close()
754
  logging.debug(f"User {email} not found, proceeding with insert")
755
 
 
756
  conn = sqlite3.connect(db_name)
757
  cursor = conn.cursor()
758
 
 
759
  transformed_data = {}
760
+ for json_key, db_column in mapping_template_log.items():
761
  value = user_data.get(json_key, "")
762
 
763
  if isinstance(value, list):
 
764
  if all(isinstance(item, str) for item in value):
765
+ transformed_data[db_column] = "; ".join(value)
766
  else:
767
  logging.error(f"Expected list of strings for key {json_key}, but got: {value}")
768
  transformed_data[db_column] = ""
 
770
  transformed_data[db_column] = str(value)
771
  logging.debug(f"Transformed data: {transformed_data}")
772
 
773
+ insert_query = f"""
774
+ INSERT INTO contacts (name, phone, email, vk_id, chat_id, ws_st, ws_stop, web_st, fin_prog, b_city, b_fin, b_ban, b_ign, b_baners, b_butt, b_mess, shop_st, curator, pr1, pr2, pr3, pr4, pr5, gc_url, key_pr, n_con, canal, data_t, utm_source, utm_medium, utm_campaign, utm_term, utm_content)
775
+ VALUES (:name, :phone, :email, :vk_id, :chat_id, :ws_st, :ws_stop, :web_st, :fin_prog, :b_city, :b_fin, :b_ban, :b_ign, :b_baners, :b_butt, :b_mess, :shop_st, :curator, :pr1, :pr2, :pr3, :pr4, :pr5, :gc_url, :key_pr, :n_con, :canal, :data_t, :utm_source, :utm_medium, :utm_campaign, :utm_term, :utm_content)
776
+ """
777
+
778
+ insert_values = {
779
+ 'name': transformed_data.get('name', ''),
780
+ 'phone': transformed_data.get('phone', ''),
781
+ 'email': transformed_data.get('email', ''),
782
+ 'vk_id': transformed_data.get('vk_id', ''),
783
+ 'chat_id': transformed_data.get('chat_id', ''),
784
+ 'ws_st': transformed_data.get('ws_st', ''),
785
+ 'ws_stop': transformed_data.get('ws_stop', ''),
786
+ 'web_st': transformed_data.get('web_st', ''),
787
+ 'fin_prog': transformed_data.get('fin_prog', ''),
788
+ 'b_city': transformed_data.get('b_city', ''),
789
+ 'b_fin': transformed_data.get('b_fin', ''),
790
+ 'b_ban': transformed_data.get('b_ban', ''),
791
+ 'b_ign': transformed_data.get('b_ign', ''),
792
+ 'b_baners': transformed_data.get('b_baners', ''),
793
+ 'b_butt': transformed_data.get('b_butt', ''),
794
+ 'b_mess': transformed_data.get('b_mess', ''),
795
+ 'shop_st': transformed_data.get('shop_st', ''),
796
+ 'curator': transformed_data.get('curator', ''),
797
+ 'pr1': transformed_data.get('pr1', ''),
798
+ 'pr2': transformed_data.get('pr2', ''),
799
+ 'pr3': transformed_data.get('pr3', ''),
800
+ 'pr4': transformed_data.get('pr4', ''),
801
+ 'pr5': transformed_data.get('pr5', ''),
802
+ 'gc_url': transformed_data.get('gc_url', ''),
803
+ 'key_pr': transformed_data.get('key_pr', ''),
804
+ 'n_con': transformed_data.get('n_con', ''),
805
+ 'canal': transformed_data.get('canal', ''),
806
+ 'data_t': transformed_data.get('data_t', ''),
807
+ 'utm_source': transformed_data.get('utm_source', ''),
808
+ 'utm_medium': transformed_data.get('utm_medium', ''),
809
+ 'utm_campaign': transformed_data.get('utm_campaign', ''),
810
+ 'utm_term': transformed_data.get('utm_term', ''),
811
+ 'utm_content': transformed_data.get('utm_content', '')
812
+ }
813
+ logging.debug(f"Insert query: {insert_query} with values: {insert_values}")
814
+ cursor.execute(insert_query, insert_values)
815
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
816
  conn.commit()
817
  conn.close()
818
  logging.debug(f"User with email {email} processed successfully")
819
 
820
+ # Отправляем данные в Google Форму после обновления/вставки
821
+ send_data_to_google_form(transformed_data)
822
 
823
  @app.route('/send_request', methods=['POST'])
824
  def send_request():
 
836
  else:
837
  return jsonify({'error': 'Failed to fetch data from the API'}), response.status_code
838
 
 
 
 
839
  @app.route('/send_get_request', methods=['GET'])
840
  def send_get_request():
841
  token = request.args.get('token')
 
844
 
845
  try:
846
  response = requests.get(url, headers={'X-Token': token})
847
+ response.raise_for_status()
848
  data = response.json()
849
 
 
850
  if data is None or 'report' not in data:
851
  return jsonify({'error': 'No report data found'}), 500
852
 
853
  report = data.get('report', {})
854
  messages = data.get('messages', {})
855
 
 
856
  if report is None:
857
  return jsonify({'error': 'No report data found in the response'}), 500
858
 
 
884
  except requests.exceptions.RequestException as e:
885
  return jsonify({'error': f'API request failed: {str(e)}'}), 500
886
 
 
 
 
887
  @app.route('/webhookbz', methods=['POST'])
888
  def webhookbz():
889
  api_sys_control = request.args.get('api_sys')
 
946
 
947
 
948
 
949
+
950
+
951
+
952
+
953
+
954
 
955
 
956