2023-07-19 11:35:18 +08:00
2023-07-11 11:36:24 +08:00
2023-07-19 11:35:18 +08:00
2023-07-16 09:41:14 +08:00
2023-07-19 11:35:18 +08:00
2023-07-08 23:10:13 +08:00
2023-07-19 11:35:18 +08:00
2023-07-15 12:40:36 +08:00
2023-07-19 11:35:18 +08:00
2023-07-10 16:42:20 +08:00
2023-06-06 07:15:17 +08:00
2023-06-11 11:47:03 +08:00
2023-06-07 13:04:36 +08:00

MoviePilot

基于 NAStool 部分代码重新设计,聚焦自动化核心需求,减少问题同时更易于扩展和维护。

Dockerhttps://hub.docker.com/r/jxxghp/moviepilot

主要特性

  • 前后端分离基于FastApi + Vue3前端项目地址MoviePilot-Frontend
  • 聚焦核心需求,简化功能和设置,部分设置项可直接使用默认值。
  • 重新设计了用户界面,更加美观易用。

安装

  1. 安装CookieCloud插件

站点信息需要通过CookieCloud同步获取因此需要安装CookieCloud插件将浏览器中的站点Cookie数据同步到云端后再同步到MoviePilot使用。 插件下载地址请点击 这里

  1. 安装CookieCloud服务端可选

MoviePilot内置了公共的CookieCloud服务器如果需要自建服务可参考 CookieCloud 项目进行安装。

docker pull easychen/cookiecloud:latest
  1. 安装配套管理软件

MoviePilot跟NAStool一样需要配套下载器和媒体服务器使用。

  • 下载器支持qBittorrent、TransmissionQB版本号要求>= 4.3.9TR版本号要求>= 3.0推荐使用QB。
  • 媒体服务器支持Jellyfin、Emby、Plex推荐使用Emby。
  1. 安装MoviePilot

目前仅提供docker镜像后续可能会提供更多安装方式。

docker pull jxxghp/moviepilot:latest

配置

项目的所有配置均通过环境变量进行设置,部分环境建立容器后会自动显示待配置项,如未自动显示配置项则需要手动增加对应环境变量。

1. 基础设置

  • HOST 监听地址,默认0.0.0.0如需支持ipv6则需改为::

  • SUPERUSER 超级管理员用户名,默认admin,安装后使用该用户登录后台管理界面

  • SUPERUSER_PASSWORD 超级管理员初始密码,默认password,建议修改为复杂密码

  • API_TOKEN API密钥默认moviepilot在媒体服务器Webhook、微信回调等地址配置中需要加上?token=该值,建议修改为复杂字符串

  • PROXY_HOST 网络代理可选访问themoviedb需要使用代理访问格式为http(s)://ip:port

  • TMDB_API_DOMAIN TMDB API地址默认api.themoviedb.org,也可配置为api.tmdb.org或其它中转代理服务地址,能连通即可

  • DOWNLOAD_PATH 下载保存目录,注意:需要将moviepilot下载器的映射路径与宿主机真实路径保持一致,例如群晖中下载路程径为/volume1/downloads,则需要将moviepilot下载器的映射路径均设置为/volume1/downloads,否则会导致下载文件无法转移

  • LIBRARY_PATH 媒体库目录,注意:需要将moviepilot的映射路径与宿主机真实路径保持一致,多个目录使用,分隔

  • LIBRARY_CATEGORY 二级分类开关,true/false,开启后会根据配置自动在媒体库目录下建立二级目录分类

  • DOUBAN_USER_IDS 豆瓣用户ID用于同步豆瓣标记的想看数据,自动添加订阅,多个用户使用,分隔

  • TRANSFER_TYPE 转移方式,支持link/copy/move/softlink

  • COOKIECLOUD_HOST CookieCloud服务器地址格式http://ip:port,必须配置,否则无法添加站点

  • COOKIECLOUD_KEY CookieCloud用户KEY

  • COOKIECLOUD_PASSWORD CookieCloud端对端加密密码

  • COOKIECLOUD_INTERVAL CookieCloud同步间隔分钟

  • USER_AGENT CookieCloud对应的浏览器UA可选同步站点后可以在管理界面中修改

  • MESSAGER 消息通知渠道,支持 telegram/wechat/slack,开启多个渠道时使用,分隔。同时还需要配置对应渠道的环境变量,非对应渠道的变量可删除,推荐使用telegram

