X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2f66d4cc05e9442a9bb69969744d0750a02a1ed4..09cbdc3074b3f1e69c9c537875146f6da0a6ed8f:/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 9c933e870f..ba81426f0b 100644 --- a/tools/arvbox/lib/arvbox/docker/common.sh +++ b/tools/arvbox/lib/arvbox/docker/common.sh @@ -2,14 +2,18 @@ # # 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 +export GEM_HOME=$HOME/.gem +GEMLOCK=$HOME/gems.lock defaultdev=$(/sbin/ip route|awk '/default/ { print $5 }') dockerip=$(/sbin/ip route | grep default | awk '{ print $3 }') @@ -20,10 +24,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=( @@ -33,12 +37,11 @@ services=( [api]=8004 [controller]=8003 [controller-ssl]=8000 - [sso]=8900 - [composer]=4200 [arv-git-httpd-ssl]=9000 [arv-git-httpd]=9001 [keep-web]=9003 [keep-web-ssl]=9002 + [keep-web-dl-ssl]=9004 [keepproxy]=25100 [keepproxy-ssl]=25101 [keepstore0]=25107 @@ -47,6 +50,8 @@ services=( [doc]=8001 [websockets]=8005 [websockets-ssl]=8002 + [webshell]=4201 + [webshell-ssl]=4202 ) if test "$(id arvbox -u 2>/dev/null)" = 0 ; then @@ -58,22 +63,24 @@ else fi run_bundler() { + flock $GEMLOCK /var/lib/arvados/bin/gem install --no-document --user 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 test -z "$(flock $GEMLOCK /var/lib/arvados/bin/gem list | grep 'arvados[[:blank:]].*[0-9.]*dev')" ; then + (cd /usr/src/arvados/sdk/ruby && \ + /var/lib/arvados/bin/gem build arvados.gemspec && flock $GEMLOCK /var/lib/arvados/bin/gem install $(ls -1 *.gem | sort -r | head -n1)) + fi + if ! flock $GEMLOCK $BUNDLER install --verbose --local --no-deployment $frozen "$@" ; then + flock $GEMLOCK $BUNDLER install --verbose --no-deployment $frozen "$@" fi } @@ -88,12 +95,12 @@ pip_install() { popd if [ "$PYCMD" = "python3" ]; then - if ! pip3 install --prefix /usr/local --no-index --find-links /var/lib/pip $1 ; then + if ! pip3 install --prefix /usr/local --no-index --find-links /var/lib/pip $1 ; then pip3 install --prefix /usr/local $1 - fi + fi else - if ! pip install --no-index --find-links /var/lib/pip $1 ; then + if ! pip install --no-index --find-links /var/lib/pip $1 ; then pip install $1 - fi + fi fi }