Skip to main content

Python 3 module for creating and parsing torrent files and magnet URIs

Project description

torf provides a Torrent and a Magnet class.

torf-cli is a command line tool that makes use of torf.

This project started as a fork of dottorrent but turned into a rewrite.

Features

  • Create a Torrent instance from a path to the torrent’s content or by reading an existing .torrent file

  • High-level access to standard metainfo fields via properties

  • Low-level access to arbitrary metainfo fields via metainfo property

  • Optional metainfo validation with helpful error messages

  • Generate a BTIH magnet URI from a .torrent file (the reverse is also possible but the resulting torrent is incomplete due to the lack of information in magnet URIs)

  • Use multiple CPU cores to compute piece hashes

  • Randomize the info hash to help with cross-seeding

  • Conveniently re-use piece hashes from an existing torrent file

Example

from torf import Torrent
t = Torrent(path='path/to/content',
            trackers=['https://tracker1.example.org:1234/announce',
                      'https://tracker2.example.org:5678/announce'],
            comment='This is a comment')
t.private = True
t.generate()
t.write('my.torrent')

Documentation

Everything should be explained in the docstrings. Read it with pydoc3 torf.Torrent or pydoc3 torf.Magnet.

Documentation is also available at torf.readthedocs.io or torf.readthedocs.io/en/latest for the development version.

Installation

torf is available on PyPI.

The latest development version is in the master branch on GitHub.

Contributing

I consider this project feature complete, but feel free to request new features or improvements. Bug reports are always welcome, of course.

License

GPLv3+

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

torf-4.2.2.tar.gz (114.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

torf-4.2.2-py3-none-any.whl (122.8 kB view details)

Uploaded Python 3

File details

Details for the file torf-4.2.2.tar.gz.

File metadata

  • Download URL: torf-4.2.2.tar.gz
  • Upload date:
  • Size: 114.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for torf-4.2.2.tar.gz
Algorithm Hash digest
SHA256 13a8ef7fd72ce50e9a3220910660d2af9351bac1112227810a289f076c32ea7f
MD5 8e997dbcdad417176ec36a834fab51ae
BLAKE2b-256 a0b62aeaf1a9917a42824e28679e78c06b5a1d02f339ece8b5a14984ab3a88db

See more details on using hashes here.

File details

Details for the file torf-4.2.2-py3-none-any.whl.

File metadata

  • Download URL: torf-4.2.2-py3-none-any.whl
  • Upload date:
  • Size: 122.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for torf-4.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e7964377f6bc3d5c939b835a42bdf098c6170c70bd79e51bdfc3f9f695d7b78d
MD5 6c88b46196b6afe20ad1f329c2cca003
BLAKE2b-256 392f45358017ae5d36fcf6ddc69771940bd49117af795116ff87c79f1106e7ea

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page