Media-Download-Helper 完整部署说明

Media-Download-Helper 完整部署说明

前排提示:由于使用到了 Telegram、Google 等服务,所以当前方案不建议国内用户使用!

基于 docker 安装 qbittorrent WebUI

使用 docker 安装 qbittorrent 非常简单,教程也非常非常多,而且能看到这篇教程的人,我估计大部分可能正在使用 qbittorrent,因此这里就不在赘述了。

这里提供一个参考链接:《n1 docker安装qb》

如果对 docker,参考链接中的 docker compose 部分不熟悉的话,还是先去学习一下相关的基础知识吧。

在安装完成后,我们会获得一个 WebUI 的地址,形如:http://192.168.1.123:8080/,我们记录下来,一同需要记录的还有登录的用户名 QBIT_USERNAME 和密码 QBIT_PASSWORD

安装完成后,可以先手动下载一个文件试试,验证一下是否能正常下载磁力链接,以及下载后的文件是否能正常获取和使用。避免后续出现下载问题,例如无法联网,无法解析磁力链接,下载无速度,找不到下载的文件等。

申请 Telegram Bot 并获取对应 Token

这一部分不做详细介绍,网上教程非常多,直接按照本章节标题进行 Google 即可。

如果懒得 Google,也可以参考这篇文章《Telegram 机器人的申请和设置图文教程》,里面的教程非常详细,原作者也由对应的油管视频可供参考,只要按部就班抄作业即可。

在此章节中,我们获取到了一个 "Bot_TOKEN",在后续的配置和部署中会使用到。

部署 Google Apps Script 在线脚本

默认情况下,我们发送给 Telegram Bot 的消息是直接发送给 Telegram 官方服务器的,在这种情况下,我们无法获取到 Bot 接收到的数据并做出相应的处理和相应。

但是 Telegram 给我们提供了一个为 bot 设置 webhook 的方法 /setwebhook?url=xxxx,这样我们就可以通过 webhook 获取到用户发送的消息。这里我们通过 Google Apps Script 来实现这个功能。

这一部分也是受到《Telegram 机器人的申请和设置图文教程》作者的系列教程《Telegram Bot 第一个回声机器人 -- 你是汤姆猫吧[第二集]》启发。原文中作者通过 Google Apps Script 实现了一个简单的回声机器人,并且在后续的系列文章中,扩展了不少 Telegram bot 的高级用法,感兴趣朋友的也可以参考参考。

步骤 1、创建 Google Apps Script 项目

打开 Google Apps Script 的官网,点击右上角的 新建 按钮,创建一个新的项目。

步骤 2、编辑脚本的代码

步骤 3、部署项目

授权时可能会出现风险提示界面,估计是挂了代理的缘故,按下图操作继续即可。

步骤 4、获取 Webhook URL

在上一步中,我们最终获取了一个 Web 应用的网址,我们可以直接将这个网址粘贴到浏览器地址栏进行访问,来验证部署是否成功,当显示 {"status":"OK","magnet_urls":[]} 时,表明已部署成功。 如下图所示:

我们还需要对这个 Web Url 进行一些处理,打开这个 Url Encode 网站 https://www.urlencoder.org/,将这个 url 进行编码,然后将编码后的 url 保存下来,后续会用。按下图操作即可:

至此我们已经完成了 Google Apps Script 在线脚本的部署,我们在这里获得了一个 "原始 URL" ,和一个 "编码后 URL"

步骤 5、注册 Telegram bot Webhook

在这一步中,我们需要将上一步中获取到的 "编码后 URL" 注册到我们的 Telegram Bot 中,这样我们就可以通过 webhook 获取到用户发送的消息。

我们通过 Telegram Bot 的 API 来实现这个功能,这里用到两个 API,一个是 setWebhook,一个是 getWebhookInfo

步骤 5.1、注册

我们使用 "Bot TOKEN""编码后 URL" 两个参数,按照以下格式完成 API 的组装:

shell 复制代码
# 将 {Bot TOKEN} 替换为你的 Bot TOKEN
# 将 {编码后 URL} 替换为你的 编码后 URL
https://api.telegram.org/bot{Bot TOKEN}/setWebhook?url={编码后 URL}

然后将这个组装后的 url 粘贴到浏览器地址栏中进行访问,如果返回 {"ok":true,"result":true,"description":"Webhook was set"},则表示注册成功。如下图所示:

步骤 5.2、验证

我们可以通过 getWebhookInfo API 来验证是否注册成功,组装后的 url 如下:

shell 复制代码
# 将 {Bot TOKEN} 替换为你的 Bot TOKEN
https://api.telegram.org/bot{Bot TOKEN}/getWebhookInfo

然后将这个组装后的 url 粘贴到浏览器地址栏中进行访问,可以在返回结果中看到注册的 url,如下图所示:

可以将图中红框部分的 URL 与我们在 步骤 4 中获取到的 "原始 URL" 进行对比,如果一致,则表示注册成功。

申请 TMDB API Token

想要达到 README.md 中展示的效果,在下载完成后将详细的影片信息推送到 Tg bot,则还需要一个 TMDB 的 API Token。

