Browse Source

Add web build to Ubuntu amd64 package build

Joshua Boniface 5 years ago
parent
commit
03d60438e2

+ 6 - 0
deployment/ubuntu-package-x64/Dockerfile

@@ -14,6 +14,12 @@ RUN apt-get update \
  && ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh \
  && ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh \
  && mkdir -p ${SOURCE_DIR} && ln -sf ${PLATFORM_DIR}/pkg-src ${SOURCE_DIR}/debian
  && mkdir -p ${SOURCE_DIR} && ln -sf ${PLATFORM_DIR}/pkg-src ${SOURCE_DIR}/debian
 
 
+# Install yarn package manager
+RUN wget -q -O- https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \
+ && echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \
+ && apt update \
+ && apt install -y yarn
+
 VOLUME ${ARTIFACT_DIR}/
 VOLUME ${ARTIFACT_DIR}/
 
 
 COPY . ${SOURCE_DIR}/
 COPY . ${SOURCE_DIR}/

+ 14 - 0
deployment/ubuntu-package-x64/docker-build.sh

@@ -11,6 +11,20 @@ pushd ${SOURCE_DIR}
 # Remove build-dep for dotnet-sdk-2.2, since it's not a package in this image
 # Remove build-dep for dotnet-sdk-2.2, since it's not a package in this image
 sed -i '/dotnet-sdk-2.2,/d' debian/control
 sed -i '/dotnet-sdk-2.2,/d' debian/control
 
 
+# Clone down and build Web frontend
+web_build_dir="$( mktemp -d )"
+web_target="${SOURCE_DIR}/MediaBrowser.WebDashboard/jellyfin-web"
+git clone https://github.com/jellyfin/jellyfin-web.git ${web_build_dir}/
+pushd ${web_build_dir}
+if [[ -n ${web_branch} ]]; then
+    checkout -b origin/${web_branch}
+fi
+yarn install
+yarn build
+mkdir -p ${web_target}
+mv dist/* ${web_target}/
+popd
+
 # Build DEB
 # Build DEB
 dpkg-buildpackage -us -uc
 dpkg-buildpackage -us -uc
 
 

+ 7 - 1
deployment/ubuntu-package-x64/package.sh

@@ -2,6 +2,12 @@
 
 
 source ../common.build.sh
 source ../common.build.sh
 
 
+args="${@}"
+declare -a docker_envvars
+for arg in ${args}; do
+    docker_envvars+=("-e ${arg}")
+done
+
 WORKDIR="$( pwd )"
 WORKDIR="$( pwd )"
 
 
 package_temporary_dir="${WORKDIR}/pkg-dist-tmp"
 package_temporary_dir="${WORKDIR}/pkg-dist-tmp"
@@ -24,7 +30,7 @@ mkdir -p "${package_temporary_dir}"
 # Set up the build environment Docker image
 # Set up the build environment Docker image
 ${docker_sudo} docker build ../.. -t "${image_name}" -f ./Dockerfile
 ${docker_sudo} docker build ../.. -t "${image_name}" -f ./Dockerfile
 # Build the DEBs and copy out to ${package_temporary_dir}
 # Build the DEBs and copy out to ${package_temporary_dir}
-${docker_sudo} docker run --rm -v "${package_temporary_dir}:/dist" "${image_name}"
+${docker_sudo} docker run --rm -v "${package_temporary_dir}:/dist" "${image_name}" ${docker_envvars}
 # Move the DEBs to the output directory
 # Move the DEBs to the output directory
 mkdir -p "${output_dir}"
 mkdir -p "${output_dir}"
 mv "${package_temporary_dir}"/deb/* "${output_dir}"
 mv "${package_temporary_dir}"/deb/* "${output_dir}"