wechat设置项:

  • WECHAT_CORPID WeChat企业ID
  • WECHAT_APP_SECRET WeChat应用Secret
  • WECHAT_APP_ID WeChat应用ID
  • WECHAT_TOKEN WeChat消息回调的Token
  • WECHAT_ENCODING_AESKEY WeChat消息回调的EncodingAESKey
  • WECHAT_ADMINS WeChat管理员列表多个管理员用英文逗号分隔可选

telegram设置项:

  • TELEGRAM_TOKEN Telegram Bot Token
  • TELEGRAM_CHAT_ID Telegram Chat ID
  • TELEGRAM_USERS Telegram 用户ID多个使用,分隔只有用户ID在列表中才可以使用Bot如未设置则均可以使用Bot
  • TELEGRAM_ADMINS Telegram 管理员ID多个使用,分隔只有管理员才可以操作Bot菜单如未设置则均可以操作菜单

slack设置项:

  • SLACK_OAUTH_TOKEN Slack Bot User OAuth Token

  • SLACK_APP_TOKEN Slack App-Level Token

  • SLACK_CHANNEL Slack 频道名称,默认全体

  • DOWNLOADER 下载器,支持qbittorrent/transmissionQB版本号要求>= 4.3.9TR版本号要求>= 3.0,同时还需要配置对应渠道的环境变量,非对应渠道的变量可删除,推荐使用qbittorrent

qbittorrent设置项:

  • QB_HOST qbittorrent地址格式ip:porthttps需要添加https://前缀
  • QB_USER qbittorrent用户名
  • QB_PASSWORD qbittorrent密码

transmission设置项:

  • TR_HOST transmission地址格式ip:porthttps需要添加https://前缀

  • TR_USER transmission用户名

  • TR_PASSWORD transmission密码

  • MEDIASERVER 媒体服务器,支持emby/jellyfin/plex,同时还需要配置对应媒体服务器的环境变量,非对应媒体服务器的变量可删除,推荐使用emby

emby设置项:

  • EMBY_HOST Emby服务器地址格式ip:porthttps需要添加https://前缀
  • EMBY_API_KEY Emby Api Key设置->高级->API密钥处生成

jellyfin设置项:

  • JELLYFIN_HOST Jellyfin服务器地址格式ip:porthttps需要添加https://前缀
  • JELLYFIN_API_KEY Jellyfin Api Key设置->高级->API密钥处生成

plex设置项:

  • PLEX_HOST Plex服务器地址格式ip:porthttps需要添加https://前缀
  • PLEX_TOKEN Plex网页Url中的X-Plex-Token通过浏览器F12->网络从请求URL中获取

2. 用户认证

  • AUTH_SITE 认证站点,支持hhclub/audiences/hddolby/zmpt/freefarm/hdfans/wintersakura/leaves/1ptba/icc2022/iyuu

MoviePilot为了控制用户数量同样需要认证PT用户后才能使用配置AUTH_SITE后,需要根据下表配置对应站点的认证参数。

