Skip to main content

Minerva DPN Worker, for more information see https://minerva-archive.org

Project description

Minerva Worker
Preserving Myrient's legacy, one file at a time.

License Python version Manager: uv Linter: Ruff Build status


Myrient is shutting down. Minerva is a volunteer-driven effort to archive its entire collection before it goes offline. Run a script, share your bandwidth, help preserve the archive.

Installation

Download and install the Python script from PIP/PyPI:

$ pip install minerva-worker

[!NOTE] If pip gives you a warning about a path not being in your PATH environment variable then promptly add that path then close all open command prompt Windows, or running minerva won't work as it will not be recognized as a program.

You now have the minerva package installed - Voilà 🎉!
Get started by running minerva in your Terminal or Windows Run.
For configuration options, see help and options by running minerva --help.

Alternatively, a Windows EXE is available on the Releases page, simply run it to begin!

Usage

It's very easy to use. Simply run the minerva.exe file, or run minerva in your Terminal/Command Prompt.

You can configure the worker settings by running minerva run --help to see what configuration options you can change. If you have a great computer and network, it's recommended to bump up the -c and -b options.

How it works

The worker script asks the minerva server for jobs to download. The server gives active workers random missing needed file URLs to download. When the worker is given a job, it temporarily downloads the file and uploads it to the minerva file servers. Once the file is downloaded, it is deleted from your machine.

Jobs are given exclusively to each worker, no two workers download the same file at the same time. However, to verify that uploads aren't corrupted, each job gets given (eventually) to a second worker. Both uploads are then confirmed and if both workers give back the same file to the minerva file server, then the job is marked as complete and verified.

Discord Authentication

When using the minerva worker, you are prompted upon startup to login and authorize with Discord. This is to authenticate unique users on the minerva server, to know who jobs are given to, and to use your username and avatar in the worker dashboard leaderboards.

This does not give Minerva, this script, or anyone else access to your account, or any permissions.

Docker

You can run the Minerva Worker inside a headless Docker container. The following steps assume some knowledge on git/docker.

To change the settings of the worker, you can set the following environment variables:

  • --server: MINERVA_SERVER
  • -c/--concurrency: MINERVA_CONCURRENCY
  • -r/--retries: MINERVA_RETRIES
  • --min-job-size: MINERVA_MIN_JOB_SIZE
  • --max-job-size: MINERVA_MAX_JOB_SIZE

There are more advanced environment variables available, you can find them listed in constants.py.

1. Download a copy of the repository

  • Clone the Git Repository: git clone https://github.com/minerva-archive/worker
  • Enter it: cd minerva

2. Get an Authorization Token

There's two ways to go about this,

  • enable tty/interactivity and run minerva normally, see Terminal Interactity,
  • or, get and save the token to a specific location manually.

To get the token manually, go to the following link to authorize with discord and the API:
https://discord.com/oauth2/authorize?client_id=1478862142793977998&response_type=code&redirect_uri=https%3A%2F%2Ffirehose.minerva-archive.org%2Fcode&scope=identify

Copy the token value the page gives you and save it to ~/.minerva-dpn/token on Linux/macOS, or save it to %USERPROFILE%/.minerva-dpn/token on Windows. Make sure the file is saved as UTF-8 encoding, without BOM.

The token file must stay there at all times for the Docker container to have it. The location where the token needs to be can be changed, just make sure you change the volume location and environment variable in the docker-compose config.

3. Start the container

Build the Docker image and start the container with docker compose up -d to run it in the background. You can later stop the container with docker compose down.

[!TIP] If you prefer to run it in the foreground (attached to your terminal), simply use docker compose up.

Terminal Interactivity

These options allow you to interact with the container directly through the terminal.

The configuration is controlled via the stdin_open and tty options in the docker-compose.yml

stdin_open: true  # Keeps STDIN open even if not attached
tty: true         # Allocates a pseudo-TTY for the container

