Tag Archives: Plex

How to Configure Multiple DNS Redirections (PlexConnect-like Service) for Apple TV

目標

  • Apple TV 通過修改 DNS,可以觀看 享看
  • 同時也可以通過本地架設 Plex+PlexConnect 來觀看 Plex

難點

  • 「享看」官方的 DNS 和 PlexConnect 都默認劫持 Apple TV 中的 Trailers 頻道,同時使用會造成衝突
  • OS X Server 在 Mavericks 中對 HTTP 的 80 端口享有絕對控制權,而 PlexConnect 需要獨佔 80 端口

實現方法

  • 在 OS X Server 上安裝 Plex 、 PlexConnect 和 Dnsmasq
  • 通過在 OS X Server 上創建新介面,設置額外 IP,避免 PlexConnect 80 端口衝突
  • 本地架設 Dnsmasq,同時劫持 Apple TV 上兩個不同頻道來實現「享看」和 PlexConnect 共存

配料表

  • 裝有 OS X 的電腦一部
  • Apple TV 一部
  • Plex 一只
  • PlexConnect 一只
  • Dnsmasq 一只

網絡基本結構設置

  • 10.0.1.3:OS X Server,DHCP with manual address(或通過 MAC 地址綁定亦可,主要是需要保持主 IP 固定)
  • 10.0.1.4:OS X Server,額外 IP(PlexConnect),DHCP with manual address

為 OS X Server 設置額外 IP

由於 OS X 上已經安裝過 Server app,為了避免與系統的 80 端口衝突,我們必須將 PlexConnect 的 80 端口指向額外的 IP 。首先我們 duplicate 現有的網絡(或者直接創建新介面),Wi-Fi 、以太均可,為了區分,可以將此服務命名為「PlexConnect」,IP 獲取方法為 DHCP with manual address,地址為 10.0.1.4(具體情況請根據自己的路由分配狀況自行修改),然後將 DNS 設置為 10.0.1.3,即 Dnsmasq 所在的主 IP,Dnsmasq 的相關設置我們會在接下來講,其他設置保持默認

Dnsmasq 安裝與配置

推薦的方法是通過 Homebrew 安裝:

brew install dnsmasq

哦?想自己編譯源代碼安裝?那請跳過此步驟

然後我們需要 vi /usr/local/etc/dnsmasq.conf 來修改 Dnsmasq 的配置,Dnsmasq 的默認配置是無法作為 DNS server 使用的,以下是必備的配置:

https://gist.github.com/9fea03b8e6349ab3c805

  • port=53:DNS 默認端口,這裡我們需要禁用 Server app 里的 DNS
  • domain-needed:不轉發 plain name
  • bogus-priv:不轉發本地的 nslookup 請求
  • server=8.8.8.8server=8.8.4.4:使用 Google 的 DNS 作為主、從 DNS,當然也可以選擇 ISP 提供的
  • local=/localnet/:讓本地域名走 /etc/hosts 或者 DHCP
  • address=/trailers.apple.com/180.153.225.136:享看 DNS,劫持 Apple TV 中的 Trailers,具體的 IP 地址請去享看官網參考
  • address=/secure.marketwatch.com/10.0.1.4:PlexConnect DNS,劫持的是 WSJ,指向的是本地的 PlexConnect instance
  • listen-address:限制 Dnsmasq listen 指定地址,當然也可以按 interface 來限制

以上就是本教程的技巧所在,運用 Dnsmasq 對不同域名進行劫持,來實現「享看」和 PlexConnect 的共存,通過下面的方法可以測試是否設置正確:

dig trailers.apple.com @10.0.1.3
dig secure.marketwatch.com @10.0.1.3

執行下面命令可以啓動、停止 Dnsmasq

sudo launchctl stop homebrew.mxcl.dnsmasq
sudo launchctl start homebrew.mxcl.dnsmasq

PlexConnect 的安裝與配置

PlexConnect 官方提供有 詳細的教程,具體請參考官方的方法。在這裡我只對配置文件做詳細描述:

配置方面,為了避免與 Server app 的 httpd 衝突,我們要將 PlexConnect 的 server 綁定到之前設置的 10.0.1.4 上,另外我們也自己搭建了 Dnsmasq,需要把 PlexConnect 自帶的 DNS 服務禁用,於是我們的 PlexConnect 配置如下:

https://gist.github.com/cb1e7dee359fe3d9b8a1

以下是必備的設置:

  • enable_plexconnect_autodetect = False:因為我們有多 IP,避免造成混亂,我們把 Plex server 的 auto detect 禁用掉
  • ip_pms = 10.0.1.3:既然禁用了,我就需要指定 Plex 的 IP
  • port_pms = 32400:相應的端口,我是用的默認端口
  • ip_plexconnect = 10.0.1.4:指定 PlexConnect 的 IP 地址,這裡用我們創建的新 IP
  • enable_dnsserver = False:這裡禁用自帶 DNS
  • ip_dnsmaster = 10.0.1.3:使用我們自己的 Dnsmasq
  • hosttointercept = secure.marketwatch.com:設置要劫持的域名,這裡要與 Dnsmasq 中的設置保持一致

