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.4.tar.gz (26.3 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.4-py3-none-any.whl (31.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mikancli-0.1.4.tar.gz
  • Upload date:
  • Size: 26.3 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.4.tar.gz
Algorithm Hash digest
SHA256 57d392ef2821c7180b67117e52f0bb79f1ffc70a591cfec86acb568e859e70be
MD5 db48b93b5b2b583e54a69edbc9176655
BLAKE2b-256 82ec706559f3673bf444375f5fb2007246152feba91adf57c3a84f065a82d7a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for mikancli-0.1.4.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.4-py3-none-any.whl.

File metadata

  • Download URL: mikancli-0.1.4-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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 dbe887e5f2fca5d82c4b97b3085544b6fc569a182e297e22b8a557d756de3fb3
MD5 63e44d1343f709faf6d015b30b2c5161
BLAKE2b-256 8c13e549b18ac1a6a5048c026281d0db0de2db802dcf3482dccd594dea536aa8

See more details on using hashes here.

Provenance

The following attestation bundles were made for mikancli-0.1.4-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