If you do not need terminal interactivity, you can comment out or remove these lines. This is useful for running the container in the background without manual input.

When these are enabled, you may prefer to use docker attach <container_name> instead of docker logs <container_name> to see real-time output without duplicated lines, and to provide input.

[!TIP] To safely detach from an attached container without stopping it, use the key sequence CTRL + P then CTRL + Q.

Troubleshooting

Before continuing, make sure you are using the worker installed using the instructions above. Delete any minerva.py file you may have as your terminal might run that when calling minerva instead of the pip package installed as instructed above. Also double check that your Python version is 3.10.0 or newer with python --version. If you use python3, try python and see if one or the other is newer.

  1. This environment is externally managed

You use a Linux system that prevents pip from modifying the Python environment to avoid breaking packages used by the OS. Instead, install pipx, for example with sudo apt install pipx, then run pipx ensurepath. Now install the worker by calling pipx install minerva-worker.

  1. Other pip-related installation issues

Commands like pip install minerva-worker must be run in a Terminal/Command Prompt, not typed into a Python script, Python shell, Notepad, Windows Run, or any other program. We highly recommend using Microsoft Terminal on both Windows or Linux as it plays really well with the UI.

  1. minerva was not found

This happens because Python installs command scripts into a Scripts directory that may not be in your System PATH Environment Variable.

It's typical location on Windows would be in: C:\Users\<username>\AppData\Local\Programs\Python\PythonXXX\Scripts where <username> is your Windows Username and PythonXXX is your Python version, e.g. "Python314".

Add this location to the PATH environment variable listed under User variables in the "Environment Variables" settings window. In your start menu search "Environment variables", open it, and click "Edit environment variables". If you need assistance I recommend searching for a guide online.

  1. The interface is laggy, buggy, or similar.

On Windows, I highly recommend using Windows Terminal with the latest version of PowerShell. If you're running the worker in a shell or command prompt that has a bright blue background, your using an old version of PowerShell and are going to have a bad time.

On Linux or macOS, I have no preferences or recommendation to share, but I recommend looking around. If you are running the worker in a less typical environment or device, like Docker or cloud-based terminals, you may unfortunately be stuck with having a slow or glitchy UI.

Development

  1. Install uv
  2. uv sync --all-extras --all-groups
  3. .venv\Scripts\activate (or source .venv/bin/activate on macOS and Linux)
  4. uv tool install pre-commit --with pre-commit-uv --force-reinstall
  5. pre-commit install

Now feel free to work on the project however you like, all code will be checked before committing.

Licensing

This software is licensed under the terms of CC0 1.0 Universal. You can find a copy of the license in the LICENSE file in the root folder


© minerva-archive 2026

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

minerva_worker-2.0.0.tar.gz (30.1 MB view details)

Uploaded Source

Built Distribution

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

minerva_worker-2.0.0-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file minerva_worker-2.0.0.tar.gz.

File metadata

  • Download URL: minerva_worker-2.0.0.tar.gz
  • Upload date:
  • Size: 30.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for minerva_worker-2.0.0.tar.gz
Algorithm Hash digest
SHA256 dca621b74246fa36b56f30062f022766c1fd720aff77d5fee32cc538cef88881
MD5 5fc597ba6b92ae2540dc31266c5cd2ac
BLAKE2b-256 b122abfba9b6096c6c6f4468bfe3569d4ed1fc27b2f0303de27f24e7b01359b3

See more details on using hashes here.

File details

Details for the file minerva_worker-2.0.0-py3-none-any.whl.

File metadata

  • Download URL: minerva_worker-2.0.0-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for minerva_worker-2.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9c1d998c2a323198074da044bfcc5675d39c8d57f7919a509aab03b46f6d2941
MD5 6806408c946b09cdcb518856520fbf20
BLAKE2b-256 a61fc820baee2cea046dc7eca1bc5ce9dc5b4da95f48721bd84a9818dcea414e

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