from flask import Flask, request, render_template_string, send_from_directory, jsonify, render_template, Response from flask import render_template import sqlite3 import os import uuid import shutil import requests import re import json import base64 import logging import csv from datetime import datetime import pytz import psutil from ns import send_ns api_key_sys = os.getenv('api_key_sys') app = Flask(__name__, template_folder="./") app.config['DEBUG'] = True UPLOAD_FOLDER = 'static' HTML_FOLDER = 'html' # Создание директорий, если они не существуют if not os.path.exists(UPLOAD_FOLDER): os.makedirs(UPLOAD_FOLDER) if not os.path.exists(HTML_FOLDER): os.makedirs(HTML_FOLDER) DATABASES = ['data_gc.db', 'data1.db', 'data2.db', 'data3.db', 'data4.db', 'data5.db'] def init_db(db_name): conn = sqlite3.connect(db_name) cursor = conn.cursor() cursor.execute(''' CREATE TABLE IF NOT EXISTS contacts ( id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, phone TEXT NOT NULL, email TEXT NOT NULL, vk_id TEXT, chat_id TEXT, ws_st TEXT, ws_stop TEXT, web_st INTEGER, fin_prog INTEGER, b_city TEXT, b_fin TEXT, b_ban TEXT, b_ign TEXT, b_baners TEXT, b_butt TEXT, b_mess TEXT, shop_st TEXT, curator TEXT, pr1 TEXT, pr2 TEXT, pr3 TEXT, pr4 TEXT, pr5 TEXT, gc_url TEXT, key_pr TEXT, n_con TEXT, canal TEXT, data_on TEXT, data_t TEXT, utm_source TEXT, utm_medium TEXT, utm_campaign TEXT, utm_term TEXT, utm_content TEXT, gcpc TEXT ) ''') conn.commit() conn.close() for db in DATABASES: init_db(db) DATABASE = 'data_gc.db' @app.route('/order_new', methods=['GET']) def shop_order_new(): try: api_sys_control = request.args.get('api_sys') if api_sys_control != api_key_sys: return json.dumps({"error": "Unauthorized access"}), 403 name = request.args.get('name', '') email = request.args.get('email', '') phone = request.args.get('phone', '').lstrip('+') order = request.args.get('order', '') status = request.args.get('status', '') del_flag = request.args.get('del', '') n_con_flag = request.args.get('n_con', '') # Добавлен параметр n_con if not email or not phone: return json.dumps({"error": "Email and phone are required"}), 400 # Очистка номера телефона phone = clean_phone_number_ss(phone) conn = sqlite3.connect(DATABASE) cursor = conn.cursor() cursor.execute("SELECT * FROM contacts WHERE email = ? OR phone = ?", (email, phone)) result = cursor.fetchone() if result: shop_st = result[17] if result[17] else '{}' shop_st_data = json.loads(shop_st) print(f"Existing record found. Loaded JSON: {shop_st_data}") else: shop_st_data = {} if del_flag == '1': if order in shop_st_data: del shop_st_data[order] elif order and status: shop_st_data[order] = status shop_st_json = json.dumps(shop_st_data) # Получение текущей даты и времени в Московском часовом поясе utc_now = datetime.utcnow() msk_tz = pytz.timezone('Europe/Moscow') msk_now = utc_now.replace(tzinfo=pytz.utc).astimezone(msk_tz) data_on = msk_now.strftime('%Y-%m-%d %H:%M:%S') # Исключаем все столбцы, кроме name, phone, email, shop_st, n_con, data_on columns_to_update = ['name', 'phone', 'email', 'shop_st', 'n_con', 'data_on'] values_to_update = [name, phone, email, shop_st_json, n_con_flag, data_on] if result: # Обновляем только те поля, которые переданы в запросе set_clause = ', '.join([f"{col} = ?" for col in columns_to_update]) query = f"UPDATE contacts SET {set_clause} WHERE email = ? OR phone = ?" cursor.execute(query, values_to_update + [email, phone]) else: # Вставляем новые данные query = f"INSERT INTO contacts ({', '.join(columns_to_update)}) VALUES ({', '.join(['?' for _ in columns_to_update])})" cursor.execute(query, values_to_update) conn.commit() # Замена NULL на пустые строки replace_null_with_empty_string(conn) conn.close() return json.dumps(shop_st_data), 200 except Exception as e: return json.dumps({"error": str(e)}), 500 @app.route('/get_current_time', methods=['GET']) def get_current_time(): utc_now = datetime.utcnow() msk_tz = pytz.timezone('Europe/Moscow') msk_now = utc_now.replace(tzinfo=pytz.utc).astimezone(msk_tz) current_time = msk_now.strftime('%Y-%m-%d %H:%M:%S') return jsonify({'current_time': current_time}) # Отправка в НС1 в раб. дни нужно поправить нас групп @app.route('/add_ns', methods=['GET']) def handle_in1(): name = request.args.get('name') email = request.args.get('email') phone = request.args.get('phone') base_url = 'https://api.notisend.ru/v1' token = request.args.get('token') list_id = request.args.get('list_id') phone_id = request.args.get('phone_id') name_id = request.args.get('name_id') # Проверка наличия всех необходимых параметров if not all([name, email, phone, token, list_id, phone_id, name_id]): return jsonify({'error': 'Missing required parameters'}), 400 # Отправляем запросы в три разных места response_ns = send_ns(base_url, token, list_id, email, phone, name, phone_id, name_id) # Возвращаем список ответов return jsonify({'responses': [response_ns]}) @app.route('/upload', methods=['POST']) def upload_file(): if 'file' not in request.files: return "No file part", 400 file = request.files['file'] if file.filename == '': return "No selected file", 400 # Генерация уникального имени файла unique_filename = str(uuid.uuid4()) + os.path.splitext(file.filename)[1] save_path = os.path.join(UPLOAD_FOLDER, unique_filename) file.save(save_path) # Возвращаем полный URL загруженного файла с протоколом https full_url = request.url_root.replace('http://', 'https://') + 'uploads/' + unique_filename return f"File uploaded successfully and saved to {full_url}", 200 @app.route('/uploads/', methods=['GET']) def uploaded_file(filename): return send_from_directory(UPLOAD_FOLDER, filename) @app.route('/up_fa', methods=['GET']) def up_fa(): return render_template('up_fa.html') @app.route('/ns_info', methods=['GET']) def ns_info(): return render_template('ns_info.html') @app.route('/api/group//parameters', methods=['GET']) def get_group_parameters(group_id): api_token = request.args.get('apiToken') if not api_token: return jsonify({'error': 'API Token is required'}), 400 url = f'https://api.notisend.ru/v1/email/lists/{group_id}/parameters' headers = { 'Content-Type': 'application/json', 'Authorization': f'Bearer {api_token}' } try: response = requests.get(url, headers=headers) response.raise_for_status() data = response.json() return jsonify(data) except requests.RequestException as e: return jsonify({'error': str(e)}), 500 @app.route('/up_page', methods=['POST']) def upload_page(): if 'file' not in request.files: return "No file part", 400 file = request.files['file'] if file.filename == '': return "No selected file", 400 filename = request.form.get('filename') if not filename: return "Filename is required", 400 save_path = os.path.join(HTML_FOLDER, filename + '.html') file.save(save_path) # Возвращаем полный URL загруженного файла с протоколом https full_url = request.url_root.replace('http://', 'https://') + filename return f"Page uploaded successfully and saved to {full_url}", 200 @app.route('/', methods=['GET']) def serve_html(filename): if not filename.endswith('.html'): filename += '.html' return send_from_directory(HTML_FOLDER, filename) @app.route('/up_page', methods=['GET']) def up_page(): return render_template('up_page.html') @app.route('/monitor', methods=['GET']) def monitor(): # Получаем информацию о загруженных файлах files = os.listdir(UPLOAD_FOLDER) html_files = os.listdir(HTML_FOLDER) # Получаем информацию о дисковом пространстве total, used, free = shutil.disk_usage("/") # Преобразуем байты в гигабайты для удобства чтения total_gb = total // (2**30) used_gb = used // (2**30) free_gb = free // (2**30) # Получаем информацию об использовании оперативной памяти memory = psutil.virtual_memory() memory_total_gb = memory.total // (2**30) memory_used_gb = memory.used // (2**30) memory_free_gb = memory.free // (2**30) # Получаем информацию о количестве процессоров cpu_count = psutil.cpu_count(logical=True) return render_template('monitor.html', uploaded_files=files, uploaded_html_files=html_files, disk_space={ 'total': f"{total_gb} GB", 'used': f"{used_gb} GB", 'free': f"{free_gb} GB" }, memory_usage={ 'total': f"{memory_total_gb} GB", 'used': f"{memory_used_gb} GB", 'free': f"{memory_free_gb} GB" }, cpu_count=cpu_count) if __name__ == '__main__': app.run(host='0.0.0.0', port=int(os.environ.get('PORT', 7860)))