code-server/Dockerfile

67 lines
1.9 KiB
Docker
Raw Normal View History

2020-01-09 05:30:44 +07:00
FROM node:12.14.0
2019-07-16 01:23:29 +07:00
ARG codeServerVersion=docker
ARG vscodeVersion
2019-09-18 02:00:51 +07:00
ARG githubToken
2019-03-07 09:59:43 +07:00
# Install VS Code's deps. These are the only two it seems we need.
RUN apt-get update && apt-get install -y \
libxkbfile-dev \
libsecret-1-dev
2019-03-07 09:59:43 +07:00
WORKDIR /src
COPY . .
2019-07-16 01:23:29 +07:00
RUN yarn \
2019-09-18 02:00:51 +07:00
&& MINIFY=true GITHUB_TOKEN="${githubToken}" yarn build "${vscodeVersion}" "${codeServerVersion}" \
&& yarn binary "${vscodeVersion}" "${codeServerVersion}" \
&& mv "/src/binaries/code-server${codeServerVersion}-vsc${vscodeVersion}-linux-x86_64" /src/binaries/code-server \
&& rm -r /src/build \
&& rm -r /src/source
2019-03-07 09:59:43 +07:00
# We deploy with ubuntu so that devs have a familiar environment.
FROM ubuntu:18.04
RUN apt-get update && apt-get install -y \
openssl \
2019-04-03 07:24:44 +07:00
net-tools \
git \
locales \
sudo \
dumb-init \
vim \
curl \
wget \
&& rm -rf /var/lib/apt/lists/*
RUN locale-gen en_US.UTF-8
2019-07-16 01:23:29 +07:00
# We cannot use update-locale because docker will not use the env variables
2019-04-03 07:24:44 +07:00
# configured in /etc/default/locale so we need to set it manually.
ENV LC_ALL=en_US.UTF-8 \
SHELL=/bin/bash
2019-04-05 08:00:42 +07:00
RUN adduser --gecos '' --disabled-password coder && \
echo "coder ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers.d/nopasswd
USER coder
2019-07-16 01:23:29 +07:00
# We create first instead of just using WORKDIR as when WORKDIR creates, the
# user is root.
2019-04-18 05:36:33 +07:00
RUN mkdir -p /home/coder/project
# To avoid EACCES issues on f.ex Crostini (ChromeOS)
2019-12-11 01:06:52 +07:00
RUN mkdir -p /home/coder/.local/share/code-server
2020-01-16 02:14:05 +07:00
# FIXME: permission fix required for bind-mounts
# See GH-1270
RUN sudo chmod -R g+rw /home/coder/project && sudo chmod -R g+rw /home/coder/.local/share/code-server && \
sudo chown -R coder:coder /home/coder
WORKDIR /home/coder/project
2019-07-16 01:23:29 +07:00
# This ensures we have a volume mounted even if the user forgot to do bind
# mount. So that they do not lose their data if they delete the container.
VOLUME [ "/home/coder/project" ]
COPY --from=0 /src/binaries/code-server /usr/local/bin/code-server
2019-08-08 23:21:45 +07:00
EXPOSE 8080
2019-07-16 01:23:29 +07:00
ENTRYPOINT ["dumb-init", "code-server", "--host", "0.0.0.0"]