Metadata-Version: 2.1
Name: bgmi
Version: 2.1.4
Summary: BGmi is a cli tool for subscribed bangumi.
Home-page: https://github.com/BGmi/BGmi
License: MIT
Keywords: bangumi,bgmi,feed
Author: RicterZ
Author-email: ricterzheng@gmail.com
Maintainer: Trim21
Maintainer-email: i@trim21.me
Requires-Python: >=3.6.1,<4.0.0
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Other Audience
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: Chinese (Traditional)
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Requires-Dist: beautifulsoup4 (==4.9.1)
Requires-Dist: icalendar (==4.0.6)
Requires-Dist: importlib-metadata (==1.7.0)
Requires-Dist: peewee (==3.13.3)
Requires-Dist: pydantic (==1.6.1)
Requires-Dist: requests (==2.24.0)
Requires-Dist: tornado (==6.0.4)
Requires-Dist: transmission-rpc (==3.2.1)
Requires-Dist: wcwidth (>=0.2.5,<0.3.0)
Project-URL: Repository, https://github.com/BGmi/BGmi
Description-Content-Type: text/x-rst

BGmi
====
BGmi is a cli tool for subscribed bangumi.

`中文说明 <./README.cn.md>`_

|pypi|
|download|
|pipeline|
|coverage|
|license|

====
TODO
====


==========
Update Log
==========
+ Remove python3.4 support as it has reached its end-of-life
+ Remove Python2 support
+ Transmission rpc authentication configuration
+ New download delegate `deluge-rpc <https://www.deluge-torrent.org/>`_
+ You can filter search results by min and max episode

=======
Feature
=======
+ Multi data sources supported: `bangumi_moe <https://bangumi.moe>`_, `mikan_project <https://mikanani.me>`_ or `dmhy <https://share.dmhy.org/>`_
+ Use aria2, transmission or deluge to download bangumi
+ Web interface to manage bangumi with HTTP API
+ Play bangumi online with danmaku
+ RSS feed for uTorrent, ICS calendar for mobile devices
+ Bangumi Script: Write your own bangumi parser!
+ Bangumi calendar / episode information
+ Keyword, subtitle group, regular expression filters for download bangumi
+ Windows, Linux and Router system supported, BGmi everywhere

.. image:: ./images/bgmi_cli.png?raw=true
    :alt: BGmi
    :align: center
.. image:: ./images/bgmi_http.png?raw=true
    :alt: BGmi HTTP Service
    :align: center
.. image:: ./images/bgmi_player.png?raw=true
    :alt: BGmi HTTP Service
    :align: center
.. image:: ./images/bgmi_admin.png?raw=true
    :alt: BGmi HTTP Service
    :align: center

============
Installation
============

Use pip:

.. code-block:: bash

    pip install bgmi

Or from source(not recommended):

.. code-block:: bash

    git clone https://github.com/BGmi/BGmi
    cd BGmi
    python -m pip install -U pip
    pip install .

Init BGmi database and install BGmi web interface:

.. code-block:: bash

    bgmi install

============
Upgrade
============
.. code-block:: bash

    pip install bgmi -U
    bgmi upgrade

Make sure to run :code:`bgmi upgrade` after you upgrade your bgmi

======
Docker
======

go to `BGmi/bgmi-docker-all-in-one <https://github.com/BGmi/bgmi-docker-all-in-one>`_

=============
Usage of bgmi
=============
Cli completion(bash and zsh. Shell was detected from your env $SHELL)

.. code-block:: bash

    eval "$(bgmi complete)"

If you want to setup a custom BGMI_PATH instead of default ``$HOME/.bgmi``:

.. code-block:: bash

    BGMI_PATH=/bgmi bgmi -h

Or add this code to your .bashrc file:

.. code-block:: bash

    alias bgmi='BGMI_PATH=/tmp bgmi'

Supported data source:

+ `bangumi_moe(default) <https://bangumi.moe>`_
+ `mikan_project <https://mikanani.me>`_
+ `dmhy <https://share.dmhy.org/>`_

Help
------

you can add ``--help`` to all ``BGmi`` sub command to show full options, some of them are not mentioned here.

Change data source:
---------------------

**All bangumi in database will be deleted when changing data source!** but scripts won't be affected

video files will still store on the disk, but won't be shown on website.

.. code-block:: bash

    bgmi source mikan_project


Show bangumi calendar:
--------------------------

.. code-block:: bash

    bgmi cal


Subscribe bangumi:
---------------------

.. code-block:: bash

    bgmi add "Re:CREATORS" "夏目友人帐 陆" "进击的巨人 season 2"
    bgmi add "樱花任务" --episode 0


Unsubscribe bangumi:
---------------------

.. code-block:: bash

    bgmi delete --name "Re:CREATORS"

Update bangumi:
-----------------

Update bangumi database which locates at ~/.bgmi/bangumi.db acquiescently:

.. code-block:: bash

    bgmi update --download
    bgmi update "从零开始的魔法书" --download 2 3
    bgmi update "时钟机关之星" --download