測試

當以上都設置好後,確認 Dnsmasq 、 PlexConnect 均已運行,在瀏覽器中打開 http://10.0.1.3/,應該可以返回 httpd 的網站;打開 http://10.0.1.4/ 則是返回「Error response」,一個 code 403 的頁面,這時就是配置正確了

Apple TV 證書設置

測試都沒甚麼問題後,可以開始搞 Apple TV 的證書了,Apple TV 從某一版本更新後,所有的連接都走 HTTPS 了,這時候我們如果直接劫持就不會奏效,於是我們需要使用自己的證書並上傳到 Apple TV,讓 Apple TV 認為我們的劫持的內容才是真正的網站內容

設置方法比較簡單,可以通過 USB 線與 Apple TV 連接傳輸,也可以通過直接在 Apple TV 中直接添加,具體方法請參考 PlexConnect 文檔,需要注意的是,因為我們劫持了兩個頻道,所以兩個頻道的證書都需要進行 hack 並通過 profile 上傳到 Apple TV 中

證書設置好了,接下來就可以在 Apple TV 上進行測試了,將 Apple TV 的 DNS 改為 10.0.1.3,然後回到主屏分別進入 Trailers 和 WSJ 測試即可

更多設置

  • 你可以設置讓 Dnsmasq 開機時自動加載,設置方法可以參考 brew info dnsmasq
  • 你也可以設置讓 PlexConnect 開機是自動加載,設置方法請參考 官方文檔
  • 如果你也有使用 Server app 自帶的 DNS,可以有多種方案,一是全轉移到 Dnsmasq(推薦);或者保持 nameddnsmasq 共存,但這時需要設置 named 只監聽 10.0.1.3;再或者全部轉移到自帶 DNS 服務,如果是後兩者,這篇文章 可能會幫到你
  • 如果你 Server app 中的 httpd 沒跑任何服務,也可以通過 配置反向代理 來將系統的 web 服務轉向 PlexConnect 的內容

FlexGet + Transmission + Plex AniDB Agent on macOS

目標

  • 自動下載新番種子
  • 種子自動加入 Transmission 下載隊列
  • 新番文件自動重命名到 Plex 兼容格式
  • 通過 Plex AniDB agent 自動獲取新番相關信息

總結:基於 FlexGet 和 Transmission 的全自動追番方案

實現方法

  • 通過 FlexGet 讀取 RSS,自動下載種子文件,通過正則自動剔除無效字符
  • 通過 FlexGet 的 transmissionrpc 插件自動將種子傳送到 Transmission
  • Transmission 下載完成後觸發腳本,自動將種子重命名為 Plex 可識別格式
  • 通過 Plex 的第三方插件 Hama.bundle 自動獲取新番相關訊息

配料表

  • 裝有 macOS 的電腦一部
  • Plex
  • Transmission
  • FlexGet

配置 FlexGet(2021 版)

最新版本配置採用 FlexGet 內置的 manipulate 方法,對 RSS 直接修改為符合 Plex 查詢標準的文件名,避免了使用 Transmission 調用外掛腳本的方案,下面的正則可根據實際場景進行修改:

  bangumi:
    template: torrent
    manipulate:
      - title:
          # remove underscores
          replace:
            regexp: '_'
            format: ''
      - title:
          replace:
            regexp: '★'
            format: ''
      - title:
          extract: '^[\[【].*?[\]】](.*)'
      - title:
          replace:
            regexp: '【'
            format: '['
      - title:
          replace:
            regexp: '】'
            format: ']'
      - title:
          replace:
            regexp: '】'
            format: ']'
      - title:
          replace:
            regexp: '(?:\[|【)(简体|簡體|繁体|繁體|简日双语|繁日雙語|GB|BIG5|MP4)(?:\]|】)'
            format: ''
      - title:
          replace:
            regexp: '(?:\[|【|第)(\d\d)(?:\]|】|話|话)'
            # format: 's01e\1'
            format: '\1'
      - title:
          # replace `][` to ` ` (space)
          replace:
            regexp: '\]\['
            format: ' '
      - title:
          # remove leftover brackets
          replace:
            regexp: '[\[\]【】]'
            format: ' '
      - title:
          replace:
            regexp: '(?:.*字幕 (?: 组|組))'
            format: ''
      - title:
          replace:
            regexp: '\[(?:.+? 月新? 番)'
            format: ''
    set:
      path: /Volumes/Gizur/Downloads/Anime/{{ series_name }}
      content_filename: '{{ series_name }} - {{ series_id|pad(2) }}'
      magnetization_timeout: 45
    series:
      - スーパーカブ:
          alternate_name: 本田小狼與我 Super Cub
      - ダイナ莊びより:
          alternate_name: 恐龍日和
      - 回復術士のやり直し 〜即死魔法とスキルコピーの超越ヒール〜:

