mirror of
https://github.com/linuxserver/docker-beets
synced 2025-12-06 00:13:03 +01:00
Merge pull request #92 from linuxserver/3.17-master
Rebasing master to alpine 3.17
This commit is contained in:
commit
0efe516128
20 changed files with 92 additions and 110 deletions
0
.github/workflows/call_invalid_helper.yml
vendored
Executable file → Normal file
0
.github/workflows/call_invalid_helper.yml
vendored
Executable file → Normal file
0
.github/workflows/permissions.yml
vendored
Executable file → Normal file
0
.github/workflows/permissions.yml
vendored
Executable file → Normal file
53
Dockerfile
53
Dockerfile
|
|
@ -1,4 +1,6 @@
|
|||
FROM ghcr.io/linuxserver/baseimage-alpine:3.15
|
||||
# syntax=docker/dockerfile:1
|
||||
|
||||
FROM ghcr.io/linuxserver/baseimage-alpine:3.17
|
||||
|
||||
# set version label
|
||||
ARG BUILD_DATE
|
||||
|
|
@ -10,50 +12,44 @@ LABEL maintainer="aptalca"
|
|||
RUN \
|
||||
echo "**** install build packages ****" && \
|
||||
apk add --no-cache --virtual=build-dependencies --upgrade \
|
||||
build-base \
|
||||
cairo-dev \
|
||||
cargo \
|
||||
cmake \
|
||||
ffmpeg-dev \
|
||||
fftw-dev \
|
||||
g++ \
|
||||
gcc \
|
||||
git \
|
||||
gobject-introspection-dev \
|
||||
jpeg-dev \
|
||||
libpng-dev \
|
||||
make \
|
||||
mpg123-dev \
|
||||
openjpeg-dev \
|
||||
python3-dev && \
|
||||
echo "**** install runtime packages ****" && \
|
||||
apk add --no-cache --upgrade \
|
||||
curl \
|
||||
chromaprint \
|
||||
expat \
|
||||
ffmpeg \
|
||||
ffmpeg-libs \
|
||||
fftw \
|
||||
flac \
|
||||
gdbm \
|
||||
gst-plugins-good \
|
||||
gstreamer \
|
||||
jpeg \
|
||||
jq \
|
||||
lame \
|
||||
libffi \
|
||||
libpng \
|
||||
mpg123 \
|
||||
nano \
|
||||
openjpeg \
|
||||
py3-gobject3 \
|
||||
py3-pip \
|
||||
py3-pylast \
|
||||
python3 \
|
||||
sqlite-libs \
|
||||
tar \
|
||||
wget && \
|
||||
sqlite-libs && \
|
||||
echo "**** compile mp3gain ****" && \
|
||||
mkdir -p \
|
||||
/tmp/mp3gain-src && \
|
||||
curl -o \
|
||||
/tmp/mp3gain-src/mp3gain.zip -sL \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.1/mp3gain-1_6_1-src.zip && \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.2/mp3gain-1_6_2-src.zip && \
|
||||
cd /tmp/mp3gain-src && \
|
||||
unzip -qq /tmp/mp3gain-src/mp3gain.zip && \
|
||||
sed -i "s#/usr/local/bin#/usr/bin#g" /tmp/mp3gain-src/Makefile && \
|
||||
|
|
@ -69,39 +65,34 @@ RUN \
|
|||
tar xzf /tmp/mp3val-src/mp3val.tar.gz --strip 1 && \
|
||||
make -f Makefile.linux && \
|
||||
cp -p mp3val /usr/bin && \
|
||||
echo "**** compile chromaprint ****" && \
|
||||
git clone https://bitbucket.org/acoustid/chromaprint.git \
|
||||
/tmp/chromaprint && \
|
||||
cd /tmp/chromaprint && \
|
||||
cmake \
|
||||
-DBUILD_TOOLS=ON \
|
||||
-DCMAKE_BUILD_TYPE=Release \
|
||||
-DCMAKE_INSTALL_PREFIX:PATH=/usr && \
|
||||
make && \
|
||||
make install && \
|
||||
echo "**** install pip packages ****" && \
|
||||
if [ -z ${BEETS_VERSION+x} ]; then \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json \
|
||||
|jq -r '. | .info.version'); \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json |jq -r '. | .info.version'); \
|
||||
fi && \
|
||||
python3 -m pip install --upgrade pip && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine/ \
|
||||
wheel \
|
||||
python3 -m ensurepip && \
|
||||
pip3 install -U --no-cache-dir \
|
||||
pip \
|
||||
wheel && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine-3.17/ \
|
||||
beautifulsoup4 \
|
||||
beets==${BEETS_VERSION} \
|
||||
beets-extrafiles \
|
||||
beetcamp \
|
||||
discogs-client \
|
||||
flask \
|
||||
PyGObject \
|
||||
pillow \
|
||||
pyacoustid \
|
||||
pylast \
|
||||
requests \
|
||||
unidecode && \
|
||||
echo "**** cleanup ****" && \
|
||||
apk del --purge \
|
||||
build-dependencies && \
|
||||
rm -rf \
|
||||
/root/.cache \
|
||||
/tmp/*
|
||||
/tmp/* \
|
||||
$HOME/.cache \
|
||||
$HOME/.cargo
|
||||
|
||||
# environment settings
|
||||
ENV BEETSDIR="/config" \
|
||||
|
|
|
|||
|
|
@ -1,4 +1,6 @@
|
|||
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.15
|
||||
# syntax=docker/dockerfile:1
|
||||
|
||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm64v8-3.17
|
||||
|
||||
# set version label
|
||||
ARG BUILD_DATE
|
||||
|
|
@ -10,21 +12,22 @@ LABEL maintainer="aptalca"
|
|||
RUN \
|
||||
echo "**** install build packages ****" && \
|
||||
apk add --no-cache --virtual=build-dependencies --upgrade \
|
||||
build-base \
|
||||
cairo-dev \
|
||||
cargo \
|
||||
cmake \
|
||||
ffmpeg-dev \
|
||||
fftw-dev \
|
||||
g++ \
|
||||
gcc \
|
||||
git \
|
||||
gobject-introspection-dev \
|
||||
jpeg-dev \
|
||||
libpng-dev \
|
||||
make \
|
||||
mpg123-dev \
|
||||
openjpeg-dev \
|
||||
python3-dev && \
|
||||
echo "**** install runtime packages ****" && \
|
||||
apk add --no-cache --upgrade \
|
||||
curl \
|
||||
chromaprint \
|
||||
expat \
|
||||
ffmpeg \
|
||||
ffmpeg-libs \
|
||||
|
|
@ -34,26 +37,20 @@ RUN \
|
|||
gst-plugins-good \
|
||||
gstreamer \
|
||||
jpeg \
|
||||
jq \
|
||||
lame \
|
||||
libffi \
|
||||
libpng \
|
||||
mpg123 \
|
||||
nano \
|
||||
openjpeg \
|
||||
py3-gobject3 \
|
||||
py3-pip \
|
||||
py3-pylast \
|
||||
python3 \
|
||||
sqlite-libs \
|
||||
tar \
|
||||
wget && \
|
||||
sqlite-libs && \
|
||||
echo "**** compile mp3gain ****" && \
|
||||
mkdir -p \
|
||||
/tmp/mp3gain-src && \
|
||||
curl -o \
|
||||
/tmp/mp3gain-src/mp3gain.zip -sL \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.1/mp3gain-1_6_1-src.zip && \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.2/mp3gain-1_6_2-src.zip && \
|
||||
cd /tmp/mp3gain-src && \
|
||||
unzip -qq /tmp/mp3gain-src/mp3gain.zip && \
|
||||
sed -i "s#/usr/local/bin#/usr/bin#g" /tmp/mp3gain-src/Makefile && \
|
||||
|
|
@ -69,39 +66,34 @@ RUN \
|
|||
tar xzf /tmp/mp3val-src/mp3val.tar.gz --strip 1 && \
|
||||
make -f Makefile.linux && \
|
||||
cp -p mp3val /usr/bin && \
|
||||
echo "**** compile chromaprint ****" && \
|
||||
git clone https://bitbucket.org/acoustid/chromaprint.git \
|
||||
/tmp/chromaprint && \
|
||||
cd /tmp/chromaprint && \
|
||||
cmake \
|
||||
-DBUILD_TOOLS=ON \
|
||||
-DCMAKE_BUILD_TYPE=Release \
|
||||
-DCMAKE_INSTALL_PREFIX:PATH=/usr && \
|
||||
make && \
|
||||
make install && \
|
||||
echo "**** install pip packages ****" && \
|
||||
if [ -z ${BEETS_VERSION+x} ]; then \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json \
|
||||
|jq -r '. | .info.version'); \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json |jq -r '. | .info.version'); \
|
||||
fi && \
|
||||
python3 -m pip install --upgrade pip && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine/ \
|
||||
wheel \
|
||||
python3 -m ensurepip && \
|
||||
pip3 install -U --no-cache-dir \
|
||||
pip \
|
||||
wheel && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine-3.17/ \
|
||||
beautifulsoup4 \
|
||||
beets==${BEETS_VERSION} \
|
||||
beets-extrafiles \
|
||||
beetcamp \
|
||||
discogs-client \
|
||||
flask \
|
||||
PyGObject \
|
||||
pillow \
|
||||
pyacoustid \
|
||||
pylast \
|
||||
requests \
|
||||
unidecode && \
|
||||
echo "**** cleanup ****" && \
|
||||
apk del --purge \
|
||||
build-dependencies && \
|
||||
rm -rf \
|
||||
/root/.cache \
|
||||
/tmp/*
|
||||
/tmp/* \
|
||||
$HOME/.cache \
|
||||
$HOME/.cargo
|
||||
|
||||
# environment settings
|
||||
ENV BEETSDIR="/config" \
|
||||
|
|
|
|||
|
|
@ -1,4 +1,6 @@
|
|||
FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.15
|
||||
# syntax=docker/dockerfile:1
|
||||
|
||||
FROM ghcr.io/linuxserver/baseimage-alpine:arm32v7-3.17
|
||||
|
||||
# set version label
|
||||
ARG BUILD_DATE
|
||||
|
|
@ -10,21 +12,22 @@ LABEL maintainer="aptalca"
|
|||
RUN \
|
||||
echo "**** install build packages ****" && \
|
||||
apk add --no-cache --virtual=build-dependencies --upgrade \
|
||||
build-base \
|
||||
cairo-dev \
|
||||
cargo \
|
||||
cmake \
|
||||
ffmpeg-dev \
|
||||
fftw-dev \
|
||||
g++ \
|
||||
gcc \
|
||||
git \
|
||||
gobject-introspection-dev \
|
||||
jpeg-dev \
|
||||
libpng-dev \
|
||||
make \
|
||||
mpg123-dev \
|
||||
openjpeg-dev \
|
||||
python3-dev && \
|
||||
echo "**** install runtime packages ****" && \
|
||||
apk add --no-cache --upgrade \
|
||||
curl \
|
||||
chromaprint \
|
||||
expat \
|
||||
ffmpeg \
|
||||
ffmpeg-libs \
|
||||
|
|
@ -34,26 +37,20 @@ RUN \
|
|||
gst-plugins-good \
|
||||
gstreamer \
|
||||
jpeg \
|
||||
jq \
|
||||
lame \
|
||||
libffi \
|
||||
libpng \
|
||||
mpg123 \
|
||||
nano \
|
||||
openjpeg \
|
||||
py3-gobject3 \
|
||||
py3-pip \
|
||||
py3-pylast \
|
||||
python3 \
|
||||
sqlite-libs \
|
||||
tar \
|
||||
wget && \
|
||||
sqlite-libs && \
|
||||
echo "**** compile mp3gain ****" && \
|
||||
mkdir -p \
|
||||
/tmp/mp3gain-src && \
|
||||
curl -o \
|
||||
/tmp/mp3gain-src/mp3gain.zip -sL \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.1/mp3gain-1_6_1-src.zip && \
|
||||
https://sourceforge.net/projects/mp3gain/files/mp3gain/1.6.2/mp3gain-1_6_2-src.zip && \
|
||||
cd /tmp/mp3gain-src && \
|
||||
unzip -qq /tmp/mp3gain-src/mp3gain.zip && \
|
||||
sed -i "s#/usr/local/bin#/usr/bin#g" /tmp/mp3gain-src/Makefile && \
|
||||
|
|
@ -69,39 +66,34 @@ RUN \
|
|||
tar xzf /tmp/mp3val-src/mp3val.tar.gz --strip 1 && \
|
||||
make -f Makefile.linux && \
|
||||
cp -p mp3val /usr/bin && \
|
||||
echo "**** compile chromaprint ****" && \
|
||||
git clone https://bitbucket.org/acoustid/chromaprint.git \
|
||||
/tmp/chromaprint && \
|
||||
cd /tmp/chromaprint && \
|
||||
cmake \
|
||||
-DBUILD_TOOLS=ON \
|
||||
-DCMAKE_BUILD_TYPE=Release \
|
||||
-DCMAKE_INSTALL_PREFIX:PATH=/usr && \
|
||||
make && \
|
||||
make install && \
|
||||
echo "**** install pip packages ****" && \
|
||||
if [ -z ${BEETS_VERSION+x} ]; then \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json \
|
||||
|jq -r '. | .info.version'); \
|
||||
BEETS_VERSION=$(curl -sL https://pypi.python.org/pypi/beets/json |jq -r '. | .info.version'); \
|
||||
fi && \
|
||||
python3 -m pip install --upgrade pip && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine/ \
|
||||
wheel \
|
||||
python3 -m ensurepip && \
|
||||
pip3 install -U --no-cache-dir \
|
||||
pip \
|
||||
wheel && \
|
||||
pip3 install -U --no-cache-dir --find-links https://wheel-index.linuxserver.io/alpine-3.17/ \
|
||||
beautifulsoup4 \
|
||||
beets==${BEETS_VERSION} \
|
||||
beets-extrafiles \
|
||||
beetcamp \
|
||||
discogs-client \
|
||||
flask \
|
||||
PyGObject \
|
||||
pillow \
|
||||
pyacoustid \
|
||||
pylast \
|
||||
requests \
|
||||
unidecode && \
|
||||
echo "**** cleanup ****" && \
|
||||
apk del --purge \
|
||||
build-dependencies && \
|
||||
rm -rf \
|
||||
/root/.cache \
|
||||
/tmp/*
|
||||
/tmp/* \
|
||||
$HOME/.cache \
|
||||
$HOME/.cargo
|
||||
|
||||
# environment settings
|
||||
ENV BEETSDIR="/config" \
|
||||
|
|
|
|||
|
|
@ -244,6 +244,7 @@ Once registered you can define the dockerfile to use with `-f Dockerfile.aarch64
|
|||
|
||||
## Versions
|
||||
|
||||
* **24.02.23:** - Rebase to Alpine 3.17, migrate to s6v3, install chromaprint from Alpine repos, add beetcamp plugin.
|
||||
* **15.01.22:** - Rebasing to alpine 3.15.
|
||||
* **19.12.19:** - Rebasing to alpine 3.11.
|
||||
* **28.06.19:** - Rebasing to alpine 3.10.
|
||||
|
|
|
|||
|
|
@ -52,6 +52,7 @@ app_setup_block: |
|
|||
|
||||
# changelog
|
||||
changelogs:
|
||||
- { date: "24.02.23:", desc: "Rebase to Alpine 3.17, migrate to s6v3, install chromaprint from Alpine repos, add beetcamp plugin." }
|
||||
- { date: "15.01.22:", desc: "Rebasing to alpine 3.15." }
|
||||
- { date: "19.12.19:", desc: "Rebasing to alpine 3.11." }
|
||||
- { date: "28.06.19:", desc: "Rebasing to alpine 3.10." }
|
||||
|
|
|
|||
|
|
@ -1,4 +1,5 @@
|
|||
#!/bin/bash
|
||||
#!/usr/bin/with-contenv bash
|
||||
# shellcheck shell=bash
|
||||
#
|
||||
# beets music tagger - post-processing script
|
||||
#
|
||||
|
|
@ -8,7 +9,7 @@
|
|||
# $1 - Fullpath of directory to be processed. eg./mnt/user/downloads/some.artist_some.album
|
||||
|
||||
# $7 - Status of post processing. 0 = OK, 1 = failed verification, 2 = failed unpack, 3 = 1+2
|
||||
if [ ! -z "$7" ] && [ "$7" -gt 0 ]; then
|
||||
if [ -n "$7" ] && [ "$7" -gt 0 ]; then
|
||||
echo "post-processing failed, bypassing script"
|
||||
exit 1
|
||||
fi
|
||||
|
|
@ -16,7 +17,7 @@ fi
|
|||
# process files
|
||||
echo "--------------------------"
|
||||
printf %b "$(date)\n"
|
||||
echo "Starting beets.sh for $(basename $1)"
|
||||
echo "Starting beets.sh for $(basename "$1")"
|
||||
|
||||
BEETSDIR=/config
|
||||
export BEETSDIR
|
||||
|
|
|
|||
|
|
@ -1,11 +0,0 @@
|
|||
#!/usr/bin/with-contenv bash
|
||||
|
||||
# copy config
|
||||
[[ ! -e /config/beets.sh ]] && \
|
||||
cp /defaults/beets.sh /config/beets.sh
|
||||
[[ ! -e /config/config.yaml ]] && \
|
||||
cp /defaults/config.yaml /config/config.yaml
|
||||
|
||||
# permissions
|
||||
chown -R abc:abc \
|
||||
/config
|
||||
10
root/etc/s6-overlay/s6-rc.d/init-beets-config/run
Executable file
10
root/etc/s6-overlay/s6-rc.d/init-beets-config/run
Executable file
|
|
@ -0,0 +1,10 @@
|
|||
#!/usr/bin/with-contenv bash
|
||||
# shellcheck shell=bash
|
||||
|
||||
# copy config
|
||||
cp -n /defaults/beets.sh /config/beets.sh
|
||||
cp -n /defaults/config.yaml /config/config.yaml
|
||||
|
||||
# permissions
|
||||
lsiown -R abc:abc \
|
||||
/config
|
||||
1
root/etc/s6-overlay/s6-rc.d/init-beets-config/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/init-beets-config/type
Normal file
|
|
@ -0,0 +1 @@
|
|||
oneshot
|
||||
1
root/etc/s6-overlay/s6-rc.d/init-beets-config/up
Normal file
1
root/etc/s6-overlay/s6-rc.d/init-beets-config/up
Normal file
|
|
@ -0,0 +1 @@
|
|||
/etc/s6-overlay/s6-rc.d/init-beets-config/run
|
||||
1
root/etc/s6-overlay/s6-rc.d/svc-beets/notification-fd
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-beets/notification-fd
Normal file
|
|
@ -0,0 +1 @@
|
|||
3
|
||||
6
root/etc/s6-overlay/s6-rc.d/svc-beets/run
Executable file
6
root/etc/s6-overlay/s6-rc.d/svc-beets/run
Executable file
|
|
@ -0,0 +1,6 @@
|
|||
#!/usr/bin/with-contenv bash
|
||||
# shellcheck shell=bash
|
||||
|
||||
exec \
|
||||
s6-notifyoncheck -d -n 300 -w 1000 -c "nc -z localhost 8337" \
|
||||
s6-setuidgid abc beet web
|
||||
1
root/etc/s6-overlay/s6-rc.d/svc-beets/type
Normal file
1
root/etc/s6-overlay/s6-rc.d/svc-beets/type
Normal file
|
|
@ -0,0 +1 @@
|
|||
longrun
|
||||
0
root/etc/s6-overlay/s6-rc.d/user/contents.d/svc-beets
Normal file
0
root/etc/s6-overlay/s6-rc.d/user/contents.d/svc-beets
Normal file
|
|
@ -1,5 +0,0 @@
|
|||
#!/usr/bin/with-contenv bash
|
||||
umask 022
|
||||
|
||||
exec \
|
||||
s6-setuidgid abc beet web
|
||||
Loading…
Reference in a new issue