Skip to main content

CLI foundation for building qBittorrent RSS rules from anime search input.

Project description

MikanCli

MikanCli is a Python command-line tool for finding bangumi/anime on Mikanani.me, choosing the correct Bangumi and subgroup RSS feed, and turning that selection into a qBittorrent RSS download rule

It supports both a guided interactive flow and a JSON preview mode for scripting or inspection. Though, only the interactive flow is pretty much finished as of now

Features

  • Search Mikan by anime title or keyword
  • Choose from matching Bangumi results and subgroup-specific RSS feeds
  • Preview recent RSS feed items before confirming a feed
  • Build qBittorrent RSS rules with include and exclude filters
  • Choose and save a default download folder
  • Configure qBittorrent WebUI access from the CLI
  • Submit RSS feeds and auto-download rules to qBittorrent, then verify that qBittorrent saved them
  • Print rule drafts as JSON without submitting anything

Requirements

  • Python 3.10 or newer.
  • pipx for installing MikanCli as a standalone CLI app
  • qBittorrent, if you want MikanCli to submit RSS feeds and rules automatically

Quick Start | Install

I recommend installing it with pipx, such so you can use it as a CLI app anytime anywhere from the terminal. You can skip the following if you already have pipx installed:

python -m pip install --user pipx           # Installing pipx for the current user on this machine
python -m pipx ensurepath                   # Update machine's PATH variable to include the folder where pipx places executable files

Refresh by reopening a new terminal after running pipx ensurepath, then run:

pipx install mikancli

How to use

Now that it is installed, run the following and follow the menu to start using it:

mikancli

Install by cloning the Repo

To install from a local clone:

git clone https://github.com/JianHua-Deng/MikanCli.git
cd MikanCli
python -m pipx install -e .

For development, an editable pip install also works:

python -m pip install -e .
python -m mikancli

Dependencies are declared in pyproject.toml and installed by pip or pipx. MikanCli does not install packages at runtime.

Guided Flow

When you run mikancli without arguments, the first menu lets you:

  • search anime
  • modify qBittorrent configuration
  • exit MikanCli

The search flow then:

  1. asks for an anime title or keyword
  2. searches Mikan for matching Bangumi entries
  3. lets you choose the correct Bangumi entry
  4. fetches subgroup RSS feeds from the selected Bangumi page
  5. lets you choose a subgroup
  6. previews recent RSS feed items
  7. asks for include and exclude filters
  8. asks where downloads should be saved
  9. builds a rule draft
  10. submits the feed and rule to qBittorrent
  11. verifies the submitted feed and rule through the qBittorrent WebUI API

Interactive prompts accept exit or quit where text input is requested, and menus include an exit option

qBittorrent Setup

Before MikanCli can submit feeds or rules, enable qBittorrent WebUI:

  1. Open qBittorrent settings
  2. Enable WebUI or remote control
  3. Confirm the WebUI address, username, and password. If the address is empty, it usually mean it is just http://localhost:[port]
  4. Run mikancli --setup-qbittorrent

Setup notes:

  • Pressing Enter for the URL uses http://localhost:8080
  • Entering localhost:8080 is normalized to http://localhost:8080
  • Username and password can be left blank if your qBittorrent WebUI allows localhost access without authentication
  • If qBittorrent rejects the connection, re-check the WebUI port and credentials in qBittorrent settings

Configuration

MikanCli stores configuration in a JSON file:

  • Windows: %APPDATA%\Roaming\MikanCli\config.json
  • macOS(Probably): ~/Library/Application Support/MikanCli/config.json
  • Linux and other POSIX systems(Probably): $XDG_CONFIG_HOME/mikancli/config.json or ~/.config/mikancli/config.json

Saved settings can include:

  • default download folder
  • qBittorrent WebUI URL
  • qBittorrent username and password
  • qBittorrent category
  • whether qBittorrent should add matched torrents paused

The qBittorrent password is stored in the config file so MikanCli can submit rules in later runs. Keep that file private on shared machines.

Project Structure

mikancli/
  cli/            CLI entrypoint, prompts, and interactive flows
  core/           dataclasses, normalization, and rule-building logic
  integrations/   Mikan and qBittorrent adapters
  config.py       user config and folder selection helpers
  display.py      text summaries and feed previews

The console command is declared in pyproject.toml:

[project.scripts]
mikancli = "mikancli.cli.entrypoint:main"

Commands Usage

usage: mikancli [-h] [--include INCLUDE] [--exclude EXCLUDE]
                [--save-path SAVE_PATH] [--json] [--setup-qbittorrent]
                [--version]
                [keyword]

Options:

  • keyword: anime title or search phrase
  • --include VALUE: require a word or phrase in accepted release titles. Repeat for multiple values
  • --exclude VALUE: reject release titles containing a word or phrase. Repeat for multiple values
  • --save-path PATH: use this base download folder for the generated qBittorrent rule
  • --json: print the rule draft as JSON. This mode does not submit to qBittorrent
  • --setup-qbittorrent: configure and verify qBittorrent WebUI settings
  • --version: print the installed CLI version.

Release

The repository includes a GitHub Actions workflow at .github/workflows/publish.yml that builds distributions, checks them with twine, and publishes to PyPI when a GitHub release is published.

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

mikancli-0.1.5.tar.gz (26.4 kB view details)

Uploaded Source

Built Distribution

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

mikancli-0.1.5-py3-none-any.whl (31.3 kB view details)

Uploaded Python 3

File details

Details for the file mikancli-0.1.5.tar.gz.

File metadata

  • Download URL: mikancli-0.1.5.tar.gz
  • Upload date:
  • Size: 26.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mikancli-0.1.5.tar.gz
Algorithm Hash digest
SHA256 9a12f45b64ce4707eed5be982b81017d7a08fc53b391c59f7e48078b68d50a07
MD5 9283e9dcdd1a4ea77d3e8cde9607b208
BLAKE2b-256 a7e1bdfc91d24e15b4990877d348f33ca63d9a09a28b04964fbc7c8d436d9781

See more details on using hashes here.

Provenance

The following attestation bundles were made for mikancli-0.1.5.tar.gz:

Publisher: publish.yml on JianHua-Deng/MikanCli

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

File details

Details for the file mikancli-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: mikancli-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 31.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for mikancli-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 d25a079699bb65770907eba8646e147c9c3e2e4a8580060d30b5884164c120dd
MD5 00dda57ec1b6abf8d5792e63b9128d6c
BLAKE2b-256 5d631702807904bb3db63f54a47b8f7aa28236ed0c7042cc31adbddc12e4f638

See more details on using hashes here.

Provenance

The following attestation bundles were made for mikancli-0.1.5-py3-none-any.whl:

Publisher: publish.yml on JianHua-Deng/MikanCli

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