mirror of
https://github.com/upa/mscp.git
synced 2026-02-04 11:34:44 +08:00
MSCP_SSH_AUTH_PASSWORD passes a password, and MSCP_SSH_AUTH_PASSPHRASE passes a passphrase for publickey auth. They enable avoiding interactive password input. Test cases are also added.
45 lines
1.1 KiB
Docker
45 lines
1.1 KiB
Docker
FROM ubuntu:22.04
|
|
|
|
ARG DEBIAN_FRONTEND=noninteractive
|
|
RUN set -ex && apt-get update && apt-get install -y --no-install-recommends \
|
|
ca-certificates
|
|
|
|
# install pytest, and sshd for test
|
|
RUN apt-get install -y --no-install-recommends \
|
|
python3 python3-pip python3-dev openssh-server
|
|
|
|
RUN python3 -m pip install pytest
|
|
|
|
|
|
# preparation for sshd
|
|
RUN mkdir /var/run/sshd \
|
|
&& ssh-keygen -A \
|
|
&& ssh-keygen -f /root/.ssh/id_rsa -N "" \
|
|
&& cat /root/.ssh/id_rsa.pub > /root/.ssh/authorized_keys
|
|
|
|
# create test user
|
|
RUN useradd -m -d /home/test test \
|
|
&& echo "test:userpassword" | chpasswd \
|
|
&& mkdir -p /home/test/.ssh \
|
|
&& ssh-keygen -f /home/test/.ssh/id_rsa_test -N "keypassphrase" \
|
|
&& cat /home/test/.ssh/id_rsa_test.pub >> /home/test/.ssh/authorized_keys \
|
|
&& chown -R test:test /home/test \
|
|
&& chown -R test:test /home/test/.ssh
|
|
|
|
|
|
ARG mscpdir="/mscp"
|
|
|
|
COPY . ${mscpdir}
|
|
|
|
# install build dependency
|
|
RUN ${mscpdir}/scripts/install-build-deps.sh
|
|
|
|
|
|
# build
|
|
RUN cd ${mscpdir} \
|
|
&& rm -rf build \
|
|
&& cmake -B build \
|
|
&& cd ${mscpdir}/build \
|
|
&& make -j 2 \
|
|
&& make install
|