fix file transfer
This commit is contained in:
		| @@ -6,6 +6,7 @@ from app.chain import ChainBase | ||||
| from app.chain.cookiecloud import CookieCloudChain | ||||
| from app.chain.douban_sync import DoubanSyncChain | ||||
| from app.chain.subscribe import SubscribeChain | ||||
| from app.chain.transfer import TransferChain | ||||
| from app.core import eventmanager, PluginManager, EventManager | ||||
| from app.core.event_manager import Event as ManagerEvent | ||||
| from app.log import logger | ||||
| @@ -44,6 +45,11 @@ class Command(metaclass=Singleton): | ||||
|             "data": { | ||||
|                 'state': 'R', | ||||
|             } | ||||
|         }, | ||||
|         "/transfer": { | ||||
|             "func": TransferChain().process, | ||||
|             "description": "下载文件整理", | ||||
|             "data": {} | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -96,7 +96,7 @@ class Settings(BaseSettings): | ||||
|     # Transmission密码 | ||||
|     TR_PASSWORD: str = None | ||||
|     # 种子标签 | ||||
|     TORRENT_TAG: str = "MP" | ||||
|     TORRENT_TAG: str = "MOVIEPILOT" | ||||
|     # 下载保存目录,容器内映射路径需要一致 | ||||
|     DOWNLOAD_PATH: str = "/downloads" | ||||
|     # 媒体服务器 emby/jellyfin/plex | ||||
|   | ||||
| @@ -9,6 +9,7 @@ from qbittorrentapi.client import Client | ||||
| from app.core import settings | ||||
| from app.log import logger | ||||
| from app.utils.singleton import Singleton | ||||
| from app.utils.string import StringUtils | ||||
|  | ||||
|  | ||||
| class Qbittorrent(metaclass=Singleton): | ||||
| @@ -21,10 +22,7 @@ class Qbittorrent(metaclass=Singleton): | ||||
|     qbc: Client = None | ||||
|  | ||||
|     def __init__(self): | ||||
|         host = settings.QB_HOST | ||||
|         if host and host.find(":") != -1: | ||||
|             self._host = settings.QB_HOST.split(":")[0] | ||||
|             self._port = settings.QB_HOST.split(":")[1] | ||||
|         self._host, self._port = StringUtils.get_domain_address(settings.QB_HOST) | ||||
|         self._username = settings.QB_USER | ||||
|         self._password = settings.QB_PASSWORD | ||||
|         if self._host and self._port and self._username and self._password: | ||||
|   | ||||
| @@ -33,13 +33,13 @@ class Telegram(metaclass=Singleton): | ||||
|  | ||||
|             @_bot.message_handler(func=lambda message: True) | ||||
|             def echo_all(message): | ||||
|                 RequestUtils(timeout=10).post_res(self._ds_url, json=message.json) | ||||
|                 RequestUtils(timeout=5).post_res(self._ds_url, json=message.json) | ||||
|  | ||||
|         def run_polling(): | ||||
|             """ | ||||
|             定义线程函数来运行 infinity_polling | ||||
|             """ | ||||
|             _bot.infinity_polling() | ||||
|             _bot.infinity_polling(long_polling_timeout=5) | ||||
|  | ||||
|         # 启动线程来运行 infinity_polling | ||||
|         self._polling_thread = threading.Thread(target=run_polling) | ||||
|   | ||||
| @@ -7,6 +7,7 @@ from transmission_rpc import Client, Torrent, File | ||||
| from app.core import settings | ||||
| from app.log import logger | ||||
| from app.utils.singleton import Singleton | ||||
| from app.utils.string import StringUtils | ||||
|  | ||||
|  | ||||
| class Transmission(metaclass=Singleton): | ||||
| @@ -25,10 +26,7 @@ class Transmission(metaclass=Singleton): | ||||
|               "error", "errorString", "doneDate", "queuePosition", "activityDate", "trackers"] | ||||
|  | ||||
|     def __init__(self): | ||||
|         host = settings.TR_HOST | ||||
|         if host and host.find(":") != -1: | ||||
|             self._host = settings.TR_HOST.split(":")[0] | ||||
|             self._port = settings.TR_HOST.split(":")[1] | ||||
|         self._host, self._port = StringUtils.get_domain_address(settings.QB_HOST) | ||||
|         self._username = settings.TR_USER | ||||
|         self._password = settings.TR_PASSWORD | ||||
|         if self._host and self._port and self._username and self._password: | ||||
|   | ||||
| @@ -530,3 +530,24 @@ class StringUtils: | ||||
|         parses = re.sub(r"([_*\[\]()~`>#+\-=|.!{}])", r"\\\1", content) | ||||
|         reparse = re.sub(r"\\\\([_*\[\]()~`>#+\-=|.!{}])", r"\1", parses) | ||||
|         return reparse | ||||
|  | ||||
|     @staticmethod | ||||
|     def get_domain_address(address: str) -> Tuple[Optional[str], Optional[int]]: | ||||
|         """ | ||||
|         从地址中获取域名和端口号 | ||||
|         """ | ||||
|         if not address.startswith("http"): | ||||
|             address = "http://" + address | ||||
|         parts = address.split(":") | ||||
|         if len(parts) > 3: | ||||
|             # 处理不希望包含多个冒号的情况(除了协议后的冒号) | ||||
|             return None, None | ||||
|         domain = ":".join(parts[:-1]) | ||||
|         # 检查是否包含端口号 | ||||
|         try: | ||||
|             port = int(parts[-1]) | ||||
|         except ValueError: | ||||
|             # 端口号不是整数,返回 None 表示无效 | ||||
|             return None, None | ||||
|         return domain, port | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user