配置 FlexGet(2013 版,無需再看)

FlexGet 的安裝方法和自動運行請參考參考 官方文檔,寫的很詳細

配置文件如下,要點在於 presets.global.transmission.path,為了能讓 Plex 識別和方便管理,每一個動畫 要分別放在相應命名的目錄。其中 {{task}} 對應的就是 tasks 下的新番標題:

presets:
  global:
    accept_all: true
    transmission:
      host: localhost
      port: 9091
      addpaused: No
      ratio: 0.01
      removewhendone: Yes
      path: "/Volumes/Backups HD/Anime/{{task}}/"
tasks:
  WHITE ALBUM2:
    rss: http://bt.ktxp.com/rss-search-%E6%BE%84%E7%A9%BA%E5%AD%A6%E5%9B%AD+%E7%99%BD%E8%89%B2%E7%9B%B8%E7%B0%BF+2+MP4+720p.xml
  アウトブレイク・カンパニー:
    rss: http://bt.ktxp.com/rss-search-%E6%BE%84%E7%A9%BA%E5%AD%A6%E5%9B%AD+%E8%90%8C%E8%90%8C%E4%BE%B5%E7%95%A5%E8%80%85+MP4+720p.xml
  ガリレイドンナ:
    rss: http://bt.ktxp.com/rss-search-%E6%BE%84%E7%A9%BA%E5%AD%A6%E5%9B%AD+%E4%BC%BD%E5%88%A9%E7%95%A5%E5%B0%91%E5%A5%B3+%E7%AE%80%E4%BD%93+MP4+720p.xml
  キルラキル:
    rss: http://bt.ktxp.com/rss-search-%E6%A5%B5%E5%BD%B1%E5%AD%97%E5%B9%95%E7%A4%BE+Kill+La+Kill+BIG5+MP4+720p.xml
  京騒戯画:
    rss: http://bt.ktxp.com/rss-search-WOLF+%E4%BA%AC%E9%AA%9A%E6%88%8F%E7%94%BB+GB+720P+MP4.xml
  凪のあすから:
    rss: http://bt.ktxp.com/rss-search-%E5%8B%95%E6%BC%AB%E5%9C%8B+%E4%BE%86%E8%87%AA%E9%A2%A8%E5%B9%B3%E6%B5%AA%E9%9D%9C%E7%9A%84%E6%98%8E%E5%A4%A9+720P+%E7%B9%81%E9%AB%94+MP4.xml
  境界の彼方:
    rss: http://bt.ktxp.com/rss-search-%E6%BE%84%E7%A9%BA%E5%AD%A6%E5%9B%AD+%E5%A2%83%E7%95%8C%E7%9A%84%E5%BD%BC%E6%96%B9+%E7%AE%80%E4%BD%93+MP4+720p.xml
  夜桜四重奏 ~ハナノウタ~:
    rss: http://bt.ktxp.com/rss-search-%E6%A5%B5%E5%BD%B1%E5%AD%97%E5%B9%95%E7%A4%BE+%E5%A4%9C%E6%AB%BB%E5%9B%9B%E9%87%8D%E5%A5%

配置 Transmission

如果使用了 2021 版的方案,請略過本段

Transmission 本身不需要進行過多配置,為了避免下載隊列越來越多,記得勾選下載完成後從隊列刪除這個選項。下面是其對應的 post-process 腳本:

#!/bin/sh

# Search all subdirectories
# Use rename -n for dry-run
cd /Volumes/Backups\ HD/Anime
find . -name '*.mp4' -print0 | xargs -0 /usr/local/bin/rename -f 's/\[(.*)\]\[(.*)\]\[(\d{2})\].*$/$2 - $3\.mp4/'

上述腳本會通過正則將 [Fansub][Title][Episode]*.mp4 這樣的格式替換為 Plex 可識別的 Title - Episode.mp4 格式,例如 [WOLF&HYSUB][Kyousougiga][00][GB][720P][MP4].mp4 就會被替換為 Kyousougiga - 00.mp4

配置 Plex w/ Hama Agent

注意!,已棄用 AniDB agent,改為 Hama Agent 。詳情請訪問最新文章:Hama (HTTP Anidb Metadata Agent) and Plex Media Server – 2014-04-09

訪問 Plex 論壇 下載 AniDB agent 并安裝,通過 Plex 的 web 界面進行管理即可

完成配置後可通過下列指令進行 dry run 測試:

flexget -c ~/.flexget/config.yml --test execute

以下是效果圖: