fix save path, fix prio, update deprecated calls
This commit is contained in:
parent
8ee5cee8c3
commit
6efd4dd19a
2 changed files with 21 additions and 12 deletions
|
@ -36,10 +36,14 @@ class TorrentHandle:
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def largest_file(self) -> Optional[str]:
|
def largest_file(self) -> Optional[str]:
|
||||||
if not self.torrent_file:
|
if self.torrent_file is None:
|
||||||
return None
|
return None
|
||||||
index = self.largest_file_index
|
index = self.largest_file_index
|
||||||
return os.path.join(self._base_path, self.torrent_file.at(index).path)
|
return os.path.join(self._base_path, self.torrent_file.file_path(index))
|
||||||
|
|
||||||
|
@property
|
||||||
|
def save_path(self) -> Optional[str]:
|
||||||
|
return self._base_path
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def largest_file_index(self):
|
def largest_file_index(self):
|
||||||
|
@ -66,15 +70,18 @@ class TorrentHandle:
|
||||||
if not self.metadata_completed.is_set():
|
if not self.metadata_completed.is_set():
|
||||||
self.metadata_completed.set()
|
self.metadata_completed.set()
|
||||||
log.info("Metadata completed for btih:%s - %s", status.info_hash, self.name)
|
log.info("Metadata completed for btih:%s - %s", status.info_hash, self.name)
|
||||||
self.torrent_file = self._handle.get_torrent_info().files()
|
self.torrent_file = self._handle.torrent_file().files()
|
||||||
self._base_path = status.save_path
|
self._base_path = status.save_path
|
||||||
first_piece = self.torrent_file.at(self.largest_file_index).offset
|
first_piece = self.torrent_file.piece_index_at_file(self.largest_file_index)
|
||||||
if not self.started.is_set():
|
if not self.started.is_set():
|
||||||
if self._handle.have_piece(first_piece):
|
if self._handle.have_piece(first_piece):
|
||||||
self.started.set()
|
self.started.set()
|
||||||
else:
|
else:
|
||||||
# prioritize it
|
# prioritize it
|
||||||
self._handle.set_piece_deadline(first_piece, 100)
|
self._handle.set_piece_deadline(first_piece, 100)
|
||||||
|
prios = self._handle.piece_priorities()
|
||||||
|
prios[first_piece] = 7
|
||||||
|
self._handle.prioritize_pieces(prios)
|
||||||
if not status.is_seeding:
|
if not status.is_seeding:
|
||||||
log.debug('%.2f%% complete (down: %.1f kB/s up: %.1f kB/s peers: %d seeds: %d) %s - %s',
|
log.debug('%.2f%% complete (down: %.1f kB/s up: %.1f kB/s peers: %d seeds: %d) %s - %s',
|
||||||
status.progress * 100, status.download_rate / 1000, status.upload_rate / 1000,
|
status.progress * 100, status.download_rate / 1000, status.upload_rate / 1000,
|
||||||
|
@ -177,6 +184,9 @@ class TorrentSession:
|
||||||
def full_path(self, btih):
|
def full_path(self, btih):
|
||||||
return self._handles[btih].largest_file
|
return self._handles[btih].largest_file
|
||||||
|
|
||||||
|
def save_path(self, btih):
|
||||||
|
return self._handles[btih].save_path
|
||||||
|
|
||||||
async def add_torrent(self, btih, download_path):
|
async def add_torrent(self, btih, download_path):
|
||||||
await self._loop.run_in_executor(
|
await self._loop.run_in_executor(
|
||||||
self._executor, self._add_torrent, btih, download_path
|
self._executor, self._add_torrent, btih, download_path
|
||||||
|
@ -239,17 +249,16 @@ async def main():
|
||||||
|
|
||||||
executor = None
|
executor = None
|
||||||
session = TorrentSession(asyncio.get_event_loop(), executor)
|
session = TorrentSession(asyncio.get_event_loop(), executor)
|
||||||
session2 = TorrentSession(asyncio.get_event_loop(), executor)
|
await session.bind()
|
||||||
await session.bind('localhost', port=4040)
|
await session.add_torrent(btih, os.path.expanduser("~/Downloads"))
|
||||||
await session2.bind('localhost', port=4041)
|
|
||||||
btih = await session.add_fake_torrent()
|
|
||||||
session2._session.add_dht_node(('localhost', 4040))
|
|
||||||
await session2.add_torrent(btih, "/tmp/down")
|
|
||||||
while True:
|
while True:
|
||||||
await asyncio.sleep(100)
|
session.full_path(btih)
|
||||||
|
await asyncio.sleep(1)
|
||||||
await session.pause()
|
await session.pause()
|
||||||
executor.shutdown()
|
executor.shutdown()
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
logging.basicConfig(level=logging.DEBUG, format="%(asctime)s %(levelname)-4s %(name)s:%(lineno)d: %(message)s")
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
asyncio.run(main())
|
asyncio.run(main())
|
||||||
|
|
|
@ -48,7 +48,7 @@ class TorrentSource(ManagedDownloadSource):
|
||||||
@property
|
@property
|
||||||
def full_path(self) -> Optional[str]:
|
def full_path(self) -> Optional[str]:
|
||||||
full_path = self.torrent_session.full_path(self.identifier)
|
full_path = self.torrent_session.full_path(self.identifier)
|
||||||
self.download_directory = os.path.dirname(full_path)
|
self.download_directory = self.torrent_session.save_path(self.identifier)
|
||||||
return full_path
|
return full_path
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|
Loading…
Add table
Reference in a new issue