Skip to main content

reliable-download server

Project description

https://img.shields.io/pypi/v/rd-api.svg https://img.shields.io/pypi/l/rd-api.svg https://img.shields.io/pypi/wheel/rd-api.svg

rd-api is an HTTP file server that provides static file hosting and reliable download api for rd client.

rd-api serves files under web-root. You can use it like python3 -m http.server.

In addition, if rd command line tool is used to do the download, it will download in a reliable way by downloading in 2MiB blocks and verify checksum for each block.

Installation

To install this package:

For Debian/Ubuntu,

$ sudo apt install -y redis-server pipx   # redis is used to cache block sha1sum
$ pipx install rd-api

For RHEL,

$ sudo dnf install redis python3-pip
$ sudo systemctl start redis
$ pip install --user rd-api

To run rd-api

$ rd-api --help
$ ~/.local/bin/rd-api --help     # if ~/.local/bin/ is not in PATH

Baisc Usage

server side:

$ ls
bigfile1 bigfile2
$ rd-api --host 0.0.0.0 --port 8082

client side (requires rd client):

$ rd http://server-ip:8082/bigfile1

Documentation

Reliable download is implemented this way:

  • User uses rd client to request a resource to download.

  • rd client requests resource block metadata via the /rd/ api. Block metadata contains block count, block id, block byte offset, block content sha1sum.

  • rd-api calculates and serves block metadata to rd client incrementally. Block metadata is cached in redis after calculation.

  • rd client fetches block using HTTP/1.1 Range header and verifies sha1sum incrementally. When all blocks are downloaded and verified, combine blocks to get the final resource.

  • rd client will retry on http errors and sha1sum verification failures.

  • rd client supports continuing a partial download. You can press Ctrl-C to stop download anytime, and continue later by running the same command again.

Reliable download is written in Haskell, binary is distributed on PyPI for easy installation on linux system. Reliable download only runs in linux.

License

Reliable download is released under GPLv3+. Source code can be found at https://gitlab.emacsos.com/sylecn/reliable-download

ChangeLog

  • v1.6.0.0 2024-04-26

    • feature: auto detect file content changes for small files. auto invalidate metadata cache if file has changed.

    • feature: refine fileWorker logs

  • v1.5.0.0 2024-04-08

    • bugfix: properly handle unicode string in URL path

    • bugfix: use local time in log messages instead of UTC time

    • bugfix: fix -d –web-root option. this option was not working before.

  • v1.4.0.0 2023-10-18

    • feature: rd-api listen host defaults to ::, so it works on both ipv4 and ipv6.

  • v1.1.3.0 2022-03-14

    • bugfix: revised logging messages. rd-api supports –verbose option. debug msg is not shown by default.

    • feature: code ported to ghc 8.10.7

  • v1.1.0.0 2018-05-10

    • feature: support passing arguments using env variables, for cli arg –redis-host, the env variable will be REDIS_HOST.

    • bugfix: fix cli argument parsing for string types

  • v1.0.0.3 2018-05-09

    • update installation doc, rd-api requires redis server

  • v1.0.0.2 2018-05-09

    • init release.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

rd_api-1.6.0.0-py2.py3-none-any.whl (6.1 MB view details)

Uploaded Python 2Python 3

File details

Details for the file rd_api-1.6.0.0-py2.py3-none-any.whl.

File metadata

  • Download URL: rd_api-1.6.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 6.1 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for rd_api-1.6.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 86429396d42a63be780774f4187a66f0fee70b18341bb71429365af7b5624bfa
MD5 70c02d4aea37ded034bf2a1593b6f9b3
BLAKE2b-256 c4e7487fe27681177b09ef2dcc3599cf81078abdca5fbf76ef88a85494149ad6

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