| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 | FROM alpine:3.22COPY --chown=root:root server/ssh /etc/ssh/COPY --chown=root:root server/script /opt/sshnetCOPY user/sshnet /home/sshnet/.sshRUN apk update && apk upgrade --no-cache && \    apk add --no-cache syslog-ng && \    # install and configure sshd    apk add --no-cache openssh && \    # install openssh-server-pam to allow for keyboard-interactive authentication    apk add --no-cache openssh-server-pam && \    # must not use * for dos2unix parameter otherwise it tries to process folders too and fails    dos2unix /etc/ssh/ssh*key && \    chmod 400 /etc/ssh/ssh*key && \    sed -i 's/#PasswordAuthentication yes/PasswordAuthentication yes/' /etc/ssh/sshd_config && \    sed -i 's/#LogLevel\s*INFO/LogLevel DEBUG3/' /etc/ssh/sshd_config && \    # Set the default RSA key    echo 'HostKey /etc/ssh/ssh_host_rsa_key' >> /etc/ssh/sshd_config && \    echo 'TrustedUserCAKeys /etc/ssh/user-ca.pub' >> /etc/ssh/sshd_config && \    chmod 646 /etc/ssh/sshd_config && \    # install and configure sudo    apk add --no-cache sudo && \    addgroup sudo && \    # allow root to run any command    echo 'root ALL=(ALL) ALL' > /etc/sudoers && \    # allow everyone in the 'sudo' group to run any command without a password    echo '%sudo ALL=(ALL) NOPASSWD:ALL' >> /etc/sudoers && \    # add user to run most of the integration tests    adduser -D sshnet && \    passwd -u sshnet && \    echo 'sshnet:ssh4ever' | chpasswd && \    # must not use * for dos2unix parameter otherwise it tries to process folders too and fails    dos2unix /home/sshnet/.ssh/*_key* && \    chown -R sshnet:sshnet /home/sshnet && \    chmod -R 700 /home/sshnet/.ssh && \    chmod -R 644 /home/sshnet/.ssh/authorized_keys && \    # add user to administer container (update configs, restart sshd)    adduser -D sshnetadm && \    passwd -u sshnetadm && \    echo 'sshnetadm:ssh4ever' | chpasswd && \    addgroup sshnetadm sudo && \    dos2unix /opt/sshnet/* && \    # install shadow package; we use chage command in this package to expire/unexpire password of the sshnet user    apk add --no-cache shadow && \    # allow us to use telnet command; we use this in the remote port forwarding tests    apk --no-cache add busybox-extras && \    # install full-fledged ps command    apk add --no-cache procpsEXPOSE 22 22ENTRYPOINT ["/opt/sshnet/start.sh"]
 |