Skip to main content

a comic strip downloader and archiver

Project description

Dosage

CI Maintainability codecov GitHub last commit License pre-commit

Dosage is designed to keep a local copy of specific webcomics and other picture-based content such as Picture of the Day sites. With the dosage commandline script you can get the latest strip of a webcomic, or catch-up to the last strip downloaded, or download a strip for a particular date/index (if the webcomic's site layout allows this).

Multiple webcomics can be downloaded in parallel, making the update of comic strips faster.

Dosage is licensed under the MIT license

Notice

This software is in no way intended to publically "broadcast" comic strips, it is purely for personal use. Please be aware that by making downloaded strips publically available (without the explicit permission of the author) you may be infringing upon various copyrights.

In any case, you should support the authors of the comics you are downloading, either by buying some of their products or even donating them some money since they provide the comics you like and read.

Additionally, Dosage respects (part of) the robots.txt exclusion protocol. This makes it easy for publishers to disallow Dosage access to their site. On the other hand, Dosage is no classic "crawler" oder "bot", so global rules in robots.txt are ignored.

If you are a publisher of comics and don't want Dosage to access your files, either open an issue and request removal (this is the preferred solution, since it documents your wishes to us) or add the following entry to your robots.txt file:

User-agent: Dosage
Disallow: *

Usage

List available comics (ca. 3000 at the moment):

$ dosage --list

Get the latest comic of for example CalvinAndHobbes and save it in the "Comics" directory:

$ dosage CalvinAndHobbes

If you already have downloaded several comics and want to get the latest strip of all of them:

$ dosage @

To help others find good comics, you can vote for your favourite ones:

$ dosage --vote @

For advanced options and features execute dosage --help.

Adult content

Some comics contain adult content and require age confirmation. These comics can only be downloaded by using the --adult option, which confirms that you are old enough to view them.

Installation

Dependencies

Since dosage is written in Python, a Python installation is required: Dosage needs at least Python 3.8. Dosage requires some Python modules from PyPI, so installation with pip is recommended.

Optional dependencies

Some features require optional dependencies, which can be installed by specifying them while installing Dosage:

  • bash - Installs shell completion support using the argcomplete package. You still need to register support in your shell using eval "$(register-python-argcomplete dosage)" or using argcomplete's global completion mode. argcomplete officially only supports bash & zsh, but has limited support for other shells.
  • compression - Enables Brotli & zstandard compression - These modern HTTP compression methods can reduce transferred file size and improve performance.
  • dev - Dependencies only required for running Dosage's test suite.

Using the Windows binary

Windows users can download a complete binary (including Python) from the release page.

Install with pipx

The simplest way to install and upgrade dosage is with pipx. To install the newest stable version with all optional features use:

pipx install dosage[bash,compression]

To install the newest development version, use:

pipx install "dosage[bash,compression] @ git+https://github.com/webcomics/dosage.git"

To upgrade such installations, just run:

pipx upgrade dosage

Installation for development

If you want to run dosage directly from the source code, you should install it in "editable" mode, preferable in a virtual environment:

pip install -e .[bash,compression,dev]

After that, dosage should be available as a normal command.

Code Style

This project currently has a pretty "loose" code style. Please use pre-commit to keep the code style consistent. You can ignore flake8 warnings in code you didn't touch (Set SKIP=flake8 before commiting if pre-commit doesn't let you).

Reporting Bugs

You can report bugs, patches or requests at the GitHub issue tracker - Dosage currently supports a large number of comics and that number grows on a regular basis. If you feel that there are comics that Dosage does not currently support, but should support, please feel free to request them.

Extending Dosage

In order to add a new webcomic, a new module class has to be created in one of the *.py files in one the dosagelib/plugins subdirectory. Look at the documentation for adding modules and at existing module classes for examples.

Test suite status

Dosage has unit tests to ensure code quality. GitHub Actions are used for continuous build and test integration. See the badges at the top of this page for the current status.

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

dosage-3.2.tar.gz (443.8 kB view details)

Uploaded Source

Built Distribution

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

dosage-3.2-py3-none-any.whl (192.9 kB view details)

Uploaded Python 3

File details

Details for the file dosage-3.2.tar.gz.

File metadata

  • Download URL: dosage-3.2.tar.gz
  • Upload date:
  • Size: 443.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dosage-3.2.tar.gz
Algorithm Hash digest
SHA256 3078a4a2a6ec4365a40e2f92fb57e11ee272fdcc331eee8f572fc97c02cd2542
MD5 1259a4bf7d41cb0cae62045d6216a0c0
BLAKE2b-256 918f9c2fcb729b91156ac60cc7e078980c6a278787a5627a46b4ccc40ca826a6

See more details on using hashes here.

Provenance

The following attestation bundles were made for dosage-3.2.tar.gz:

Publisher: publish.yaml on webcomics/dosage

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dosage-3.2-py3-none-any.whl.

File metadata

  • Download URL: dosage-3.2-py3-none-any.whl
  • Upload date:
  • Size: 192.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dosage-3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4030c8253d0aa8f4fb7eacf2eb73b5010093cfc4dbea22493526f2695575c659
MD5 2619fcc130e02ce3d7a27eb0ea116d78
BLAKE2b-256 f654a52658813f32e1c379d8ae64f3d5260f52bd048c7af03398858baac42d36

See more details on using hashes here.

Provenance

The following attestation bundles were made for dosage-3.2-py3-none-any.whl:

Publisher: publish.yaml on webcomics/dosage

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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