mirror of
https://github.com/vyos/vyos-build.git
synced 2025-10-01 20:28:40 +02:00
677 lines
18 KiB
Docker
677 lines
18 KiB
Docker
# Copyright (C) 2018-2022 VyOS maintainers and contributors
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# in order to easy exprort images built to "external" world
|
|
# it under the terms of the GNU General Public License version 2 or later as
|
|
# published by the Free Software Foundation.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# Must be run with --privileged flag, recommended to run the container with a
|
|
# volume mapped in order to easy export images
|
|
|
|
# This Dockerfile is installable on both x86, x86-64, armhf and arm64 systems
|
|
ARG ARCH=
|
|
FROM ${ARCH}debian:bullseye
|
|
|
|
# It is also possible to emulate an arm system inside docker,
|
|
# execution of this emulated system needs to be executed on an x86 or x86-64 host.
|
|
|
|
# To install using a non-native cpu instructionset use the `--build-arg ARCH=<ARCH>/`
|
|
# Supported architectures:
|
|
# arm32v6/
|
|
# arm32v7/
|
|
# arm64v8/
|
|
# Example bo byukd natively:
|
|
# docker build -t vyos-build:current .
|
|
# Example to build on armhf:
|
|
# docker build -t vyos-build:current-armhf --build-arg ARCH=arm32v7/ .
|
|
# Example to build on arm64:
|
|
# docker build -t vyos-build:current-arm64 --build-arg ARCH=arm64v8/ .
|
|
|
|
# On some versions of docker the emulation framework is not installed by default and
|
|
# you need to install qemu, qemu-user-static and register qemu inside docker manually using:
|
|
# `docker run --rm --privileged multiarch/qemu-user-static:register --reset`
|
|
LABEL authors="VyOS Maintainers <maintainers@vyos.io>"
|
|
ENV DEBIAN_FRONTEND noninteractive
|
|
|
|
# Standard shell should be bash not dash
|
|
RUN echo "dash dash/sh boolean false" | debconf-set-selections && \
|
|
dpkg-reconfigure dash
|
|
|
|
RUN echo -e 'APT::Install-Recommends "0";\nAPT::Install-Suggests "0";' > /etc/apt/apt.conf.d/01norecommends
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
dialog \
|
|
apt-utils \
|
|
locales
|
|
|
|
RUN echo "en_US.UTF-8 UTF-8" > /etc/locale.gen && locale-gen
|
|
ENV LANG en_US.utf8
|
|
|
|
ENV OCAML_VERSION 4.12.0
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
bash \
|
|
bash-completion \
|
|
vim \
|
|
vim-autopep8 \
|
|
nano \
|
|
git \
|
|
curl \
|
|
sudo \
|
|
mc \
|
|
pbuilder \
|
|
devscripts \
|
|
lsb-release \
|
|
libtool \
|
|
libapt-pkg-dev \
|
|
flake8 \
|
|
pkg-config \
|
|
debhelper \
|
|
gosu \
|
|
po4a \
|
|
openssh-client \
|
|
jq
|
|
|
|
# Packages needed for vyos-build
|
|
RUN apt-get update && apt-get install -y \
|
|
build-essential \
|
|
python3-pystache \
|
|
squashfs-tools \
|
|
genisoimage \
|
|
fakechroot \
|
|
python3-git \
|
|
python3-pip \
|
|
python3-flake8 \
|
|
python3-autopep8 \
|
|
debootstrap \
|
|
live-build
|
|
|
|
# vyos-build now also makes use of TOML - install yq which has toml support
|
|
RUN pip install yq==3.1.0
|
|
|
|
# Syslinux and Grub2 is only supported on x86 and x64 systems
|
|
RUN if dpkg-architecture -ii386 || dpkg-architecture -iamd64; then \
|
|
apt-get update && apt-get install -y \
|
|
syslinux \
|
|
grub2; \
|
|
fi
|
|
|
|
#
|
|
# Building libvyosconf requires a full configured OPAM/OCaml setup
|
|
#
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper \
|
|
libffi-dev \
|
|
libpcre3-dev \
|
|
unzip
|
|
|
|
# Update certificate store to not crash ocaml package install
|
|
# Apply fix for https in curl running on armhf
|
|
RUN dpkg-reconfigure ca-certificates; \
|
|
if dpkg-architecture -iarmhf; then \
|
|
echo "cacert=/etc/ssl/certs/ca-certificates.crt" >> ~/.curlrc; \
|
|
fi
|
|
|
|
|
|
# Installing OCAML needed to compile libvyosconfig
|
|
RUN curl https://raw.githubusercontent.com/ocaml/opam/master/shell/install.sh \
|
|
--output /tmp/opam_install.sh --retry 10 --retry-delay 5 && \
|
|
sed -i 's/read BINDIR/BINDIR=""/' /tmp/opam_install.sh && sh /tmp/opam_install.sh && \
|
|
opam init --root=/opt/opam --comp=${OCAML_VERSION} --disable-sandboxing --no-setup
|
|
|
|
RUN eval $(opam env --root=/opt/opam --set-root) && opam install -y \
|
|
pcre re
|
|
|
|
RUN eval $(opam env --root=/opt/opam --set-root) && opam install -y \
|
|
num \
|
|
ctypes \
|
|
ctypes-foreign \
|
|
ctypes-build \
|
|
containers \
|
|
fileutils
|
|
|
|
# Build VyConf which is required to build libvyosconfig
|
|
RUN eval $(opam env --root=/opt/opam --set-root) && \
|
|
opam pin add vyos1x-config https://github.com/vyos/vyos1x-config.git#40f7d2af -y
|
|
|
|
# Packages needed for libvyosconfig
|
|
RUN apt-get update && apt-get install -y \
|
|
quilt \
|
|
libpcre3-dev \
|
|
libffi-dev
|
|
|
|
# Build libvyosconfig
|
|
RUN eval $(opam env --root=/opt/opam --set-root) && \
|
|
git clone https://github.com/vyos/libvyosconfig.git /tmp/libvyosconfig && \
|
|
cd /tmp/libvyosconfig && git checkout 2f90f3c5 && \
|
|
dpkg-buildpackage -uc -us -tc -b && \
|
|
dpkg -i /tmp/libvyosconfig0_*_$(dpkg-architecture -qDEB_HOST_ARCH).deb
|
|
|
|
# Install open-vmdk
|
|
RUN wget -O /tmp/open-vmdk-master.zip https://github.com/vmware/open-vmdk/archive/master.zip && \
|
|
unzip -d /tmp/ /tmp/open-vmdk-master.zip && \
|
|
cd /tmp/open-vmdk-master/ && \
|
|
make && \
|
|
make install
|
|
|
|
#
|
|
# live-build: building in docker fails with mounting /proc | /sys
|
|
#
|
|
# https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=919659
|
|
# https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=921815
|
|
# https://salsa.debian.org/installer-team/debootstrap/merge_requests/26
|
|
#
|
|
RUN wget https://salsa.debian.org/klausenbusk-guest/debootstrap/commit/a9a603b17cadbf52cb98cde0843dc9f23a08b0da.patch \
|
|
-O /tmp/a9a603b17cadbf52cb98cde0843dc9f23a08b0da.patch && \
|
|
git clone https://salsa.debian.org/installer-team/debootstrap /tmp/debootstrap && \
|
|
cd /tmp/debootstrap && git checkout 1.0.114 && \
|
|
patch -p1 < /tmp/a9a603b17cadbf52cb98cde0843dc9f23a08b0da.patch && \
|
|
dch -n "Applying fix for docker image compile" && \
|
|
dpkg-buildpackage -us -uc && \
|
|
sudo dpkg -i ../debootstrap*.deb
|
|
|
|
# Packages needed for vyatta-cfg
|
|
RUN apt-get update && apt-get install -y \
|
|
autotools-dev \
|
|
libglib2.0-dev \
|
|
libboost-filesystem-dev \
|
|
libapt-pkg-dev \
|
|
libtool \
|
|
flex \
|
|
bison \
|
|
libperl-dev \
|
|
autoconf \
|
|
automake \
|
|
pkg-config \
|
|
cpio
|
|
|
|
# Packages needed for vyatta-cfg-firewall
|
|
RUN apt-get update && apt-get install -y \
|
|
autotools-dev \
|
|
autoconf \
|
|
automake \
|
|
cpio
|
|
|
|
# Packages needed for Linux Kernel
|
|
# gnupg2 is required by Jenkins for the TAR verification
|
|
RUN apt-get update && apt-get install -y \
|
|
gnupg2 \
|
|
rsync \
|
|
libncurses5-dev \
|
|
flex \
|
|
bison \
|
|
bc \
|
|
kmod \
|
|
cpio \
|
|
python-is-python3
|
|
|
|
# Packages needed for Intel QAT out-of-tree drivers
|
|
RUN apt-get update && apt-get install -y \
|
|
pciutils \
|
|
yasm
|
|
|
|
# Packages needed for Wireguard
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper-compat \
|
|
dkms \
|
|
pkg-config \
|
|
systemd
|
|
|
|
# Packages needed for iproute2
|
|
RUN apt-get update && apt-get install -y \
|
|
bison \
|
|
debhelper \
|
|
flex \
|
|
libxtables-dev \
|
|
libatm1-dev \
|
|
libcap-dev \
|
|
libdb-dev \
|
|
libbsd-dev \
|
|
libelf-dev \
|
|
libmnl-dev \
|
|
libselinux1-dev \
|
|
linux-libc-dev \
|
|
pkg-config \
|
|
po-debconf \
|
|
zlib1g-dev
|
|
|
|
# Prerequisites for building rtrlib
|
|
# see http://docs.frrouting.org/projects/dev-guide/en/latest/building-frr-for-debian8.html
|
|
RUN apt-get update && apt-get install -y \
|
|
cmake \
|
|
dpkg-dev \
|
|
debhelper \
|
|
libssh-dev \
|
|
doxygen
|
|
|
|
# Build rtrlib release 0.8.0
|
|
RUN export RTRLIB_VERSION="0.8.0" export ARCH=$(dpkg-architecture -qDEB_HOST_ARCH) && \
|
|
git clone https://github.com/rtrlib/rtrlib.git /tmp/rtrlib && cd /tmp/rtrlib && \
|
|
dpkg-buildpackage -uc -us -tc -b && \
|
|
dpkg -i ../librtr0*_${ARCH}.deb ../librtr-dev*_${ARCH}.deb ../rtr-tools*_${ARCH}.deb
|
|
|
|
# Packages needed to build libyang2
|
|
RUN pip install apkg
|
|
RUN apt-get update && apt-get install -y \
|
|
graphviz \
|
|
cmake \
|
|
libpcre3-dev \
|
|
python3-pip
|
|
|
|
# Prerequisites for building FRR from source
|
|
# see http://docs.frrouting.org/projects/dev-guide/en/latest/building-frr-for-debian8.html
|
|
#
|
|
RUN export LIBYANG_COMMIT="v2.0.164" && \
|
|
git clone https://github.com/CESNET/libyang.git && \
|
|
cd libyang && git checkout $LIBYANG_COMMIT && apkg build -i && \
|
|
cd pkg/pkgs/debian-11/libyang2_* && dpkg -i *.deb
|
|
|
|
# FRR documentation also has a dependency on an up to date spinx version
|
|
RUN pip install sphinx==4.0.2
|
|
|
|
# Packages needed to build FRR itself
|
|
# https://github.com/FRRouting/frr/blob/master/doc/developer/building-libyang.rst
|
|
# for more info
|
|
RUN apt-get update && apt-get install -y \
|
|
bison \
|
|
chrpath \
|
|
debhelper \
|
|
flex \
|
|
gawk \
|
|
install-info \
|
|
libc-ares-dev \
|
|
libcap-dev \
|
|
libjson-c-dev \
|
|
libpam0g-dev \
|
|
libpcre3-dev \
|
|
libpython3-dev \
|
|
libreadline-dev \
|
|
librtr-dev \
|
|
libsnmp-dev \
|
|
libssh-dev \
|
|
libsystemd-dev \
|
|
lsb-base \
|
|
pkg-config \
|
|
python3 \
|
|
python3-dev \
|
|
python3-pytest \
|
|
texinfo
|
|
|
|
# Packages needed for hvinfo
|
|
RUN apt-get update && apt-get install -y \
|
|
gnat \
|
|
gprbuild
|
|
|
|
# Packages needed for vyos-1x
|
|
RUN pip install git+https://github.com/aristanetworks/j2lint.git@341b5d5db86
|
|
RUN apt-get update && apt-get install -y \
|
|
dh-python \
|
|
fakeroot \
|
|
libzmq3-dev \
|
|
python3 \
|
|
python3-setuptools \
|
|
python3-sphinx \
|
|
python3-xmltodict \
|
|
python3-lxml \
|
|
python3-nose \
|
|
python3-netifaces \
|
|
python3-jinja2 \
|
|
python3-psutil \
|
|
python3-stdeb \
|
|
python3-all \
|
|
python3-coverage \
|
|
quilt \
|
|
whois
|
|
|
|
Run git clone https://github.com/dsoprea/PyInotify.git /tmp/inotify && \
|
|
cd /tmp/inotify && \
|
|
python3 setup.py --command-packages=stdeb.command bdist_deb && \
|
|
sudo dpkg -i ./deb_dist/python3-inotify*.deb
|
|
|
|
Run git clone https://github.com/nficano/humps.git /tmp/humps && \
|
|
cd /tmp/humps && git checkout v3.8.0 && \
|
|
python3 setup.py --command-packages=stdeb.command bdist_deb; cp deb_dist/*.deb .. && \
|
|
dpkg -i /tmp/python3-pyhumps_*_all.deb
|
|
|
|
# Packages needed for vyos-1x-xdp package, gcc-multilib is not available on
|
|
# arm64 but required by XDP
|
|
RUN if dpkg-architecture -ii386 || dpkg-architecture -iamd64; then \
|
|
apt-get update && apt-get install -y \
|
|
gcc-multilib \
|
|
clang \
|
|
llvm \
|
|
libelf-dev \
|
|
libpcap-dev \
|
|
libbpf-dev \
|
|
build-essential; \
|
|
fi
|
|
|
|
# Go required for validators and vyos-xe-guest-utilities
|
|
RUN GO_VERSION_INSTALL="1.18.3" ; \
|
|
wget -O /tmp/go${GO_VERSION_INSTALL}.linux-amd64.tar.gz https://go.dev/dl/go${GO_VERSION_INSTALL}.linux-$(dpkg-architecture -qDEB_HOST_ARCH).tar.gz ; \
|
|
tar -C /opt -xzf /tmp/go*.tar.gz && \
|
|
rm /tmp/go*.tar.gz
|
|
RUN echo "export PATH=/opt/go/bin:$PATH" >> /etc/bash.bashrc
|
|
|
|
# Packages needed for ipaddrcheck
|
|
RUN apt-get update && apt-get install -y \
|
|
libcidr-dev \
|
|
check
|
|
|
|
# Packages needed for vyatta-quagga
|
|
RUN apt-get update && apt-get install -y \
|
|
libpam-dev \
|
|
libcap-dev \
|
|
libsnmp-dev \
|
|
gawk
|
|
|
|
# Packages needed for vyos-strongswan
|
|
RUN apt-get update && apt-get install -y \
|
|
bison \
|
|
bzip2 \
|
|
debhelper \
|
|
dh-apparmor \
|
|
dpkg-dev \
|
|
flex \
|
|
gperf \
|
|
libxtables-dev \
|
|
libcap-dev \
|
|
libcurl4-openssl-dev \
|
|
libgcrypt20-dev \
|
|
libgmp3-dev \
|
|
libiptc-dev \
|
|
libkrb5-dev \
|
|
libldap2-dev \
|
|
libnm-dev \
|
|
libpam0g-dev \
|
|
libsqlite3-dev \
|
|
libssl-dev \
|
|
libsystemd-dev \
|
|
libtool \
|
|
libtss2-dev \
|
|
libxml2-dev \
|
|
pkg-config \
|
|
po-debconf \
|
|
systemd \
|
|
tzdata \
|
|
python-setuptools \
|
|
python3-stdeb
|
|
|
|
# Packages needed for opennhrp
|
|
RUN apt-get update && apt-get install -y \
|
|
libc-ares-dev \
|
|
libev-dev
|
|
|
|
# Packages needed for Qemu test-suite
|
|
# This is for now only supported on i386 and amd64 platforms
|
|
RUN if dpkg-architecture -ii386 || dpkg-architecture -iamd64; then \
|
|
apt-get update && apt-get install -y \
|
|
python3-pexpect \
|
|
ovmf \
|
|
qemu-system-x86 \
|
|
qemu-utils \
|
|
qemu-kvm; \
|
|
fi
|
|
|
|
# Packages needed for building vmware and GCE images
|
|
# This is only supported on i386 and amd64 platforms
|
|
RUN if dpkg-architecture -ii386 || dpkg-architecture -iamd64; then \
|
|
apt-get update && apt-get install -y \
|
|
kpartx \
|
|
parted \
|
|
udev \
|
|
grub-pc \
|
|
grub2-common; \
|
|
fi
|
|
|
|
# Packages needed for vyos-cloud-init
|
|
RUN apt-get update && apt-get install -y \
|
|
python3-configobj \
|
|
python3-httpretty \
|
|
python3-jsonpatch \
|
|
python3-mock \
|
|
python3-oauthlib \
|
|
python3-pep8 \
|
|
python3-pyflakes \
|
|
python3-serial \
|
|
python3-unittest2 \
|
|
python3-yaml \
|
|
python3-jsonschema \
|
|
python3-contextlib2 \
|
|
python3-pytest-cov \
|
|
cloud-utils
|
|
|
|
# Packages needed for libnss-mapuser & libpam-radius
|
|
RUN apt-get update && apt-get install -y \
|
|
libaudit-dev
|
|
|
|
# Install utillities for building grub and u-boot images
|
|
RUN if dpkg-architecture -iarm64; then \
|
|
apt-get update && apt-get install -y \
|
|
dosfstools \
|
|
u-boot-tools \
|
|
grub-efi-$(dpkg-architecture -qDEB_HOST_ARCH); \
|
|
elif dpkg-architecture -iarmhf; then \
|
|
apt-get update && apt-get install -y \
|
|
dosfstools \
|
|
u-boot-tools \
|
|
grub-efi-arm; \
|
|
fi
|
|
|
|
# Packages needed for libnftnl
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper-compat \
|
|
libmnl-dev \
|
|
libtool \
|
|
pkg-config
|
|
|
|
# Packages needed for nftables
|
|
RUN apt-get update && apt-get install -y \
|
|
asciidoc-base \
|
|
automake \
|
|
bison \
|
|
debhelper-compat \
|
|
dh-python \
|
|
docbook-xsl \
|
|
flex \
|
|
libeditreadline-dev \
|
|
libgmp-dev \
|
|
libjansson-dev \
|
|
libmnl-dev \
|
|
libtool \
|
|
libxtables-dev \
|
|
python3-all \
|
|
python3-setuptools \
|
|
xsltproc
|
|
|
|
# Packages needed for libnetfilter-conntrack
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper-compat \
|
|
libmnl-dev \
|
|
libnfnetlink-dev \
|
|
libnetfilter-cthelper-dev \
|
|
libnetfilter-cttimeout-dev \
|
|
libnetfilter-queue-dev \
|
|
libtool
|
|
|
|
# Packages needed for wide-dhcpv6
|
|
RUN apt-get update && apt-get install -y \
|
|
bison \
|
|
debhelper \
|
|
flex \
|
|
libfl-dev \
|
|
rsync
|
|
|
|
# Packages needed for vyos-http-api-tools
|
|
RUN apt-get update && apt-get install -y \
|
|
dh-virtualenv \
|
|
python3-venv
|
|
|
|
# Packages needed for openvpn-otp
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper \
|
|
libssl-dev \
|
|
openvpn
|
|
|
|
# Packages needed for OWAMP/TWAMP (service sla)
|
|
RUN apt-get update && apt-get install -y \
|
|
dh-exec \
|
|
libi2util-dev \
|
|
i2util-tools
|
|
|
|
# Packages needed for keepalived
|
|
RUN apt-get update && apt-get install -y \
|
|
autoconf \
|
|
libglib2.0-dev \
|
|
libip4tc-dev \
|
|
libipset-dev \
|
|
libjson-c-dev \
|
|
libnfnetlink-dev \
|
|
libnftnl-dev \
|
|
libnl-3-dev \
|
|
libnl-genl-3-dev \
|
|
libnl-nf-3-dev \
|
|
libpcre2-dev \
|
|
libpopt-dev \
|
|
libsnmp-dev \
|
|
libssl-dev \
|
|
libsystemd-dev \
|
|
linux-libc-dev \
|
|
pkg-config
|
|
|
|
# Packages needed for dropbear
|
|
RUN apt-get update && apt-get install -y \
|
|
debhelper-compat \
|
|
libtomcrypt-dev \
|
|
libtommath-dev \
|
|
libz-dev
|
|
|
|
# Creating image for embedded systems needs this utilities to prepare a image file
|
|
RUN apt-get update && apt-get install -y \
|
|
parted \
|
|
udev \
|
|
zip
|
|
|
|
# Packages needed for Fastnetmon
|
|
RUN if dpkg-architecture -ii386 || dpkg-architecture -iamd64; then \
|
|
apt-get update && apt-get install -y \
|
|
cmake \
|
|
debhelper-compat \
|
|
libboost-atomic-dev \
|
|
libboost-chrono-dev \
|
|
libboost-date-time-dev \
|
|
libboost-program-options-dev \
|
|
libboost-regex-dev \
|
|
libboost-system-dev \
|
|
libboost-thread-dev \
|
|
libbson-dev \
|
|
libcapnp-dev \
|
|
libgrpc-dev \
|
|
libgrpc++-dev \
|
|
libprotobuf-dev \
|
|
protobuf-compiler \
|
|
protobuf-compiler-grpc \
|
|
capnproto \
|
|
libhiredis-dev \
|
|
libjson-c-dev \
|
|
liblog4cpp5-dev \
|
|
libluajit-5.1-dev \
|
|
libicu-dev \
|
|
libmongoc-dev \
|
|
libncurses5-dev \
|
|
libpcap-dev \
|
|
pkg-config; \
|
|
fi
|
|
|
|
# Packages needed for hostapd (wpa_supplicant)
|
|
RUN apt-get update && apt-get install -y \
|
|
libdbus-1-dev \
|
|
libssl-dev \
|
|
libncurses5-dev \
|
|
libpcsclite-dev \
|
|
libnl-3-dev \
|
|
libnl-genl-3-dev \
|
|
libnl-route-3-dev \
|
|
libreadline-dev \
|
|
pkg-config \
|
|
docbook-to-man \
|
|
docbook-utils
|
|
|
|
# Packages needed for podman
|
|
RUN apt-get update && sudo apt-get install -y \
|
|
btrfs-progs \
|
|
git \
|
|
iptables \
|
|
libassuan-dev \
|
|
libbtrfs-dev \
|
|
libc6-dev \
|
|
libdevmapper-dev \
|
|
libglib2.0-dev \
|
|
libgpgme-dev \
|
|
libgpg-error-dev \
|
|
libprotobuf-dev \
|
|
libprotobuf-c-dev \
|
|
libseccomp-dev \
|
|
libselinux1-dev \
|
|
libsystemd-dev \
|
|
pkg-config \
|
|
runc \
|
|
uidmap
|
|
|
|
# Packages needed for Accel-PPP
|
|
# XXX: please note that this must be installed after nftable dependencies - otherwise
|
|
# APT will remove liblua5.3-dev which breaks the Accel-PPP build
|
|
RUN apt-get update && apt-get install -y \
|
|
liblua5.3-dev \
|
|
libssl1.1 \
|
|
libssl-dev \
|
|
libpcre3-dev
|
|
|
|
# Packages needed for sstp-client
|
|
RUN apt-get update && apt-get install -y \
|
|
libssl-dev \
|
|
libevent-dev \
|
|
ppp-dev
|
|
|
|
# Packages needed for pam_tacplus
|
|
RUN apt-get update && apt-get install -y \
|
|
libpam-dev \
|
|
autoconf-archive \
|
|
gnulib \
|
|
libtool
|
|
|
|
#
|
|
# fpm: a command-line program designed to help you build packages (e.g. deb)
|
|
#
|
|
RUN apt-get update && apt-get install -y \
|
|
ruby \
|
|
ruby-dev \
|
|
rubygems \
|
|
build-essential
|
|
RUN gem install --no-document fpm
|
|
|
|
# Allow password-less 'sudo' for all users in group 'sudo'
|
|
RUN sed "s/^%sudo.*/%sudo\tALL=(ALL) NOPASSWD:ALL/g" -i /etc/sudoers && \
|
|
chmod a+s /usr/sbin/useradd /usr/sbin/groupadd /usr/sbin/gosu /usr/sbin/usermod
|
|
|
|
# Ensure sure all users have access to our OCAM and Go installation
|
|
RUN echo "$(opam env --root=/opt/opam --set-root)" >> /etc/skel/.bashrc && \
|
|
echo "export PATH=/opt/go/bin:\$PATH" >> /etc/skel/.bashrc
|
|
|
|
# Cleanup
|
|
RUN rm -rf /tmp/*
|
|
|
|
# Disable mouse in vim
|
|
RUN echo -e "set mouse=\nset ttymouse=" > /etc/vim/vimrc.local
|
|
|
|
COPY entrypoint.sh /usr/local/bin/entrypoint.sh
|
|
ENTRYPOINT ["/usr/local/bin/entrypoint.sh"]
|