|
@@ -1,38 +1,29 @@
|
|
|
-#!/usr/bin/env sh
|
|
|
+#!/usr/bin/env bash
|
|
|
|
|
|
source ../common.build.sh
|
|
|
|
|
|
-VERSION=`get_version ../..`
|
|
|
+WORKDIR="$( pwd )"
|
|
|
+VERSION="$( grep '^Version:' ${WORKDIR}/pkg-src/jellyfin.spec | awk '{ print $NF }' )"
|
|
|
|
|
|
-# TODO get the version in the package automatically. And using the changelog to decide the debian package suffix version.
|
|
|
+package_temporary_dir="${WORKDIR}/pkg-dist-tmp"
|
|
|
+output_dir="${WORKDIR}/pkg-dist"
|
|
|
+pkg_src_dir="${WORKDIR}/pkg-src"
|
|
|
+current_user="$( whoami )"
|
|
|
+image_name="jellyfin-fedora-build"
|
|
|
|
|
|
-# Build a Jellyfin .rpm file with Docker on Linux
|
|
|
-# Places the output .rpm file in the parent directory
|
|
|
-
|
|
|
-set -o errexit
|
|
|
-set -o xtrace
|
|
|
-set -o nounset
|
|
|
-
|
|
|
-package_temporary_dir="`pwd`/pkg-dist-tmp"
|
|
|
-output_dir="`pwd`/pkg-dist"
|
|
|
-pkg_src_dir="`pwd`/pkg-src"
|
|
|
-current_user="`whoami`"
|
|
|
-image_name="jellyfin-rpmbuild"
|
|
|
-docker_sudo=""
|
|
|
-if ! $(id -Gn | grep -q 'docker') && [ ! ${EUID:-1000} -eq 0 ] && \
|
|
|
- [ ! $USER == "root" ] && ! $(echo "$OSTYPE" | grep -q "darwin"); then
|
|
|
- docker_sudo=sudo
|
|
|
+# Determine if sudo should be used for Docker
|
|
|
+if [[ ! -z $(id -Gn | grep -q 'docker') ]] \
|
|
|
+ && [[ ! ${EUID:-1000} -eq 0 ]] \
|
|
|
+ && [[ ! ${USER} == "root" ]] \
|
|
|
+ && [[ ! -z $( echo "${OSTYPE}" | grep -q "darwin" ) ]]; then
|
|
|
+ docker_sudo="sudo"
|
|
|
+else
|
|
|
+ docker_sudo=""
|
|
|
fi
|
|
|
|
|
|
-cleanup() {
|
|
|
- set +o errexit
|
|
|
- $docker_sudo docker image rm $image_name --force
|
|
|
- rm -rf "$package_temporary_dir"
|
|
|
- rm -rf "$pkg_src_dir/jellyfin-${VERSION}.tar.gz"
|
|
|
-}
|
|
|
-trap cleanup EXIT INT
|
|
|
+# Create RPM source archive
|
|
|
GNU_TAR=1
|
|
|
-mkdir -p "$package_temporary_dir"
|
|
|
+mkdir -p "${package_temporary_dir}"
|
|
|
echo "Bundling all sources for RPM build."
|
|
|
tar \
|
|
|
--transform "s,^\.,jellyfin-${VERSION}," \
|
|
@@ -47,12 +38,12 @@ tar \
|
|
|
--exclude='**/.nuget' \
|
|
|
--exclude='*.deb' \
|
|
|
--exclude='*.rpm' \
|
|
|
--zcf "$pkg_src_dir/jellyfin-${VERSION}.tar.gz" \
|
|
|
+-czf "${pkg_src_dir}/jellyfin-${VERSION}.tar.gz" \
|
|
|
-C "../.." ./ || GNU_TAR=0
|
|
|
|
|
|
if [ $GNU_TAR -eq 0 ]; then
|
|
|
echo "The installed tar binary did not support --transform. Using workaround."
|
|
|
- mkdir -p "$package_temporary_dir/jellyfin-${VERSION}"
|
|
|
+ mkdir -p "${package_temporary_dir}/jellyfin"
|
|
|
# Not GNU tar
|
|
|
tar \
|
|
|
--exclude='.git*' \
|
|
@@ -67,20 +58,23 @@ if [ $GNU_TAR -eq 0 ]; then
|
|
|
--exclude='*.deb' \
|
|
|
--exclude='*.rpm' \
|
|
|
-zcf \
|
|
|
- "$package_temporary_dir/jellyfin-${VERSION}/jellyfin.tar.gz" \
|
|
|
- -C "../.." \
|
|
|
- ./
|
|
|
+ "${package_temporary_dir}/jellyfin/jellyfin-${VERSION}.tar.gz" \
|
|
|
+ -C "../.." ./
|
|
|
echo "Extracting filtered package."
|
|
|
- tar -xzf "$package_temporary_dir/jellyfin-${VERSION}/jellyfin.tar.gz" -C "$package_temporary_dir/jellyfin-${VERSION}"
|
|
|
+ tar -xzf "${package_temporary_dir}/jellyfin/jellyfin-${VERSION}.tar.gz" -C "${package_temporary_dir}/jellyfin-${VERSION}"
|
|
|
echo "Removing filtered package."
|
|
|
- rm "$package_temporary_dir/jellyfin-${VERSION}/jellyfin.tar.gz"
|
|
|
+ rm -f "${package_temporary_dir}/jellyfin/jellyfin-${VERSION}.tar.gz"
|
|
|
echo "Repackaging package into final tarball."
|
|
|
- tar -zcf "$pkg_src_dir/jellyfin-${VERSION}.tar.gz" -C "$package_temporary_dir" "jellyfin-${VERSION}"
|
|
|
+ tar -czf "${pkg_src_dir}/jellyfin-${VERSION}.tar.gz" -C "${package_temporary_dir}" "jellyfin-${VERSION}"
|
|
|
fi
|
|
|
|
|
|
-$docker_sudo docker build ../.. -t "$image_name" -f ./Dockerfile
|
|
|
-mkdir -p "$output_dir"
|
|
|
-$docker_sudo docker run --rm -v "$package_temporary_dir:/temp" "$image_name" sh -c 'find /build/rpmbuild -maxdepth 3 -type f -name "jellyfin*.rpm" -exec mv {} /temp \;'
|
|
|
-chown -R "$current_user" "$package_temporary_dir" \
|
|
|
-|| sudo chown -R "$current_user" "$package_temporary_dir"
|
|
|
-mv "$package_temporary_dir"/*.rpm "$output_dir"
|
|
|
+# Set up the build environment Docker image
|
|
|
+${docker_sudo} docker build ../.. -t "${image_name}" -f ./Dockerfile
|
|
|
+# Build the RPMs and copy out to ${package_temporary_dir}
|
|
|
+${docker_sudo} docker run --rm -v "${package_temporary_dir}:/dist" "${image_name}"
|
|
|
+# Correct ownership on the RPMs (as current user, then as root if that fails)
|
|
|
+chown -R "${current_user}" "${package_temporary_dir}" \
|
|
|
+ || sudo chown -R "${current_user}" "${package_temporary_dir}"
|
|
|
+# Move the RPMs to the output directory
|
|
|
+mkdir -p "${output_dir}"
|
|
|
+mv "${package_temporary_dir}"/rpm/* "${output_dir}"
|