Filter download:
-----------------

Set up the bangumi subtitle group filter and fetch entries:

.. code-block:: bash

    bgmi list
    bgmi fetch "Re:CREATORS"
    bgmi filter "Re:CREATORS" --subtitle "DHR動研字幕組,豌豆字幕组" --include 720P --exclude BIG5
    bgmi fetch "Re:CREATORS"
    # remove subtitle, include and exclude keyword filter and add regex filter
    bgmi filter "Re:CREATORS" --subtitle "" --include "" --exclude ""
    bgmi filter "Re:CREATORS" --regex "(DHR動研字幕組|豌豆字幕组).*(720P)"
    bgmi fetch "Re:CREATORS"

Search episodes:
-----------------

.. code-block:: bash

    bgmi search '为美好的世界献上祝福！' --regex-filter '.*动漫国字幕组.*为美好的世界献上祝福！].*720P.*'
    # download
    bgmi search '为美好的世界献上祝福！' --regex-filter '.*合集.*' --download


Modify bangumi episode:

.. code-block:: bash

    bgmi list
    bgmi mark "Re:CREATORS" 1


Manage download items:

.. code-block:: bash

    bgmi download --list
    bgmi download --list --status 0
    bgmi download --mark 1 --status 2

Status code:

+ 0 - Not downloaded items
+ 1 - Downloading items
+ 2 - Downloaded items

Show BGmi configure and modify it:

.. code-block:: bash

    bgmi config
    bgmi config ARIA2_RPC_TOKEN 'token:token233'

Fields of configure file:

BGmi configure:

+ :code:`BANGUMI_MOE_URL`: url of bangumi.moe mirror
+ :code:`SAVE_PATH`: bangumi saving path
+ :code:`DOWNLOAD_DELEGATE`: the ways of downloading bangumi (aria2-rpc, transmission-rpc, xunlei)
+ :code:`MAX_PAGE`: max page for fetching bangumi information
+ :code:`TMP_PATH`: just a temporary path
+ :code:`DANMAKU_API_URL`: url of danmaku api
+ :code:`LANG`: language

Aria2-rpc configure:

+ :code:`ARIA2_RPC_URL`: aria2c daemon RPC url, not jsonrpc url.("http://localhost:6800/rpc" for localhost)
+ :code:`ARIA2_RPC_TOKEN`: aria2c daemon RPC token("token:" for no token)

Xunlei configure:

XunleiLixian is deprecated, please choose aria2-rpc or transmission-rpc.

+ :code:`XUNLEI_LX_PATH`: path of xunlei-lixian binary

Transmission-rpc configure:

