changelog:
1f8023d13a399e381176c20bbb6a71763b7c352a:
type: documentation
examples:
- command: imdl
text: "The binary is called `imdl`:"
code: "imdl --help"
- command: imdl torrent
text: "BitTorrent metainfo related functionality is under the `torrent` subcommand:"
code: "imdl torrent --help"
- command: imdl torrent create
text: "Intermodal can be used to create `.torrent` files:"
code: "imdl torrent create --input foo"
- command: imdl torrent show
text: "Print information about existing `.torrent` files:"
code: "imdl torrent show --input foo.torrent"
- command: imdl torrent verify
text: "Verify downloaded torrents:"
code: "imdl torrent verify --input foo.torrent --content foo"
- command: imdl torrent link
text: "Generate magnet links from `.torrent` files:"
code: "imdl torrent link --input foo.torrent"
- command: imdl torrent piece-length
text: "Show infromation about the piece length picker:"
code: "imdl torrent piece-length"
- command: imdl completions
text: "Print completion scripts for the `imdl` binary:"
code: "imdl completions --shell zsh"
- command: imdl torrent stats
unstable: true
text: "Print information about a collection of torrents:"
code: "imdl --unstable torrent stats --input dir"
packages:
- operating-system: '[Various](https://forge.rust-lang.org/release/platform-support.html)'
package-manager: '[Cargo](https://www.rust-lang.org)'
package: '[imdl](https://crates.io/crates/imdl)'
command: '`cargo install imdl`'
- operating-system: '[Arch Linux](https://www.archlinux.org)'
package-manager: '[Yay](https://github.com/Jguer/yay)'
package: '[intermodal-bin](https://aur.archlinux.org/packages/intermodal-bin)AUR'
command: '`yay -S intermodal-bin`'
- operating-system: '[Arch Linux](https://www.archlinux.org)'
package-manager: '[Yay](https://github.com/Jguer/yay)'
package: '[intermodal](https://aur.archlinux.org/packages/intermodal)AUR'
command: '`yay -S intermodal`'
- operating-system: '[Arch Linux](https://www.archlinux.org)'
package-manager: 'Manual Installation'
package: '[intermodal](https://aur.archlinux.org/packages/intermodal)AUR'
command: '[wiki](https://wiki.archlinux.org/index.php/Arch_User_Repository#Installing_packages)'
references:
- title: BitTorrent
entries:
- url: https://github.com/bittorrent/bittorrent.org
description: >-
GitHub repository hosting protocol development discussion and contents of
bittorrent.org.
- url: https://www.bittorrent.org
description: >-
Official web site site hosting BEPs and other information about the
protocol.
- url: https://wiki.theory.org/index.php/Main_Page
description: >-
Wiki with lots of information about all aspects of the BitTorrent
protocol and implementations.
- url: https://archive.org/details/2014_torrent_archive_organized)
description: >-
Massive 158 GiB archive containing 5.5 million torrents, assembled in
2014.
- url: https://github.com/internetarchive/dweb-transport
description: >-
Github repository hosting The Internet Archive's distributed web and
BitTorrent-related software.
- url: https://libtorrent.org/udp_tracker_protocol.html
description: UDP tracker protocol description.
- title: Metadata
entries:
- title: Media RSS Specification
url: http://www.rssboard.org/media-rss
description: >-
_Media RSS is a new RSS module that supplements the
capabilities of RSS 2.0. RSS enclosures are already being used to
syndicate audio files and images. Media RSS extends enclosures to handle
other media types, such as short films or TV, as well as provide
additional metadata with the media. Media RSS enables content publishers
and bloggers to syndicate multimedia content such as TV and video clips,
movies, images and audio._
- title: Cryptography
entries:
- url: https://ssbc.github.io/scuttlebutt-protocol-guide/
description: Secure Scuttlebutt Protocol guide
- url: https://github.com/lightningnetwork/lightning-rfc/blob/master/08-transport.md
description: 'Lightning Network Encrypted and Authenticated Transport'
- url: http://noiseprotocol.org/noise.html
description: 'Noise Protocol'
- url: https://github.com/handshake-org/hsd/blob/master/lib/net/brontide.js
description: 'Handshake P2P Encryption Protocol'
- url: https://github.com/j01tz/grin-rfcs/blob/slate-serialization/text/0000-slate-serialization.md
description: 'Grin Slate Serialization'
faq:
- title: Can intermodal be used to preview torrents with `fzf`?
anchor: fzf-preview
text: |-
Yes! [@mustaqimM](https://github.com/mustaqimM) came up with the following:
fzf --preview='imdl --color always --terminal torrent show --input {}
_Note the use of `--color always` and `--terminal` to force colored, human readable output._
This can be used to, for example, preview the torrents in a directory:
find . -name '*.torrent' | fzf --preview='imdl -c always -t torrent show -i {}'
- title: Can intermodal be used to create a torrent from a Git repo?
anchor: git-repo
text: |-
Yes! The `--ignore` flag, contributed by [@Celeo](https://github.com/Celeo), can be used
to make `imdl torrent create` respect `.gitignore` files:
imdl torrent create --ignore --include-hidden --include-junk --glob '!.git/*' --input .
In addition to `--ignore`, `--include-hidden`, `--include-junk`, and `--glob '!.git/*'`
are used to include files, like `.gitignore`, that are present in the repo but would
otherwise be skipped, and to skip the contents of the `.git` directory.
Equivalently, with short flags:
imdl torrent create --ignore -hjg '!.git/*' -i .