这里也不做赘述了,推荐一个网上的教程吧:《教程篇 篇三:影视刮削必备神器------TMDB API申请攻略》。虽然发布日期比较久远了,但是流程估计整体也差不多,作者写的也比较详细,可以参考一下。

最终我们会获得下图中的 "API 密钥 (API Key)""API 读访问令牌 (API Read Access Token)" ,在最新的官方 API 手册中,官方推荐的是使用后者进行查询操作。

因此我们将这个 **"API 读访问令牌"**保存下来即可,这个 Token 有点长,一定复制全,记得注意保护敏感数据哦 ~

基于 docker 部署 Media-Download-Helper

本项目不是一定需要 docker 才能部署,使用 docker 只是为了保证环境的一致性,想必对 Python 比较熟悉的朋友也是对 Python 版本和各种依赖包的版本管理比较头疼的,使用 docker 可以很好的解决这个问题。

不过在最后我还是会补充一个脚本,方便部分朋友直接运行或者调试 ^ ^

docker-compose 部署

如果有 docker-compose 的环境,则可以很方便使用仓库中 dockerfile/docker-compose.yml 文件进行部署。

yml 复制代码
version: '3'
services:
  media_dlhelper:
    build:
      context: .
      dockerfile: dockerfile
    image: b1gfac3c4t/media_dlhelper:v2.0.0
    environment:
      - TZ=Asia/Shanghai
      # 这里所有的环境变量都不要使用引号
      # 必填参数
      - QBIT_HOST=<your qbittorrent WebUI base API>
      - QBIT_USER=<your qbittorrent username>
      - QBIT_PASS=<your qbittorrent password>
      - BOT_TOKEN=<your telegram bot token>
      - TMDB_API_TOKEN=<your TMDB API token>
      - GOOGLE_APPS_SCRIPT_URL= <google apps scrip 部署后的原始web应用网址>
      # 可选参数
      - LOG_LEVEL=INFO # [DEBUG, INFO, WARNING] 三个等级,默认 WARNING
      - LOG_EXPORT=True # [True, False0] 是否将日志输出到文件,默认 False
      - LOG_PATH=/var/tmp/media_dlhelper_logs/ # 默认 /var/tmp/media_dlhelper_logs/
    network_mode: "bridge"

只需要将上面的环境变量替换为自己的即可,然后执行 docker-compose up -d 即可完成部署。

docker run 部署

如果没有 docker-compose 的环境,也可以使用 docker run 的方式进行部署。直接执行下面的命令即可

bash 复制代码
docker pull b1gfac3c4t/media_dlhelper:v2.0.0
docker run -d \
  --name media_dlhelper \
  -e TZ=Asia/Shanghai \
  -e QBIT_HOST=<your qbittorrent WebUI base API> \
  -e QBIT_USER=<your qbittorrent username> \
  -e QBIT_PASS=<your qbittorrent password> \
  -e BOT_TOKEN=<your telegram bot token> \
  -e TMDB_API_TOKEN=<your TMDB API token> \
  -e GOOGLE_APPS_SCRIPT_URL=<google apps scrip 部署后的原始web应用网址> \
  -e LOG_LEVEL=INFO \
  -e LOG_EXPORT=True \
  -e LOG_PATH=/var/tmp/media_dlhelper_logs/ \
  --network=bridge \
  --restart=always \
  b1gfac3c4t/media_dlhelper:v2.0.0

直接运行

如果不想使用 docker,也可以直接运行项目中的 main.py 文件,为了方便,这里提供了一个运行脚本,只要在项目的根目录下创建一个 run.sh 文件,然后将下面的内容复制进去,替换环境变量的值即可:

bash 复制代码
#!/bin/bash

export QBIT_HOST=''
export QBIT_USER=''
export QBIT_PASS=''
export BOT_TOKEN=''
export TMDB_API_TOKEN=''
export GOOGLE_APPS_SCRIPT_URL=''
export LOG_LEVEL='DEBUG'
export LOG_EXPORT='True'
export LOG_PATH='./log'

nohup python3 main.py > /dev/null 2>&1 &

保存后,直接运行 sh run.sh 即可。

相关推荐
Koi慢热2 分钟前
路由基础(全)
linux·网络·网络协议·安全
hzyyyyyyyu2 小时前
内网安全隧道搭建-ngrok-frp-nps-sapp
服务器·网络·安全
刽子手发艺2 小时前
WebSocket详解、WebSocket入门案例
网络·websocket·网络协议
速盾cdn6 小时前
速盾:CDN是否支持屏蔽IP?
网络·网络协议·tcp/ip
yaoxin5211236 小时前
第二十七章 TCP 客户端 服务器通信 - 连接管理
服务器·网络·tcp/ip
内核程序员kevin6 小时前
TCP Listen 队列详解与优化指南
linux·网络·tcp/ip
PersistJiao8 小时前
Spark 分布式计算中网络传输和序列化的关系(一)
大数据·网络·spark
黑客Ash10 小时前
【D01】网络安全概论
网络·安全·web安全·php
->yjy10 小时前
计算机网络(第一章)
网络·计算机网络·php