X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b4f1461e394cc1fe0b7b5f9f56b96121cc46ff2e..6bee9f6a6be594a7bcda9ec4062d56e325b2efc6:/tools/arvbox/lib/arvbox/docker/common.sh diff --git a/tools/arvbox/lib/arvbox/docker/common.sh b/tools/arvbox/lib/arvbox/docker/common.sh index e81e8108e2..f391376f39 100644 --- a/tools/arvbox/lib/arvbox/docker/common.sh +++ b/tools/arvbox/lib/arvbox/docker/common.sh @@ -2,14 +2,16 @@ # # SPDX-License-Identifier: AGPL-3.0 +export RUBY_VERSION=2.7.0 +export BUNDLER_VERSION=2.2.19 -export PATH=${PATH}:/usr/local/go/bin:/var/lib/gems/bin -export GEM_HOME=/var/lib/gems -export GEM_PATH=/var/lib/gems +export DEBIAN_FRONTEND=noninteractive +export PATH=${PATH}:/usr/local/go/bin:/var/lib/arvados/bin:/usr/src/arvados/sdk/cli/binstubs export npm_config_cache=/var/lib/npm export npm_config_cache_min=Infinity export R_LIBS=/var/lib/Rlibs export HOME=$(getent passwd arvbox | cut -d: -f6) +export ARVADOS_CONTAINER_PATH=/var/lib/arvados-arvbox defaultdev=$(/sbin/ip route|awk '/default/ { print $5 }') dockerip=$(/sbin/ip route | grep default | awk '{ print $3 }') @@ -20,10 +22,10 @@ else localip=$containerip fi -root_cert=/var/lib/arvados/root-cert.pem -root_cert_key=/var/lib/arvados/root-cert.key -server_cert=/var/lib/arvados/server-cert-${localip}.pem -server_cert_key=/var/lib/arvados/server-cert-${localip}.key +root_cert=$ARVADOS_CONTAINER_PATH/root-cert.pem +root_cert_key=$ARVADOS_CONTAINER_PATH/root-cert.key +server_cert=$ARVADOS_CONTAINER_PATH/server-cert-${localip}.pem +server_cert_key=$ARVADOS_CONTAINER_PATH/server-cert-${localip}.key declare -A services services=( @@ -38,6 +40,7 @@ services=( [arv-git-httpd]=9001 [keep-web]=9003 [keep-web-ssl]=9002 + [keep-web-dl-ssl]=9004 [keepproxy]=25100 [keepproxy-ssl]=25101 [keepstore0]=25107 @@ -59,22 +62,20 @@ else fi run_bundler() { + GEMLOCK=/var/lib/arvados/lib/ruby/gems/gems.lock + flock $GEMLOCK /var/lib/arvados/bin/gem install --no-document bundler:$BUNDLER_VERSION if test -f Gemfile.lock ; then frozen=--frozen else frozen="" fi - # if ! test -x /var/lib/gems/bin/bundler ; then - # bundleversion=2.0.2 - # bundlergem=$(ls -r $GEM_HOME/cache/bundler-${bundleversion}.gem 2>/dev/null | head -n1 || true) - # if test -n "$bundlergem" ; then - # flock /var/lib/gems/gems.lock gem install --verbose --local --no-document $bundlergem - # else - # flock /var/lib/gems/gems.lock gem install --verbose --no-document bundler --version ${bundleversion} - # fi - # fi - if ! flock /var/lib/gems/gems.lock bundler install --verbose --path $GEM_HOME --local --no-deployment $frozen "$@" ; then - flock /var/lib/gems/gems.lock bundler install --verbose --path $GEM_HOME --no-deployment $frozen "$@" + BUNDLER=bundle + if test -x $PWD/bin/bundle ; then + # If present, use the one associated with rails workbench or API + BUNDLER=$PWD/bin/bundle + fi + if ! flock $GEMLOCK $BUNDLER install --verbose --local --no-deployment $frozen "$@" ; then + flock $GEMLOCK $BUNDLER install --verbose --no-deployment $frozen "$@" fi }