fix transfer_completed

This commit is contained in:
jxxghp
2024-09-10 07:58:22 +08:00
parent 89f2bf5f30
commit d0ac5646f5
4 changed files with 22 additions and 21 deletions

View File

@@ -402,14 +402,16 @@ class ChainBase(metaclass=ABCMeta):
target_path=target_path, episodes_info=episodes_info, scrape=scrape)
def transfer_completed(self, hashs: str, path: Path = None,
downloader: str = None) -> None:
downloader: str = None, transfer_type: str = None) -> None:
"""
转移完成后的处理
:param hashs: 种子Hash
:param path: 源目录
:param downloader: 下载器
:param transfer_type: 整理方式
"""
return self.run_module("transfer_completed", hashs=hashs, path=path, downloader=downloader)
return self.run_module("transfer_completed", hashs=hashs, path=path,
downloader=downloader, transfer_type=transfer_type)
def remove_torrents(self, hashs: Union[str, list], delete_file: bool = True,
downloader: str = None) -> bool:

View File

@@ -68,11 +68,13 @@ class TransferChain(ChainBase):
# 如果没有下载器监控的目录则不处理
downloader_monitor = False
for dir_info in download_dirs:
if dir_info.monitor_type == "downloader":
# 只有下载器监控的本地目录才处理
if dir_info.monitor_type == "downloader" and dir_info.storage == "local":
downloader_monitor = True
break
if not downloader_monitor:
return True
logger.info("开始整理下载器中已经完成下载的文件 ...")
# 从下载器获取种子列表
torrents: Optional[List[TransferTorrent]] = self.list_torrents(status=TorrentStatus.TRANSFER)
@@ -82,8 +84,6 @@ class TransferChain(ChainBase):
logger.info(f"获取到 {len(torrents)} 个已完成的下载任务")
# 检查是否为下载器监控目录中的文件
need_handle = False
for torrent in torrents:
# 文件路径
file_path = Path(torrent.path)
@@ -91,15 +91,16 @@ class TransferChain(ChainBase):
logger.warn(f"文件不存在:{file_path}")
continue
# 检查是否为下载器监控目录中的文件
transfer_dirinfo = None
for dir_info in download_dirs:
if dir_info.monitor_type != "downloader":
continue
if not dir_info.download_path:
continue
if file_path.is_relative_to(Path(dir_info.download_path)):
need_handle = True
transfer_dirinfo = dir_info
break
if not need_handle:
if not transfer_dirinfo:
logger.info(f"文件 {file_path} 不在下载器监控目录中,不通过下载器进行整理")
# 设置下载任务状态
self.transfer_completed(hashs=torrent.hash, path=torrent.path)
@@ -137,7 +138,8 @@ class TransferChain(ChainBase):
)
# 设置下载任务状态
self.transfer_completed(hashs=torrent.hash, path=torrent.path)
self.transfer_completed(hashs=torrent.hash, path=torrent.path,
transfer_type=transfer_dirinfo.transfer_type)
# 结束
logger.info("所有下载器中下载完成的文件已整理完成")
return True

View File

@@ -264,29 +264,28 @@ class QbittorrentModule(_ModuleBase, _DownloaderBase):
return ret_torrents
def transfer_completed(self, hashs: str, path: Path = None,
downloader: str = None) -> None:
downloader: str = None, transfer_type: str = None) -> None:
"""
转移完成后的处理
:param hashs: 种子Hash
:param path: 源目录
:param downloader: 下载器
:param transfer_type: 整理方式
"""
server: Qbittorrent = self.get_server(downloader)
if not server:
return None
server.set_torrents_tag(ids=hashs, tags=['已整理'])
# FIXME 移动模式删除种子
"""
if settings.TRANSFER_TYPE in ["move"]:
# 移动模式删除种子
if transfer_type and transfer_type in ["move"]:
if self.remove_torrents(hashs):
logger.info(f"移动模式删除种子成功:{hashs} ")
# 删除残留文件
# 删除本地残留文件
if path and path.exists():
files = SystemUtils.list_files(path, settings.RMT_MEDIAEXT)
if not files:
logger.warn(f"删除残留文件夹:{path}")
shutil.rmtree(path, ignore_errors=True)
"""
def remove_torrents(self, hashs: Union[str, list], delete_file: bool = True,
downloader: str = None) -> Optional[bool]:

View File

@@ -250,13 +250,13 @@ class TransmissionModule(_ModuleBase, _DownloaderBase):
return ret_torrents
def transfer_completed(self, hashs: str, path: Path = None,
downloader: str = None) -> None:
downloader: str = None, transfer_type: str = None) -> None:
"""
转移完成后的处理
:param hashs: 种子Hash
:param path: 源目录
:param downloader: 下载器
:return: None
:param transfer_type: 整理方式
"""
# 获取下载器
server: Transmission = self.get_server(downloader)
@@ -270,18 +270,16 @@ class TransmissionModule(_ModuleBase, _DownloaderBase):
else:
tags = ['已整理']
server.set_torrent_tag(ids=hashs, tags=tags)
# FIXME 移动模式删除种子
"""
if settings.TRANSFER_TYPE in ["move"]:
# 移动模式删除种子
if transfer_type and transfer_type in ["move"]:
if self.remove_torrents(hashs):
logger.info(f"移动模式删除种子成功:{hashs} ")
# 删除残留文件
# 删除本地残留文件
if path and path.exists():
files = SystemUtils.list_files(path, settings.RMT_MEDIAEXT)
if not files:
logger.warn(f"删除残留文件夹:{path}")
shutil.rmtree(path, ignore_errors=True)
"""
def remove_torrents(self, hashs: Union[str, list], delete_file: bool = True,
downloader: str = None) -> Optional[bool]: