| 
									
										
										
										
											2025-07-14 18:32:48 +01:00
										 |  |  | import mysql.connector.pooling | 
					
						
							| 
									
										
										
										
											2025-07-14 13:42:58 +01:00
										 |  |  | from flask import jsonify, request, current_app | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  | from ktvmanager.lib.checker import single_account_check | 
					
						
							| 
									
										
										
										
											2025-07-14 11:12:13 +01:00
										 |  |  | from ktvmanager.lib.encryption import encrypt_password, decrypt_password | 
					
						
							| 
									
										
										
										
											2025-07-14 19:18:47 +01:00
										 |  |  | from ktvmanager.lib.get_urls import get_latest_urls_from_dns | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-14 18:32:48 +01:00
										 |  |  | db_pool = None | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def initialize_db_pool(): | 
					
						
							|  |  |  |     global db_pool | 
					
						
							|  |  |  |     db_pool = mysql.connector.pooling.MySQLConnectionPool( | 
					
						
							|  |  |  |         pool_name="ktv_pool", | 
					
						
							|  |  |  |         pool_size=5, | 
					
						
							| 
									
										
										
										
											2025-07-14 13:42:58 +01:00
										 |  |  |         host=current_app.config["DBHOST"], | 
					
						
							|  |  |  |         user=current_app.config["DBUSER"], | 
					
						
							|  |  |  |         password=current_app.config["DBPASS"], | 
					
						
							|  |  |  |         database=current_app.config["DATABASE"], | 
					
						
							|  |  |  |         port=current_app.config["DBPORT"] | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  |     ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  | def _execute_query(query, params=None): | 
					
						
							| 
									
										
										
										
											2025-07-14 18:32:48 +01:00
										 |  |  |     conn = db_pool.get_connection() | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     cursor = conn.cursor(dictionary=True) | 
					
						
							|  |  |  |     try: | 
					
						
							|  |  |  |         cursor.execute(query, params) | 
					
						
							|  |  |  |         if query.strip().upper().startswith("SELECT"): | 
					
						
							|  |  |  |             result = cursor.fetchall() | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             conn.commit() | 
					
						
							|  |  |  |             result = {"affected_rows": cursor.rowcount} | 
					
						
							|  |  |  |         return result | 
					
						
							|  |  |  |     finally: | 
					
						
							|  |  |  |         cursor.close() | 
					
						
							|  |  |  |         conn.close() | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  | def get_user_id_from_username(username): | 
					
						
							|  |  |  |     query = "SELECT id FROM users WHERE username = %s" | 
					
						
							|  |  |  |     result = _execute_query(query, (username,)) | 
					
						
							|  |  |  |     if result: | 
					
						
							|  |  |  |         return result[0]['id'] | 
					
						
							|  |  |  |     return None | 
					
						
							|  |  |  | def get_user_accounts(user_id): | 
					
						
							|  |  |  |     query = "SELECT * FROM userAccounts WHERE userID = %s" | 
					
						
							|  |  |  |     accounts = _execute_query(query, (user_id,)) | 
					
						
							|  |  |  |     for account in accounts: | 
					
						
							| 
									
										
										
										
											2025-07-14 11:12:13 +01:00
										 |  |  |         try: | 
					
						
							|  |  |  |             account['password'] = decrypt_password(account['password']) | 
					
						
							|  |  |  |         except Exception as e: | 
					
						
							|  |  |  |             # Log the error to the console for debugging | 
					
						
							|  |  |  |             print(f"Password decryption failed for account ID {account.get('id', 'N/A')}: {e}") | 
					
						
							|  |  |  |             account['password'] = "DECRYPTION_FAILED" | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     return jsonify(accounts) | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  | def get_stream_names(): | 
					
						
							|  |  |  |     query = "SELECT streamName FROM streams" | 
					
						
							|  |  |  |     results = _execute_query(query) | 
					
						
							|  |  |  |     stream_names = [row['streamName'] for row in results] | 
					
						
							|  |  |  |     return jsonify(stream_names) | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  | def single_check(): | 
					
						
							|  |  |  |     data = request.get_json() | 
					
						
							| 
									
										
										
										
											2025-07-14 13:42:58 +01:00
										 |  |  |     stream_urls = current_app.config["STREAM_URLS"] | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     result = single_account_check(data, stream_urls) | 
					
						
							|  |  |  |     if result: | 
					
						
							|  |  |  |         # Here you would typically update the database with the new information | 
					
						
							|  |  |  |         return jsonify(result) | 
					
						
							|  |  |  |     return jsonify({"message": "All checks failed"}), 400 | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-14 19:18:47 +01:00
										 |  |  | def add_account(user_id): | 
					
						
							|  |  |  |     data = request.form | 
					
						
							|  |  |  |     res = single_account_check(data, get_latest_urls_from_dns()) | 
					
						
							| 
									
										
										
										
											2025-07-14 11:12:13 +01:00
										 |  |  |     encrypted_password = encrypt_password(data['password']) | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     query = "INSERT INTO userAccounts (username, stream, streamURL, expiaryDate, password, userID) VALUES (%s, %s, %s, %s, %s, %s)" | 
					
						
							| 
									
										
										
										
											2025-07-14 19:18:47 +01:00
										 |  |  |     params = (data['username'], data['stream'], res['url'], res['data']['user_info']['exp_date'], encrypted_password, user_id) | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     result = _execute_query(query, params) | 
					
						
							|  |  |  |     return jsonify(result) | 
					
						
							| 
									
										
										
										
											2025-05-10 13:58:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-07-14 19:18:47 +01:00
										 |  |  | def delete_account(user_id): | 
					
						
							|  |  |  |     data = request.form | 
					
						
							|  |  |  |     query = "DELETE FROM userAccounts WHERE username = %s AND stream = %s AND userId = %s" | 
					
						
							|  |  |  |     params = (data['user'],data['stream'],user_id) | 
					
						
							| 
									
										
										
										
											2025-07-13 19:40:04 +01:00
										 |  |  |     result = _execute_query(query, params) | 
					
						
							|  |  |  |     return jsonify(result) |