FROM d4science/r-studio-requirement LABEL org.d4science.image.licenses="EUPL-1.2" \ org.d4science.image.source="https://code-repo.d4science.org/gCubeSystem/r-studio-requirement" \ org.d4science.image.vendor="D4Science " \ org.d4science.image.authors="Andrea Dell'Amico , Roberto Cirillo " \ org.d4science.image.r_version="2022.02.1+461" ARG NB_USER="jovyan" ARG NB_UID="1000" ARG NB_GID="100" ENV S6_VERSION=v2.1.0.2 ENV RSTUDIO_VERSION=2022.02.1+461 ENV DEFAULT_USER="jovyan" ENV USERID="1000" ENV GROUPID="100" ENV PANDOC_VERSION=default ENV PATH=/usr/lib/rstudio-server/bin:$PATH ENV DEBIAN_FRONTEND=noninteractive # Configure environment ENV SHELL=/bin/bash \ NB_USER="${NB_USER}" \ NB_UID=${NB_UID} \ NB_GID=${NB_GID} \ LC_ALL=en_US.UTF-8 \ LANG=en_US.UTF-8 \ LANGUAGE=en_US.UTF-8 ENV HOME="/home/${NB_USER}" # Create NB_USER with name jovyan user with UID=1000 and in the 'users' group # and make sure these dirs are writable by the `users` group. RUN echo "auth requisite pam_deny.so" >> /etc/pam.d/su && \ sed -i.bak -e 's/^%admin/#%admin/' /etc/sudoers && \ sed -i.bak -e 's/^%sudo/#%sudo/' /etc/sudoers && \ chmod g+w /etc/passwd && \ fix-permissions "${HOME}" RUN apt-get update --yes && \ apt-get upgrade --yes && \ apt-get install --yes --no-install-recommends \ python3 python3-pip RUN /rocker_scripts/install_rstudio.sh # This part comes from https://github.com/openanalytics/shinyproxy-rstudio-ide-demo/blob/master/Dockerfile RUN echo "www-frame-origin=same" >> /etc/rstudio/disable_auth_rserver.conf RUN echo "www-verify-user-agent=0" >> /etc/rstudio/disable_auth_rserver.conf ADD 01_set_env.sh /etc/cont-init.d/01_set_env ADD 02_userconf.sh /etc/cont-init.d/02_userconf ADD 03_setup_root_path.sh /etc/cont-init.d/03_setup_root_path # By default RStudio does not give access to all enviornment variables defined in the container (e.g. using ShinyProxy). # Uncomment the next line, to change this behavior. ADD 04_copy_env.sh /etc/cont-init.d/04_copy_env ADD 05_setup_rsession_parameters.sh /etc/cont-init.d/05_setup_rsession_parameters # Install the jupiterhub proxy RUN pip3 install \ jupyterhub \ jupyterlab \ jupyter-rsession-proxy \ jupyter-server-proxy \ notebook RUN apt-get clean && rm -rf /var/lib/apt/lists/* && \ echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && \ locale-gen # Copy a script that we will use to correct permissions after running certain commands COPY fix-permissions /usr/local/bin/fix-permissions RUN chmod a+rx /usr/local/bin/fix-permissions # Enable prompt color in the skeleton .bashrc before creating the default NB_USER # hadolint ignore=SC2016 RUN sed -i 's/^#force_color_prompt=yes/force_color_prompt=yes/' /etc/skel/.bashrc RUN NODE_OPTIONS="--openssl-legacy-provider" \ jupyter labextension install \ @jupyter-widgets/jupyterlab-manager jupyter-leaflet # Prepare the workspace environment # RUN mkdir -p /opt/workspace-lib # RUN mkdir /var/log/workspace-lib # ADD https://maven.d4science.org/nexus/content/repositories/gcube-snapshots/org/gcube/data-access/sh-fuse-integration/2.0.0-SNAPSHOT/sh-fuse-integration-2.0.0-20211005.090627-1-jar-with-dependencies.jar /opt/workspace-lib/fuse-workspace.jar # ADD 06_workspace_mount.sh /etc/cont-init.d/06_workspace_mount # ADD 06-fuse-logback.xml /opt/workspace-lib/logback.xml # EXPOSE 8787 # CMD ["/init"]