站点 参数
iyuu IYUU_SIGNIYUU登录令牌
hhclub HHCLUB_USERNAME:用户名
HHCLUB_PASSKEY:密钥
audiences AUDIENCES_UID用户ID
AUDIENCES_PASSKEY:密钥
hddolby HDDOLBY_ID用户ID
HDDOLBY_PASSKEY:密钥
zmpt ZMPT_UID用户ID
ZMPT_PASSKEY:密钥
freefarm FREEFARM_UID用户ID
FREEFARM_PASSKEY:密钥
hdfans HDFANS_UID用户ID
HDFANS_PASSKEY:密钥
wintersakura WINTERSAKURA_UID用户ID
WINTERSAKURA_PASSKEY:密钥
leaves LEAVES_UID用户ID
LEAVES_UID:密钥
1ptba 1PTBA_UID用户ID
1PTBA_PASSKEY:密钥
icc2022 ICC2022_UID用户ID
ICC2022_PASSKEY:密钥

2. 进阶配置

  • MOVIE_RENAME_FORMAT 电影重命名格式

MOVIE_RENAME_FORMAT支持的配置项:

title 标题
original_name 原文件名
original_title 原语种标题
name 识别名称
year 年份
edition 版本
videoFormat 分辨率
releaseGroup 制作组/字幕组
effect 特效
videoCodec 视频编码
audioCodec 音频编码
tmdbid TMDBID
imdbid IMDBID
part:段/节
fileExt:文件扩展名

MOVIE_RENAME_FORMAT默认配置格式:

{{title}}{% if year %} ({{year}}){% endif %}/{{title}}{% if year %} ({{year}}){% endif %}{% if part %}-{{part}}{% endif %}{% if videoFormat %} - {{videoFormat}}{% endif %}{{fileExt}}
  • TV_RENAME_FORMAT 电视剧重命名格式

TV_RENAME_FORMAT额外支持的配置项:

season 季号
episode 集号
season_episode 季集 SxxExx

TV_RENAME_FORMAT默认配置格式:

{{title}}{% if year %} ({{year}}){% endif %}/Season {{season}}/{{title}} - {{season_episode}}{% if part %}-{{part}}{% endif %}{% if episode %} - 第 {{episode}} 集{% endif %}{{fileExt}}

3. 过滤规则

设定-规则中设定,规则说明:

  • 仅支持使用内置规则进行排列组合,内置规则有:BLU4K1080PCNSUBSPECSUBH265H264DOLBYHDRREMUXWEBDLFREE
  • &表示与,表示或,!表示非,>表示优先级层级
  • 符合任一层级规则的资源将被标识选中,匹配成功的层级做为该资源的优先级,排越前面优先级超高
  • 不符合过滤规则所有层级规则的资源将不会被选中

!BLU & 4K & CN > !BLU & 1080P & CN > !BLU & 4K > !BLU & 1080P 表示优先中文字幕非蓝光4K然后中文字幕非蓝光1080P然后非蓝光4K最后非蓝光1080P

使用

  • 通过CookieCloud同步快速同步站点不需要使用的站点可在WEB管理界面中禁用。
  • 通过下载器监控实现资源下载后自动整理入库刮削。
  • 通过微信/Telegram/Slack远程搜索下载、订阅和管理设置其中Telegram将会自动添加操作菜单。微信回调相对路径为/api/v1/message/
  • 通过WEB进行管理将WEB添加到手机桌面获得类App使用效果管理界面端口3000
  • 设置媒体服务器Webhook通过MoviePilot发送播放通知以及后续播放限速等插件功能。Webhook回调相对路径为/api/v1/webhook?token=moviepilot,其中moviepilot为设置的API_TOKEN
  • 将MoviePilot做为Radarr或Sonarr服务器添加到Overseerr或Jellyseerr可使用Overseerr/Jellyseerr选片。

image

image

image

image

TODO

仍在开发中,当前功能并不完善。

  • 搜索结果过滤
  • 多通知渠道支持
  • 多媒体库目录支持
  • 自定义识别词
  • 便捷工具
  • 过滤规则维护
  • 手动整理功能增强
  • 本地存在标识
  • 媒体详情页面
  • 洗版支持
  • 插件管理
Description
No description provided
Readme 48 MiB
Languages
Python 99.4%
Shell 0.4%
Dockerfile 0.2%