Immich: formatting changes
This commit is contained in:
parent
0ab98a769b
commit
7c4c4af751
@ -21,8 +21,8 @@ echo "deb http://deb.debian.org/debian testing main contrib" >/etc/apt/sources.l
|
|||||||
echo "Pin-Priority: -10"
|
echo "Pin-Priority: -10"
|
||||||
|
|
||||||
} >/etc/apt/preferences.d/immich
|
} >/etc/apt/preferences.d/immich
|
||||||
$STD apt-get update
|
"$STD" apt-get update
|
||||||
$STD apt-get install --no-install-recommends -y \
|
"$STD" apt-get install --no-install-recommends -y \
|
||||||
git \
|
git \
|
||||||
redis \
|
redis \
|
||||||
python3-venv \
|
python3-venv \
|
||||||
@ -68,7 +68,7 @@ $STD apt-get install --no-install-recommends -y \
|
|||||||
zlib1g \
|
zlib1g \
|
||||||
ocl-icd-libopencl1 \
|
ocl-icd-libopencl1 \
|
||||||
intel-media-va-driver
|
intel-media-va-driver
|
||||||
$STD apt-get install -y \
|
"$STD" apt-get install -y \
|
||||||
libgdk-pixbuf-2.0-dev librsvg2-dev libtool
|
libgdk-pixbuf-2.0-dev librsvg2-dev libtool
|
||||||
curl -fsSL https://repo.jellyfin.org/jellyfin_team.gpg.key | gpg --dearmor -o /etc/apt/keyrings/jellyfin.gpg
|
curl -fsSL https://repo.jellyfin.org/jellyfin_team.gpg.key | gpg --dearmor -o /etc/apt/keyrings/jellyfin.gpg
|
||||||
DPKG_ARCHITECTURE="$(dpkg --print-architecture)"
|
DPKG_ARCHITECTURE="$(dpkg --print-architecture)"
|
||||||
@ -81,49 +81,49 @@ Components: main
|
|||||||
Architectures: ${DPKG_ARCHITECTURE}
|
Architectures: ${DPKG_ARCHITECTURE}
|
||||||
Signed-By: /etc/apt/keyrings/jellyfin.gpg
|
Signed-By: /etc/apt/keyrings/jellyfin.gpg
|
||||||
EOF
|
EOF
|
||||||
$STD apt-get update
|
"$STD" apt-get update
|
||||||
$STD apt-get install -y jellyfin-ffmpeg7
|
"$STD" apt-get install -y jellyfin-ffmpeg7
|
||||||
ln -s /usr/lib/jellyfin-ffmpeg/ffmpeg /usr/bin/ffmpeg
|
ln -s /usr/lib/jellyfin-ffmpeg/ffmpeg /usr/bin/ffmpeg
|
||||||
ln -s /usr/lib/jellyfin-ffmpeg/ffprobe /usr/bin/ffprobe
|
ln -s /usr/lib/jellyfin-ffmpeg/ffprobe /usr/bin/ffprobe
|
||||||
tmp_dir=$(mktemp -d)
|
tmp_dir=$(mktemp -d)
|
||||||
cd $tmp_dir
|
cd "$tmp_dir" || exit
|
||||||
curl -fsSL https://github.com/intel/intel-graphics-compiler/releases/download/igc-1.0.17193.4/intel-igc-core_1.0.17193.4_amd64.deb -O
|
curl -fsSL https://github.com/intel/intel-graphics-compiler/releases/download/igc-1.0.17193.4/intel-igc-core_1.0.17193.4_amd64.deb -O
|
||||||
curl -fsSL https://github.com/intel/intel-graphics-compiler/releases/download/igc-1.0.17193.4/intel-igc-opencl_1.0.17193.4_amd64.deb -O
|
curl -fsSL https://github.com/intel/intel-graphics-compiler/releases/download/igc-1.0.17193.4/intel-igc-opencl_1.0.17193.4_amd64.deb -O
|
||||||
curl -fsSL https://github.com/intel/compute-runtime/releases/download/24.26.30049.6/intel-opencl-icd_24.26.30049.6_amd64.deb -O
|
curl -fsSL https://github.com/intel/compute-runtime/releases/download/24.26.30049.6/intel-opencl-icd_24.26.30049.6_amd64.deb -O
|
||||||
curl -fsSL https://github.com/intel/compute-runtime/releases/download/24.26.30049.6/libigdgmm12_22.3.20_amd64.deb -O
|
curl -fsSL https://github.com/intel/compute-runtime/releases/download/24.26.30049.6/libigdgmm12_22.3.20_amd64.deb -O
|
||||||
$STD dpkg -i ./*.deb
|
"$STD" dpkg -i ./*.deb
|
||||||
msg_ok "Base Dependencies Installed"
|
msg_ok "Base Dependencies Installed"
|
||||||
|
|
||||||
msg_info "Setting up Postgresql Database"
|
msg_info "Setting up Postgresql Database"
|
||||||
$STD apt-get install -y postgresql-common
|
"$STD" apt-get install -y postgresql-common
|
||||||
echo "YES" | /usr/share/postgresql-common/pgdg/apt.postgresql.org.sh &>/dev/null
|
echo "YES" | /usr/share/postgresql-common/pgdg/apt.postgresql.org.sh &>/dev/null
|
||||||
$STD apt-get install -y postgresql-17 postgresql-17-pgvector
|
"$STD" apt-get install -y postgresql-17 postgresql-17-pgvector
|
||||||
DB_NAME="immich"
|
DB_NAME="immich"
|
||||||
DB_USER="immich"
|
DB_USER="immich"
|
||||||
DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c18)
|
DB_PASS=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c18)
|
||||||
$STD sudo -u postgres psql -c "CREATE USER $DB_USER WITH ENCRYPTED PASSWORD '$DB_PASS';"
|
"$STD" sudo -u postgres psql -c "CREATE USER $DB_USER WITH ENCRYPTED PASSWORD '$DB_PASS';"
|
||||||
$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8' TEMPLATE template0;"
|
"$STD" sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8' TEMPLATE template0;"
|
||||||
$STD sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME to $DB_USER;"
|
"$STD" sudo -u postgres psql -c "GRANT ALL PRIVILEGES ON DATABASE $DB_NAME to $DB_USER;"
|
||||||
$STD sudo -u postgres psql -c "ALTER USER $DB_USER WITH SUPERUSER;"
|
"$STD" sudo -u postgres psql -c "ALTER USER $DB_USER WITH SUPERUSER;"
|
||||||
{
|
{
|
||||||
echo "${APPLICATION} DB Credentials"
|
echo "${APPLICATION} DB Credentials"
|
||||||
echo "Database User: $DB_USER"
|
echo "Database User: $DB_USER"
|
||||||
echo "Database Password: $DB_PASS"
|
echo "Database Password: $DB_PASS"
|
||||||
echo "Database Name: $DB_NAME"
|
echo "Database Name: $DB_NAME"
|
||||||
} >>~/${APPLICATION}.creds
|
} >>~/"$APPLICATION".creds
|
||||||
msg_ok "Set up Postgresql Database"
|
msg_ok "Set up Postgresql Database"
|
||||||
|
|
||||||
msg_info "Installing NodeJS"
|
msg_info "Installing NodeJS"
|
||||||
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
|
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg
|
||||||
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_22.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
|
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_22.x nodistro main" >/etc/apt/sources.list.d/nodesource.list
|
||||||
$STD apt-get update
|
"$STD" apt-get update
|
||||||
$STD apt-get install -y nodejs
|
"$STD" apt-get install -y nodejs
|
||||||
msg_ok "Installed NodeJS"
|
msg_ok "Installed NodeJS"
|
||||||
|
|
||||||
msg_info "Installing Packages from Testing Repo"
|
msg_info "Installing Packages from Testing Repo"
|
||||||
export APT_LISTCHANGES_FRONTEND=none
|
export APT_LISTCHANGES_FRONTEND=none
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
export DEBIAN_FRONTEND=noninteractive
|
||||||
$STD apt-get install -t testing --no-install-recommends -y \
|
"$STD" apt-get install -t testing --no-install-recommends -y \
|
||||||
libio-compress-brotli-perl \
|
libio-compress-brotli-perl \
|
||||||
libwebp7 \
|
libwebp7 \
|
||||||
libwebpdemux2 \
|
libwebpdemux2 \
|
||||||
@ -135,31 +135,31 @@ $STD apt-get install -t testing --no-install-recommends -y \
|
|||||||
msg_ok "Packages from Testing Repo Installed"
|
msg_ok "Packages from Testing Repo Installed"
|
||||||
|
|
||||||
# Fix default DB collation issue
|
# Fix default DB collation issue
|
||||||
$STD sudo -u postgres psql -c "ALTER DATABASE postgres REFRESH COLLATION VERSION;"
|
"$STD" sudo -u postgres psql -c "ALTER DATABASE postgres REFRESH COLLATION VERSION;"
|
||||||
$STD sudo -u postgres psql -c "ALTER DATABASE $DB_NAME REFRESH COLLATION VERSION;"
|
"$STD" sudo -u postgres psql -c "ALTER DATABASE $DB_NAME REFRESH COLLATION VERSION;"
|
||||||
|
|
||||||
msg_info "Compiling Custom Photo-processing Library (extreme patience)"
|
msg_info "Compiling Custom Photo-processing Library (extreme patience)"
|
||||||
STAGING_DIR=/opt/staging
|
STAGING_DIR=/opt/staging
|
||||||
BASE_REPO="https://github.com/immich-app/base-images"
|
BASE_REPO="https://github.com/immich-app/base-images"
|
||||||
BASE_DIR=${STAGING_DIR}/base-images
|
BASE_DIR=${STAGING_DIR}/base-images
|
||||||
SOURCE_DIR=${STAGING_DIR}/image-source
|
SOURCE_DIR=${STAGING_DIR}/image-source
|
||||||
$STD git clone -b main ${BASE_REPO} ${BASE_DIR} # TODO: convert this git clone into a TAG download
|
"$STD" git clone -b main "$BASE_REPO" "$BASE_DIR" # TODO: convert this git clone into a TAG download
|
||||||
mkdir -p ${SOURCE_DIR}
|
mkdir -p "$SOURCE_DIR"
|
||||||
|
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
SOURCE=${SOURCE_DIR}/libjxl
|
SOURCE=${SOURCE_DIR}/libjxl
|
||||||
JPEGLI_LIBJPEG_LIBRARY_SOVERSION="62"
|
JPEGLI_LIBJPEG_LIBRARY_SOVERSION="62"
|
||||||
JPEGLI_LIBJPEG_LIBRARY_VERSION="62.3.0"
|
JPEGLI_LIBJPEG_LIBRARY_VERSION="62.3.0"
|
||||||
: "${LIBJXL_REVISION:=$(jq -cr '.sources[] | select(.name == "libjxl").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
: "${LIBJXL_REVISION:=$(jq -cr '.sources[] | select(.name == "libjxl").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
||||||
$STD git clone https://github.com/libjxl/libjxl.git ${SOURCE}
|
"$STD" git clone https://github.com/libjxl/libjxl.git "$SOURCE"
|
||||||
cd ${SOURCE}
|
cd "$SOURCE" || exit
|
||||||
$STD git reset --hard "${LIBJXL_REVISION}"
|
"$STD" git reset --hard "$LIBJXL_REVISION"
|
||||||
$STD git submodule update --init --recursive --depth 1 --recommend-shallow
|
"$STD" git submodule update --init --recursive --depth 1 --recommend-shallow
|
||||||
$STD git apply ${BASE_DIR}/server/bin/patches/jpegli-empty-dht-marker.patch
|
"$STD" git apply "$BASE_DIR"/server/bin/patches/jpegli-empty-dht-marker.patch
|
||||||
$STD git apply ${BASE_DIR}/server/bin/patches/jpegli-icc-warning.patch
|
"$STD" git apply "$BASE_DIR"/server/bin/patches/jpegli-icc-warning.patch
|
||||||
mkdir build
|
mkdir build
|
||||||
cd build
|
cd build || exit
|
||||||
$STD cmake \
|
"$STD" cmake \
|
||||||
-DCMAKE_BUILD_TYPE=Release \
|
-DCMAKE_BUILD_TYPE=Release \
|
||||||
-DBUILD_TESTING=OFF \
|
-DBUILD_TESTING=OFF \
|
||||||
-DJPEGXL_ENABLE_DOXYGEN=OFF \
|
-DJPEGXL_ENABLE_DOXYGEN=OFF \
|
||||||
@ -173,25 +173,25 @@ $STD cmake \
|
|||||||
-DJPEGXL_ENABLE_JPEGLI_LIBJPEG=ON \
|
-DJPEGXL_ENABLE_JPEGLI_LIBJPEG=ON \
|
||||||
-DJPEGXL_INSTALL_JPEGLI_LIBJPEG=ON \
|
-DJPEGXL_INSTALL_JPEGLI_LIBJPEG=ON \
|
||||||
-DJPEGXL_ENABLE_PLUGINS=ON \
|
-DJPEGXL_ENABLE_PLUGINS=ON \
|
||||||
-DJPEGLI_LIBJPEG_LIBRARY_SOVERSION="${JPEGLI_LIBJPEG_LIBRARY_SOVERSION}" \
|
-DJPEGLI_LIBJPEG_LIBRARY_SOVERSION="$JPEGLI_LIBJPEG_LIBRARY_SOVERSION" \
|
||||||
-DJPEGLI_LIBJPEG_LIBRARY_VERSION="${JPEGLI_LIBJPEG_LIBRARY_VERSION}" \
|
-DJPEGLI_LIBJPEG_LIBRARY_VERSION="$JPEGLI_LIBJPEG_LIBRARY_VERSION" \
|
||||||
-DLIBJPEG_TURBO_VERSION_NUMBER=2001005 \
|
-DLIBJPEG_TURBO_VERSION_NUMBER=2001005 \
|
||||||
..
|
..
|
||||||
$STD cmake --build . -- -j"$(nproc)"
|
"$STD" cmake --build . -- -j"$(nproc)"
|
||||||
$STD cmake --install .
|
"$STD" cmake --install .
|
||||||
$STD ldconfig /usr/local/lib
|
"$STD" ldconfig /usr/local/lib
|
||||||
$STD make clean
|
"$STD" make clean
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
rm -rf ${SOURCE}/{build,third_party}
|
rm -rf "$SOURCE"/{build,third_party}
|
||||||
|
|
||||||
SOURCE=${SOURCE_DIR}/libheif
|
SOURCE=${SOURCE_DIR}/libheif
|
||||||
: "${LIBHEIF_REVISION:=$(jq -cr '.sources[] | select(.name == "libheif").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
: "${LIBHEIF_REVISION:=$(jq -cr '.sources[] | select(.name == "libheif").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
||||||
$STD git clone https://github.com/strukturag/libheif.git ${SOURCE}
|
"$STD" git clone https://github.com/strukturag/libheif.git "$SOURCE"
|
||||||
cd ${SOURCE}
|
cd "$SOURCE" || exit
|
||||||
$STD git reset --hard "${LIBHEIF_REVISION}"
|
"$STD" git reset --hard "$LIBHEIF_REVISION"
|
||||||
mkdir build
|
mkdir build
|
||||||
cd build
|
cd build || exit
|
||||||
$STD cmake --preset=release-noplugins \
|
"$STD" cmake --preset=release-noplugins \
|
||||||
-DWITH_DAV1D=ON \
|
-DWITH_DAV1D=ON \
|
||||||
-DENABLE_PARALLEL_TILE_DECODING=ON \
|
-DENABLE_PARALLEL_TILE_DECODING=ON \
|
||||||
-DWITH_LIBSHARPYUV=ON \
|
-DWITH_LIBSHARPYUV=ON \
|
||||||
@ -201,108 +201,108 @@ $STD cmake --preset=release-noplugins \
|
|||||||
-DWITH_X265=OFF \
|
-DWITH_X265=OFF \
|
||||||
-DWITH_EXAMPLES=OFF \
|
-DWITH_EXAMPLES=OFF \
|
||||||
..
|
..
|
||||||
$STD make install
|
"$STD" make install
|
||||||
ldconfig /usr/local/lib
|
ldconfig /usr/local/lib
|
||||||
$STD make clean
|
"$STD" make clean
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
rm -rf ${SOURCE}/build
|
rm -rf "$SOURCE"/build
|
||||||
|
|
||||||
SOURCE=${SOURCE_DIR}/libraw
|
SOURCE=${SOURCE_DIR}/libraw
|
||||||
: "${LIBRAW_REVISION:=$(jq -cr '.sources[] | select(.name == "libraw").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
: "${LIBRAW_REVISION:=$(jq -cr '.sources[] | select(.name == "libraw").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
||||||
$STD git clone https://github.com/libraw/libraw.git ${SOURCE}
|
"$STD" git clone https://github.com/libraw/libraw.git "$SOURCE"
|
||||||
cd ${SOURCE}
|
cd "$SOURCE" || exit
|
||||||
$STD git reset --hard "${LIBRAW_REVISION}"
|
"$STD" git reset --hard "$LIBRAW_REVISION"
|
||||||
$STD autoreconf --install
|
"$STD" autoreconf --install
|
||||||
$STD ./configure
|
"$STD" ./configure
|
||||||
$STD make -j"$(nproc)"
|
"$STD" make -j"$(nproc)"
|
||||||
$STD make install
|
"$STD" make install
|
||||||
ldconfig /usr/local/lib
|
ldconfig /usr/local/lib
|
||||||
$STD make clean
|
"$STD" make clean
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
|
|
||||||
SOURCE=$SOURCE_DIR/imagemagick
|
SOURCE=$SOURCE_DIR/imagemagick
|
||||||
: "${IMAGEMAGICK_REVISION:=$(jq -cr '.sources[] | select(.name == "imagemagick").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
: "${IMAGEMAGICK_REVISION:=$(jq -cr '.sources[] | select(.name == "imagemagick").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
||||||
$STD git clone https://github.com/ImageMagick/ImageMagick.git $SOURCE
|
"$STD" git clone https://github.com/ImageMagick/ImageMagick.git "$SOURCE"
|
||||||
cd $SOURCE
|
cd "$SOURCE" || exit
|
||||||
$STD git reset --hard "${IMAGEMAGICK_REVISION}"
|
"$STD" git reset --hard "$IMAGEMAGICK_REVISION"
|
||||||
$STD ./configure --with-modules
|
"$STD" ./configure --with-modules
|
||||||
$STD make -j"$(nproc)"
|
"$STD" make -j"$(nproc)"
|
||||||
$STD make install
|
"$STD" make install
|
||||||
ldconfig /usr/local/lib
|
ldconfig /usr/local/lib
|
||||||
$STD make clean
|
"$STD" make clean
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
|
|
||||||
SOURCE=$SOURCE_DIR/libvips
|
SOURCE=$SOURCE_DIR/libvips
|
||||||
: "${LIBVIPS_REVISION:=$(jq -cr '.sources[] | select(.name == "libvips").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
: "${LIBVIPS_REVISION:=$(jq -cr '.sources[] | select(.name == "libvips").revision' $BASE_DIR/server/bin/build-lock.json)}"
|
||||||
$STD git clone https://github.com/libvips/libvips.git ${SOURCE}
|
"$STD" git clone https://github.com/libvips/libvips.git "$SOURCE"
|
||||||
cd ${SOURCE}
|
cd "$SOURCE" || exit
|
||||||
$STD git reset --hard "${LIBVIPS_REVISION}"
|
"$STD" git reset --hard "$LIBVIPS_REVISION"
|
||||||
$STD meson setup build --buildtype=release --libdir=lib -Dintrospection=disabled -Dtiff=disabled
|
"$STD" meson setup build --buildtype=release --libdir=lib -Dintrospection=disabled -Dtiff=disabled
|
||||||
cd build
|
cd build || exit
|
||||||
$STD ninja install
|
"$STD" ninja install
|
||||||
$STD ldconfig /usr/local/lib
|
"$STD" ldconfig /usr/local/lib
|
||||||
cd ${STAGING_DIR}
|
cd "$STAGING_DIR" || exit
|
||||||
rm -rf ${SOURCE}/build
|
rm -rf "$SOURCE"/build
|
||||||
msg_ok "Custom Photo-processing Library Compiled"
|
msg_ok "Custom Photo-processing Library Compiled"
|
||||||
|
|
||||||
msg_info "Installing ${APPLICATION} (more patience please)"
|
msg_info "Installing ${APPLICATION} (more patience please)"
|
||||||
tmp_file=$(mktemp)
|
tmp_file=$(mktemp)
|
||||||
RELEASE=$(curl -s https://api.github.com/repos/immich-app/immich/releases?per_page=1 | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
|
RELEASE=$(curl -s https://api.github.com/repos/immich-app/immich/releases?per_page=1 | grep "tag_name" | awk '{print substr($2, 3, length($2)-4) }')
|
||||||
curl -fsSL "https://github.com/immich-app/immich/archive/refs/tags/v${RELEASE}.zip" -o $tmp_file
|
curl -fsSL "https://github.com/immich-app/immich/archive/refs/tags/v${RELEASE}.zip" -o "$tmp_file"
|
||||||
unzip -q $tmp_file
|
unzip -q "$tmp_file"
|
||||||
INSTALL_DIR="/opt/${APPLICATION}"
|
INSTALL_DIR="/opt/${APPLICATION}"
|
||||||
UPLOAD_DIR="${INSTALL_DIR}/upload"
|
UPLOAD_DIR="${INSTALL_DIR}/upload"
|
||||||
SRC_DIR="${INSTALL_DIR}/source"
|
SRC_DIR="${INSTALL_DIR}/source"
|
||||||
APP_DIR="${INSTALL_DIR}/app"
|
APP_DIR="${INSTALL_DIR}/app"
|
||||||
ML_DIR="${APP_DIR}/machine-learning"
|
ML_DIR="${APP_DIR}/machine-learning"
|
||||||
GEO_DIR="${INSTALL_DIR}/geodata"
|
GEO_DIR="${INSTALL_DIR}/geodata"
|
||||||
mkdir -p ${INSTALL_DIR}
|
mkdir -p "$INSTALL_DIR"
|
||||||
mv ${APPLICATION}-${RELEASE}/ ${SRC_DIR}
|
mv "$APPLICATION-$RELEASE"/ "$SRC_DIR"
|
||||||
mkdir -p {${APP_DIR},${UPLOAD_DIR},${GEO_DIR},${ML_DIR},${INSTALL_DIR}/.cache}
|
mkdir -p "{$APP_DIR,$UPLOAD_DIR,$GEO_DIR,$ML_DIR,$INSTALL_DIR/.cache}"
|
||||||
|
|
||||||
cd ${SRC_DIR}/server
|
cd "$SRC_DIR"/server || exit
|
||||||
$STD npm ci
|
"$STD" npm ci
|
||||||
$STD npm run build
|
"$STD" npm run build
|
||||||
$STD npm prune --omit=dev --omit=optional
|
"$STD" npm prune --omit=dev --omit=optional
|
||||||
cd ${SRC_DIR}/open-api/typescript-sdk
|
cd "$SRC_DIR"/open-api/typescript-sdk || exit
|
||||||
$STD npm ci
|
"$STD" npm ci
|
||||||
$STD npm run build
|
"$STD" npm run build
|
||||||
cd ${SRC_DIR}/web
|
cd "$SRC_DIR"/web || exit
|
||||||
$STD npm ci
|
"$STD" npm ci
|
||||||
$STD npm run build
|
"$STD" npm run build
|
||||||
cd ${SRC_DIR}
|
cd "$SRC_DIR" || exit
|
||||||
cp -a server/{node_modules,dist,bin,resources,package.json,package-lock.json,start*.sh} ${APP_DIR}/
|
cp -a server/{node_modules,dist,bin,resources,package.json,package-lock.json,start*.sh} "$APP_DIR"/
|
||||||
cp -a web/build ${APP_DIR}/www
|
cp -a web/build "$APP_DIR"/www
|
||||||
cp LICENSE ${APP_DIR}
|
cp LICENSE "$APP_DIR"
|
||||||
cp ${BASE_DIR}/server/bin/build-lock.json ${APP_DIR}
|
cp "$BASE_DIR"/server/bin/build-lock.json "$APP_DIR"
|
||||||
|
|
||||||
cd ${SRC_DIR}/machine-learning
|
cd "$SRC_DIR"/machine-learning || exit
|
||||||
$STD python3 -m venv ${ML_DIR}/ml-venv
|
"$STD" python3 -m venv "$ML_DIR"/ml-venv
|
||||||
(
|
(
|
||||||
. ${ML_DIR}/ml-venv/bin/activate
|
. "$ML_DIR"/ml-venv/bin/activate
|
||||||
$STD pip3 install uv
|
"$STD" pip3 install uv
|
||||||
$STD uv sync --extra cpu --active
|
"$STD" uv sync --extra cpu --active
|
||||||
)
|
)
|
||||||
cd ${SRC_DIR}
|
cd "$SRC_DIR" || exit
|
||||||
cp -a machine-learning/{ann,immich_ml} ${ML_DIR}
|
cp -a machine-learning/{ann,immich_ml} "$ML_DIR"
|
||||||
ln -sf ${APP_DIR}/resources ${INSTALL_DIR}
|
ln -sf "$APP_DIR"/resources "$INSTALL_DIR"
|
||||||
|
|
||||||
cd ${APP_DIR}
|
cd "$APP_DIR" || exit
|
||||||
grep -RlI /usr/src . --exclude="*.py*" --exclude="*.json" |
|
grep -RlI /usr/src . --exclude="*.py*" --exclude="*.json" |
|
||||||
xargs -n1 sed -i "s|\/usr/src|$INSTALL_DIR|g"
|
xargs -n1 sed -i "s|\/usr/src|$INSTALL_DIR|g"
|
||||||
# sed -i "s|\"/cache\"|\"$INSTALL_DIR/cache\"|g" $ML_DIR/immich_ml/config.py
|
# sed -i "s|\"/cache\"|\"$INSTALL_DIR/cache\"|g" $ML_DIR/immich_ml/config.py
|
||||||
grep -RlE "'/build'" | xargs -n1 sed -i "s|'/build'|'$APP_DIR'|g"
|
grep -RlE "'/build'" | xargs -n1 sed -i "s|'/build'|'$APP_DIR'|g"
|
||||||
ln -s ${UPLOAD_DIR} ${APP_DIR}/upload
|
ln -s "$UPLOAD_DIR" "$APP_DIR"/upload
|
||||||
ln -s ${UPLOAD_DIR} ${ML_DIR}/upload
|
ln -s "$UPLOAD_DIR" "$ML_DIR"/upload
|
||||||
|
|
||||||
msg_info "Installing Immich CLI"
|
msg_info "Installing Immich CLI"
|
||||||
$STD npm install --build-from-source sharp
|
"$STD" npm install --build-from-source sharp
|
||||||
rm -rf ${APP_DIR}/node_modules/@img/sharp-{libvips*,linuxmusl-x64}
|
rm -rf "$APP_DIR"/node_modules/@img/sharp-{libvips*,linuxmusl-x64}
|
||||||
$STD npm i -g @immich/cli
|
"$STD" npm i -g @immich/cli
|
||||||
msg_ok "Installed Immich CLI"
|
msg_ok "Installed Immich CLI"
|
||||||
|
|
||||||
msg_info "Installing GeoNames data"
|
msg_info "Installing GeoNames data"
|
||||||
cd ${GEO_DIR}
|
cd "$GEO_DIR" || exit
|
||||||
URL_LIST=(
|
URL_LIST=(
|
||||||
https://download.geonames.org/export/dump/admin1CodesASCII.txt
|
https://download.geonames.org/export/dump/admin1CodesASCII.txt
|
||||||
https://download.geonames.org/export/dump/admin2Codes.txt
|
https://download.geonames.org/export/dump/admin2Codes.txt
|
||||||
@ -312,17 +312,17 @@ URL_LIST=(
|
|||||||
echo "${URL_LIST[@]}" | xargs -n1 -P 8 wget -q
|
echo "${URL_LIST[@]}" | xargs -n1 -P 8 wget -q
|
||||||
unzip -q cities500.zip
|
unzip -q cities500.zip
|
||||||
date --iso-8601=seconds | tr -d "\n" >geodata-date.txt
|
date --iso-8601=seconds | tr -d "\n" >geodata-date.txt
|
||||||
cd ${INSTALL_DIR}
|
cd "$INSTALL_DIR" || exit
|
||||||
ln -s ${GEO_DIR} ${APP_DIR}
|
ln -s "$GEO_DIR" "$APP_DIR"
|
||||||
msg_ok "Installed GeoNames data"
|
msg_ok "Installed GeoNames data"
|
||||||
|
|
||||||
mkdir -p /var/log/immich
|
mkdir -p /var/log/immich
|
||||||
touch /var/log/immich/{web.log,ml.log}
|
touch /var/log/immich/{web.log,ml.log}
|
||||||
echo "${RELEASE}" >/opt/${APPLICATION}_version.txt
|
echo "$RELEASE" >/opt/"${APPLICATION}"_version.txt
|
||||||
msg_ok "Installed ${APPLICATION}"
|
msg_ok "Installed ${APPLICATION}"
|
||||||
|
|
||||||
msg_info "Creating env file, scripts & services"
|
msg_info "Creating env file, scripts & services"
|
||||||
cat <<EOF >${INSTALL_DIR}/.env
|
cat <<EOF >"${INSTALL_DIR}"/.env
|
||||||
TZ=$(cat /etc/timezone)
|
TZ=$(cat /etc/timezone)
|
||||||
IMMICH_VERSION=release
|
IMMICH_VERSION=release
|
||||||
IMMICH_ENV=production
|
IMMICH_ENV=production
|
||||||
@ -337,7 +337,7 @@ REDIS_HOSTNAME=localhost
|
|||||||
|
|
||||||
MACHINE_LEARNING_CACHE_FOLDER=${INSTALL_DIR}/.cache
|
MACHINE_LEARNING_CACHE_FOLDER=${INSTALL_DIR}/.cache
|
||||||
EOF
|
EOF
|
||||||
cat <<EOF >${ML_DIR}/ml_start.sh
|
cat <<EOF >"${ML_DIR}"/ml_start.sh
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
cd ${ML_DIR}
|
cd ${ML_DIR}
|
||||||
@ -345,8 +345,8 @@ cd ${ML_DIR}
|
|||||||
|
|
||||||
python -m immich_ml
|
python -m immich_ml
|
||||||
EOF
|
EOF
|
||||||
chmod +x ${ML_DIR}/ml_start.sh
|
chmod +x "$ML_DIR"/ml_start.sh
|
||||||
cat <<EOF >/etc/systemd/system/${APPLICATION}-web.service
|
cat <<EOF >/etc/systemd/system/"${APPLICATION}"-web.service
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=${APPLICATION} Web Service
|
Description=${APPLICATION} Web Service
|
||||||
After=network.target
|
After=network.target
|
||||||
@ -368,7 +368,7 @@ StandardError=append:/var/log/immich/web.log
|
|||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
cat <<EOF >/etc/systemd/system/${APPLICATION}-ml.service
|
cat <<EOF >/etc/systemd/system/"${APPLICATION}"-ml.service
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=${APPLICATION} Machine-Learning
|
Description=${APPLICATION} Machine-Learning
|
||||||
After=network.target
|
After=network.target
|
||||||
@ -387,7 +387,7 @@ StandardError=append:/var/log/immich/ml.log
|
|||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
systemctl enable -q --now ${APPLICATION}-ml.service ${APPLICATION}-web.service
|
systemctl enable -q --now "$APPLICATION"-ml.service "$APPLICATION"-web.service
|
||||||
msg_ok "Created env file, scripts and services"
|
msg_ok "Created env file, scripts and services"
|
||||||
|
|
||||||
sed -i "$ a VERSION_ID=12" /etc/os-release # otherwise the motd_ssh function will fail
|
sed -i "$ a VERSION_ID=12" /etc/os-release # otherwise the motd_ssh function will fail
|
||||||
@ -395,8 +395,8 @@ motd_ssh
|
|||||||
customize
|
customize
|
||||||
|
|
||||||
msg_info "Cleaning up"
|
msg_info "Cleaning up"
|
||||||
rm -f $tmp_file
|
rm -f "$tmp_file"
|
||||||
rm -rf $tmp_dir
|
rm -rf "$tmp_dir"
|
||||||
$STD apt-get -y autoremove
|
"$STD" apt-get -y autoremove
|
||||||
$STD apt-get -y autoclean
|
"$STD" apt-get -y autoclean
|
||||||
msg_ok "Cleaned"
|
msg_ok "Cleaned"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user