|
|
|
# using ubuntu 20 docker image
|
|
|
|
FROM ubuntu:focal
|
|
|
|
|
|
|
|
ARG DEBIAN_FRONTEND=noninteractive
|
|
|
|
ARG HEY_URL=https://hey-release.s3.us-east-2.amazonaws.com/hey_linux_amd64
|
|
|
|
ARG WASI_SDK_URL=https://github.com/WebAssembly/wasi-sdk/releases/download/wasi-sdk-8/wasi-sdk_8.0_amd64.deb
|
|
|
|
ARG WASMCEPTION_URL=https://github.com/gwsystems/wasmception/releases/download/v0.2.0/wasmception-linux-x86_64-0.2.0.tar.gz
|
|
|
|
|
|
|
|
# General GCC C/C++ Build toolchain
|
|
|
|
# pkg-config, libtool - used by PocketSphinx
|
|
|
|
# cmake - used by cmsis
|
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
|
|
automake \
|
|
|
|
build-essential \
|
|
|
|
binutils-dev \
|
|
|
|
cmake \
|
|
|
|
git \
|
|
|
|
libtinfo5 \
|
|
|
|
libtool \
|
|
|
|
pkg-config
|
|
|
|
|
|
|
|
# Needed to install from http endpoints via curl or wget
|
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
|
|
curl \
|
|
|
|
ca-certificates \
|
|
|
|
libssl-dev \
|
|
|
|
lsb-release \
|
|
|
|
gpg-agent \
|
|
|
|
software-properties-common \
|
|
|
|
wget
|
|
|
|
|
|
|
|
# Test Script Stuff
|
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
|
|
fonts-dejavu \
|
|
|
|
fonts-cascadia-code \
|
|
|
|
fonts-roboto \
|
|
|
|
imagemagick \
|
|
|
|
netpbm \
|
|
|
|
pango1.0-tools \
|
|
|
|
wamerican
|
|
|
|
|
|
|
|
# Hey is a load generator we have to recklessly download from the 'net, as it is only published to brew
|
|
|
|
# Binaries are only provided for AMD64 though, so ARM will have to build from source
|
|
|
|
# See https://github.com/rakyll/hey
|
|
|
|
RUN wget $HEY_URL -O hey && chmod +x hey && mv hey /usr/bin/hey
|
|
|
|
|
|
|
|
# Interactive Tools
|
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
|
|
bc \
|
|
|
|
bsdmainutils \
|
|
|
|
less \
|
|
|
|
gdb \
|
|
|
|
strace \
|
|
|
|
vim
|
|
|
|
|
|
|
|
ENV LLVM_VERSION=8
|
|
|
|
ADD install_llvm.sh /sledge/install_llvm.sh
|
|
|
|
RUN ./sledge/install_llvm.sh $LLVM_VERSION
|
|
|
|
|
|
|
|
# Wasmception
|
|
|
|
RUN wget $WASMCEPTION_URL -O wasmception.tar.gz
|
|
|
|
RUN mkdir -p /sledge/awsm/wasmception
|
|
|
|
RUN tar xvfz wasmception.tar.gz -C /sledge/awsm/wasmception
|
|
|
|
|
|
|
|
# WASI-SDK
|
|
|
|
# TODO: Refactor to output as an arch-neutral filename
|
|
|
|
# RUN curl -sS -L -O $WASI_SDK_URL && dpkg -i wasi-sdk_8.0_amd64.deb && rm -f wasi-sdk_8.0_amd64.deb
|
|
|
|
# ENV WASI_SDK=/opt/wasi-sdk
|
|
|
|
|
|
|
|
# Create non-root user and add to sudoers
|
|
|
|
ARG USERNAME=dev
|
|
|
|
ARG USER_UID=1000
|
|
|
|
ARG USER_GID=$USER_UID
|
|
|
|
RUN groupadd --gid $USER_GID $USERNAME
|
|
|
|
RUN useradd --uid $USER_UID --gid $USER_GID -m $USERNAME
|
|
|
|
RUN apt-get update && apt-get install -y sudo
|
|
|
|
RUN echo $USERNAME ALL=\(root\) NOPASSWD:ALL > /etc/sudoers.d/$USERNAME
|
|
|
|
RUN chmod 0440 /etc/sudoers.d/$USERNAME
|
|
|
|
|
|
|
|
# Make non-root user default user and use for rest of Dockerfile
|
|
|
|
USER $USER_UID
|
|
|
|
|
|
|
|
# Make sure the mount point and installation target and any files therein are owned by the non-root user
|
|
|
|
RUN sudo chown $USER_GID:$USER_GID /sledge
|
|
|
|
ADD fix_root.sh /sledge/fix_root.sh
|
|
|
|
RUN cd sledge && ./fix_root.sh
|
|
|
|
RUN sudo mkdir /opt/sledge
|
|
|
|
RUN sudo chown $USER_GID:$USER_GID /opt/sledge
|
|
|
|
|
|
|
|
################################
|
|
|
|
# Final Setup as non-root user #
|
|
|
|
################################
|
|
|
|
|
|
|
|
# Rust
|
|
|
|
# Rustup does not cleanly support system installs, so install as non-root user
|
|
|
|
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --default-toolchain stable --component rustfmt --target wasm32-wasi -y
|
|
|
|
ENV PATH=/home/dev/.cargo/bin:$PATH
|
|
|
|
RUN cargo install --debug cargo-audit cargo-watch rsign2
|
|
|
|
|
|
|
|
# We need to set the locale for pango-view
|
|
|
|
ENV LANG C.UTF-8
|
|
|
|
ENV LANGUAGE C.UTF-8
|
|
|
|
ENV LC_ALL C.UTF-8
|
|
|
|
|
|
|
|
# Update PATH and LD_LIBRARY_PATH
|
|
|
|
ENV PATH=/opt/sledge/bin:$PATH
|
|
|
|
|
|
|
|
# TODO: Does the build process for the sample applications actually copy here?
|
|
|
|
# TODO: Should we create a special SLEDGE_MODULE_PATH that is searched for these modules?
|
|
|
|
ENV LD_LIBRARY_PATH=/opt/sledge/bin:LD_LIBRARY_PATH
|