Skip to content

Commit

Permalink
fix transfer_completed
Browse files Browse the repository at this point in the history
  • Loading branch information
jxxghp committed Sep 9, 2024
1 parent 89f2bf5 commit d0ac564
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 21 deletions.
6 changes: 4 additions & 2 deletions app/chain/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -402,14 +402,16 @@ def transfer(self, fileitem: FileItem, meta: MetaBase, mediainfo: MediaInfo,
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:
Expand Down
14 changes: 8 additions & 6 deletions app/chain/transfer.py
Original file line number Diff line number Diff line change
Expand Up @@ -68,11 +68,13 @@ def process(self) -> bool:
# 如果没有下载器监控的目录则不处理
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)
Expand All @@ -82,24 +84,23 @@ def process(self) -> bool:

logger.info(f"获取到 {len(torrents)} 个已完成的下载任务")

# 检查是否为下载器监控目录中的文件
need_handle = False
for torrent in torrents:
# 文件路径
file_path = Path(torrent.path)
if not file_path.exists():
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)
Expand Down Expand Up @@ -137,7 +138,8 @@ def process(self) -> bool:
)

# 设置下载任务状态
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
Expand Down
11 changes: 5 additions & 6 deletions app/modules/qbittorrent/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -264,29 +264,28 @@ def list_torrents(self, status: TorrentStatus = None,
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]:
Expand Down
12 changes: 5 additions & 7 deletions app/modules/transmission/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -250,13 +250,13 @@ def list_torrents(self, status: TorrentStatus = None,
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)
Expand All @@ -270,18 +270,16 @@ def transfer_completed(self, hashs: str, path: Path = None,
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]:
Expand Down

0 comments on commit d0ac564

Please sign in to comment.