Skip to content

yojo-art/media-proxy-rs

Repository files navigation

media-proxy-rs

misskey/cherrypick用メディアプロキシのrust実装

機能的には互換性を維持しつつ、様々な画像形式のデコードに対応
ほとんどの画像読み書きにimage crate v0.25を使用しています

実行(Docker)

docker run -itd -p 12766:12766 ghcr.io/yojo-art/media-proxy-rs:main

実行(Linux)

例(x86_64/amd64)

curl -L https://github.com/yojo-art/media-proxy-rs/releases/download/nightly/media-proxy-rs_linux-amd64.gz | gzip -d > ./media-proxy-rs
chmod u+x ./media-proxy-rs
./media-proxy-rs

利用するプラットフォームに応じて適切なバイナリを選択してください。ファイル名のリストを示します

media-proxy-rs_linux-386.gz
media-proxy-rs_linux-amd64.gz
media-proxy-rs_linux-arm-v6.gz
media-proxy-rs_linux-arm-v7.gz
media-proxy-rs_linux-arm64.gz
media-proxy-rs_linux-riscv64.gz

設定ファイル

環境変数MEDIA_PROXY_CONFIG_PATHを設定する事でファイルの場所を指定できます
デフォルト値は$(pwd)/config.jsonです
十分に強力なマシンではencode_aviftrueに変更することでAVIFエンコードを利用する事ができます

target support

  • x86_64-unknown-linux-musl
  • aarch64-unknown-linux-musl
  • armv7-unknown-linux-musleabihf
  • arm-unknown-linux-musleabihf
  • i686-unknown-linux-musl
  • riscv64gc-unknown-linux-musl

ビルド(x64/aarch64 Docker)

Dockerを使用する場合はbuildxとqemuによるクロスコンパイルが利用できます
ビルド対象プラットフォームはtarget supportの項目を参照してください

  1. git clone https://github.com/yojo-art/media-proxy-rs && cd media-proxy-rs
  2. docker build -t media-proxy-rs .

ビルド(x64 Debian系)

この方法ではx86_64-unknown-linux-gnu向けにビルドします
すべてを静的に組み込むmusl系とは異なる共有ライブラリを必要とする場合があります

  1. https://www.rust-lang.org/ja/tools/install に従ってrustをインストール
  2. apt-get install -y meson ninja-build pkg-config nasm git
  3. git clone https://github.com/yojo-art/media-proxy-rs && cd media-proxy-rs
  4. cargo build --release

対応する画像形式

  • AVIF(dav1d)
  • BMP
  • DDS
  • Farbfeld
  • GIF
  • HDR
  • ICO(png+rgba not support)
  • JPEG
  • EXR
  • PNG
  • PNM
  • QOI
  • TGA
  • TIFF
  • WebP
  • JPEG XL(jxl-oxide)
  • JPEG 2000(openjp2)
  • JPEG XR(jxrlib)