From 61ac955c2dcad5c18b16fc92ac8fb6590f52511e Mon Sep 17 00:00:00 2001 From: zayac Date: Thu, 25 Apr 2024 14:24:59 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=BA=86=E5=AD=98=E6=AC=BE?= =?UTF-8?q?=E9=87=91=E9=A2=9D=E4=B8=8D=E8=83=BD=E6=AD=A3=E5=B8=B8=E6=98=BE?= =?UTF-8?q?=E7=A4=BA=E7=9A=84=E9=97=AE=E9=A2=98,=E6=B7=BB=E5=8A=A0?= =?UTF-8?q?=E4=BA=86lastBetTime=E5=AD=97=E6=AE=B5?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Dockerfile => src/change_url/Dockerfile | 2 +- src/change_url/app.py | 2 +- src/change_url/change_url.py | 28 ++++++++++++++----------- src/entity/member.py | 1 + src/entity/pay_record.py | 2 +- 5 files changed, 20 insertions(+), 15 deletions(-) rename Dockerfile => src/change_url/Dockerfile (94%) diff --git a/Dockerfile b/src/change_url/Dockerfile similarity index 94% rename from Dockerfile rename to src/change_url/Dockerfile index ecfdf8a..c4e20cd 100644 --- a/Dockerfile +++ b/src/change_url/Dockerfile @@ -2,7 +2,7 @@ FROM python:3.11 # 将应用代码复制到 /app 目录下 -COPY src/change_url /app +COPY . /app COPY requirements.txt /app/requirements.txt # 设置工作目录 diff --git a/src/change_url/app.py b/src/change_url/app.py index 519ae7a..804a378 100644 --- a/src/change_url/app.py +++ b/src/change_url/app.py @@ -1,5 +1,5 @@ import uvicorn -from fastapi import FastAPI, Request, Form +from fastapi import FastAPI, Request from fastapi.responses import HTMLResponse from fastapi.staticfiles import StaticFiles from fastapi.templating import Jinja2Templates diff --git a/src/change_url/change_url.py b/src/change_url/change_url.py index 65822ed..2b4039c 100644 --- a/src/change_url/change_url.py +++ b/src/change_url/change_url.py @@ -1,13 +1,15 @@ import re import requests from sqlalchemy import create_engine, text as sql_text +import portalocker +from loguru import logger try: engine = create_engine("mysql+mysqlconnector://ky_tools:HJQY35seXen8patn@1panel.stupidpz.com:3306/ky_tools") connection = engine.connect() - print('链接成功') + logger.debug('链接成功') except: - print('连接失败!') + logger.debug('连接失败!') ky_base64 = '' @@ -17,16 +19,18 @@ def read_file(filename): with open(filename, 'r') as file: return file.read() except IOError as e: - print(f"Error reading file {filename}: {e}") + logger.debug(f"Error reading file {filename}: {e}") raise def write_file(filename, content): try: with open(filename, 'w') as file: + portalocker.lock(file, portalocker.LOCK_EX) # 获取独占锁 file.write(content) + portalocker.unlock(file) # 释放锁 except IOError as e: - print(f"Error writing to file {filename}: {e}") + logger.debug(f"Error writing to file {filename}: {e}") raise @@ -80,7 +84,7 @@ def get_url_mapping(urls_with_context, template_type): "atyH5": categories.get("H5", [""])[0] if categories.get("H5", [""]) else categories.get("h5", [""])[0] } else: - print('未知模板') + logger.debug('未知模板') return return url_mapping @@ -131,7 +135,7 @@ def check_urls(url_list): elif '爱体育' in content: return 'aty', '马甲包' in content except requests.RequestException: - print(f"URL '{url}' 不可用,跳过。") + logger.debug(f"URL '{url}' 不可用,跳过。") return 'unknown', False @@ -144,9 +148,9 @@ def update_agent_url(url_list, url_type): update_stmt = sql_text("UPDATE ky_tools.ky_account SET url = :url WHERE type = :url_type") connection.execute(update_stmt, {"url": url, "url_type": url_type}) connection.commit() - print(f"{url_type}后台链接更新成功") + logger.debug(f"{url_type}后台链接更新成功") except Exception as e: - print(f"执行SQL语句出错: {e}") + logger.debug(f"执行SQL语句出错: {e}") break @@ -206,7 +210,7 @@ function visit(platform, key) { # 使用正则表达式匹配和替换链接的域名部分 for key, value in url_mapping.items(): - print(f"key: {key}, value: {value}") + logger.debug(f"key: {key}, value: {value}") pattern = re.compile(r"'{}':?\s*'(https?://[^/]+)(/[^']*)'".format(key)) existing_content = pattern.sub(lambda match: "'{0}': '{1}{2}'".format(key, value, match.group(2)), existing_content) @@ -226,7 +230,7 @@ def change_url(text): return True, url_type return True, '代理更新' except Exception as e: - print(f"An error occurred: {e}") + logger.debug(f"An error occurred: {e}") return False, 'unknown.js' @@ -256,6 +260,6 @@ H5 https://www.c0azge.vip:7988  【新】 msg = f'{res.json()["msg"]}修改失败' else: msg = '请求发生错误,请检查服务是否正常' - print(msg) + logger.debug(msg) except Exception as e: - print(f"An error occurred in the main program: {e}") \ No newline at end of file + logger.debug(f"An error occurred in the main program: {e}") diff --git a/src/entity/member.py b/src/entity/member.py index 10d1c58..44456cb 100644 --- a/src/entity/member.py +++ b/src/entity/member.py @@ -45,6 +45,7 @@ class MemberList(BaseMember): class MemberDetail(BaseMember): venueNetAmountList: list tags: str + lastBetTime: str status: Optional[int] = field(default=None) def get_first_pay_datetime(self) -> datetime: diff --git a/src/entity/pay_record.py b/src/entity/pay_record.py index 4555765..4f86026 100644 --- a/src/entity/pay_record.py +++ b/src/entity/pay_record.py @@ -246,5 +246,5 @@ def get_pay_failed_by_telegram_id(telegram_id: int) -> Optional[str]: if __name__ == '__main__': deposit_results = '\n'.join( [f"用户: `{member.name}`, 首存金额: *{member.deposit}*" for member in - get_latest_deposit_user(get_user_by_username_and_password('zayac', 'password').accounts[0], 1)]) + get_latest_deposit_user(get_user_by_username_and_password('zayac', '123456').accounts[2], 1)]) print(deposit_results)