+ :code:`TRANSMISSION_RPC_URL`: transmission rpc host
+ :code:`TRANSMISSION_RPC_PORT`: transmission rpc port
+ :code:`TRANSMISSION_RPC_USERNAME`: transmission rpc username (leave it default if you don't set rpc authentication)
+ :code:`TRANSMISSION_RPC_PASSWORD`: transmission rpc password (leave it default if you don't set rpc authentication)

Deluge-rpc configure:

+ :code:`DELUGE_RPC_URL`: deluge rpc url
+ :code:`DELUGE_RPC_PASSWORD`: deluge rpc password

==================
Usage of bgmi_http
==================
Download all bangumi cover:

.. code-block:: bash

    bgmi cal --download-cover

Download frontend static files(you may have done it before):

.. code-block:: bash

    bgmi install

Start BGmi HTTP Service bind on :code:`0.0.0.0:8888`:

.. code-block:: bash

    bgmi_http --port=8888 --address=0.0.0.0

Use bgmi_http on Windows
------------------------
Just start your bgmi_http and open `http://localhost:8888/ <http://localhost:8888/>`_ in your browser.

Consider most people won't use Nginx on Windows, bgmi_http use tornado.web.StaticFileHandler to serve static files(frontend, bangumi covers, bangumi files) without Nginx.

Use bgmi_http on Linux
----------------------
Generate Nginx config

.. code-block:: bash

    bgmi gen nginx.conf --server-name bgmi.whatever.com > bgmi.whatever.com

Or write your config file manually.

.. code-block:: nginx

    server {
        listen 80;
        server_name bgmi;

        root /path/to/bgmi;
        autoindex on;
        charset utf-8;

        location /bangumi {
            # ~/.bgmi/bangumi
            alias /path/to/bangumi;
        }

        location /api {
            proxy_pass http://127.0.0.1:8888;
            # Requests to api/update may take more than 60s
            proxy_connect_timeout 500s;
            proxy_read_timeout 500s;
            proxy_send_timeout 500s;
        }

        location /resource {
            proxy_pass http://127.0.0.1:8888;
        }

        location / {
            # ~/.bgmi/front_static/;
            alias /path/to/front_static/;
        }

    }

Of cause you can use `yaaw <https://github.com/binux/yaaw/>`_ to manage download items if you use aria2c to download bangumi.

.. code-block:: nginx

    ...
    location /yaaw {
        alias /path/to/yaaw;
    }

    location /jsonrpc {
        # aria2c rpc
        proxy_pass http://127.0.0.1:6800;
    }
    ...

Example file: `bgmi.conf <https://github.com/BGmi/BGmi/blob/dev/bgmi.conf>`_

macOS launchctl service controller
----------------------------------
see `issue #77 <https://github.com/BGmi/BGmi/pull/77>`_

`me.ricterz.bgmi.plist <https://github.com/BGmi/BGmi/blob/master/bgmi/others/me.ricterz.bgmi.plist>`_

===================
DPlayer and Danmaku
===================

BGmi use `DPlayer <https://github.com/DIYgod/DPlayer>`_ to play bangumi.

First, setup nginx to access bangumi files.
Second, choose one danmaku backend at `DPlayer#related-projects <https://github.com/DIYgod/DPlayer#related-projects>`_.

Use :code:`bgmi config` to setup the url of danmaku api.

.. code-block:: bash

    bgmi config DANMAKU_API_URL https://api.prprpr.me/dplayer/ # This api is provided by dplayer official

...restart your :code:`bgmi_http` and enjoy :D

==============
Bangumi Script
==============

Bangumi Script is a script which you can write the bangumi parser own.
BGmi will load the script and call the method you write before the native functionality.

Bangumi Script Runner will catch the data you returned, update the database, and download the bangumi.
You only just write the parser and return the data.

Bangumi Script is located at :code:`BGMI_PATH/script`, inherited :code:`ScriptBase` class.

examples: `script_example.py <./script_example.py>`_

``get_download_url`` returns a dict as follows.

.. code-block:: python

    {
        1: 'http://example.com/Bangumi/1/1.torrent',
        2: 'http://example.com/Bangumi/1/2.torrent',
        3: 'http://example.com/Bangumi/1/3.torrent'
    }

The keys `1`, `2`, `3` is the episode, the value is the url of bangumi, make sure your download delegate support it..

================
BGmi Data Source
================
You can easily add your own BGmi data source by extending BGmi website base class and implement all the method.

.. code-block:: python

    from typing import List, Optional

    from bgmi.website.base import BaseWebsite
    from bgmi.website.model import WebsiteBangumi, Episode


    class DataSource(BaseWebsite):
        def search_by_keyword(
            self, keyword: str, count: int
        ) -> List[Episode]:  # pragma: no cover
            """

            :param keyword: search key word
            :param count: how many page to fetch from website
            :return: list of episode search result
            """
            raise NotImplementedError

        def fetch_bangumi_calendar(self,) -> List[WebsiteBangumi]:  # pragma: no cover
            """
            return a list of all bangumi and a list of all subtitle group

            list of bangumi dict:
            update time should be one of ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Unknown']
            """
            raise NotImplementedError

        def fetch_episode_of_bangumi(
            self, bangumi_id: str, max_page: int, subtitle_list: Optional[List[str]] = None
        ) -> List[Episode]:  # pragma: no cover
            """
            get all episode by bangumi id

            :param bangumi_id: bangumi_id
            :param subtitle_list: list of subtitle group
            :type subtitle_list: list
            :param max_page: how many page you want to crawl if there is no subtitle list
            :type max_page: int
            :return: list of bangumi
            """
            raise NotImplementedError


        def fetch_single_bangumi(self, bangumi_id: str) -> WebsiteBangumi:
            """
            fetch bangumi info when updating

            :param bangumi_id: bangumi_id, or bangumi['keyword']
            :type bangumi_id: str
            :rtype: WebsiteBangumi
            """
            # return WebsiteBangumi(keyword=bangumi_id) if website don't has a page contains episodes and info

===================
Debug
===================
Set env :code:`BGMI_LOG` to :code:`debug`, :code:`info`, :code:`warning`, :code:`error` for different log level

log file will locate at :code:`{TMP_PATH}/bgmi.log`


===================
Uninstall
===================
Scheduled task will not be delete automatically, you will have to remove them manually.

``*nix``:
    remove them from your crontab

``windows``:

.. code-block:: powershell

    schtasks /Delete /TN 'bgmi updater'

=======
License
=======

`MIT License <https://github.com/BGmi/BGmi/blob/master/LICENSE>`_

.. |pypi| image:: https://img.shields.io/pypi/v/bgmi.svg
   :target: https://pypi.python.org/pypi/bgmi

.. |pipeline| image:: https://dev.azure.com/BGmi/BGmi/_apis/build/status/BGmi.BGmi?branchName=master
   :target: https://dev.azure.com/BGmi/BGmi/_apis/build/status/BGmi.BGmi?branchName=master

.. |coverage| image:: https://codecov.io/gh/BGmi/BGmi/branch/master/graph/badge.svg
   :target: https://codecov.io/gh/BGmi/BGmi

.. |license| image:: https://img.shields.io/badge/License-MIT-blue.svg
   :target: https://github.com/BGmi/BGmi/blob/master/LICENSE

.. |download| image:: https://pepy.tech/badge/bgmi/month
   :target: https://pepy.tech/project/bgmi

