This directory contains a Dockerfile that builds the OQS OpenSSH fork, that allows to establish a quantum safe SSH connection with quantum safe key exchange and authentication.
Install Docker and run the following commands:
-
Make sure to change to the
openssh
directory. The commanddocker build -t oqs-openssh-img .
will build the image with the name
oqs-openssh-img
. Should this command fail with some permission issue, see below for a solution. -
Start an OpenSSH server with post-quantum cryptography support by running
docker run --name oqs-openssh-server -dit --rm oqs-openssh-img
-
Connect to that server running
docker exec --user oqs -it oqs-openssh-server ssh oqs@localhost
-
Accept the host key and authenticate with the default password
oqs.pw
-
To clean up, exit the ssh session with
exit
and rundocker stop oqs-openssh-server
to stop (and remove) the container.
Note: Due to the --rm
option the container will be removed as soon as it is stopped, it may be omitted to keep the container. But because we're just testing its basic functionality right now this is not required.
It is possible that the docker build [...]
command fails with something like Got permission denied while trying to connect to the Docker daemon socket [...]
. That is because the active user is not a member of the docker
group yet. To fix this, run
usermod -aG docker <user>
newgrp docker
The first command adds user <user>
(yourself) to the group docker
, and the second simulates a logout/login, so you don't have to do a re-login.
The Dockerfile
- obtains all source code required for building the quantum safe cryptography (QSC) algorithms and the QSC-enabled version of OpenSSH (7.9-2020-08_p1)
- builds all libraries and applications
- creates a second user
oqs
with the default passwordoqs.pw
- by default starts the openssh daemon*
- by default creates host keys based on the config file
sshd_config
* - by default creates identity keys based on the config file
ssh_config
*
*those steps are executed when the image is started.
Note for the interested: The build process is two-stage with the final image only retaining all executables, libraries and include-files to utilize OQS-enabled openssh.
Currently the used version of liboqs is 0.4.0. Be aware that upon changing this version, which can be done in the Dockerfile, the default algorithms may change. If this is the case sshd_config/sshd_config must be updated accordingly.
Detailed information on how to use the image is available in the separate file USAGE.md.
The Dockerfile provided allows for some customization of the image built. Those build arguments can be used at buildtime via the flag --build-arg
, e.g. docker build --build-arg INSTALL_DIR="/some/directory/" -t name-of-image .
.
This sets the location of the software installation including the configuration files and host keys inside the docker image.
By default this is /opt/oqs-ssh
. When it is changed, every occurrence of this default path is replaced with it at build time. That means that for example the ssh_config
file copied to the container can differ from the original ssh_config because it is edited during build.
This permits changing the build options for the underlying library with the quantum safe algorithms. All possible options are documented here.
By default, the image is built such as to have maximum portability regardless of CPU type and optimizations available, i.e. to run on the widest possible range of cloud machines.
This allows to configure some additional build options for building OQS-OpenSSH. Those options, if specified, will be appended to the ./configure
command as shown here. Some parameters are configured as follows in the Dockerfile as they are essential to the build:
./configure \
--with-libs=-lm \
--prefix=${INSTALL_DIR} \
--sysconfdir=${INSTALL_DIR} \
--with-liboqs-dir=/opt/ossh-src/oqs \
--with-mantype=man \
${OPENSSH_BUILD_OPTIONS}
These parameters will be overridden if specified again in OPENSSH_BUILD_OPTIONS
.
/opt/ossh-src/oqs
is the location the intermediate build in the Dockerfile writes the compiled liboqs binaries to. This should not be changed, as it does not influence the final docker image.
Allow setting parameters to make
operation, e.g., -j nnn
where nnn
defines the number of jobs run in parallel during build.
The default is conservative and known not to overload normal machines (default: -j 2
). If one has a very powerful (many cores, >64GB RAM) machine, passing larger numbers (or only -j
for maximum parallelism) speeds up the build considerably.
This build argument defines the make install target of the OpenSSH installation is defined. Default is install-nokeys
, thus no keys are generated when installing. Another valid value would be install
which generates keys when installing. Note that this may take quite some time depending on the enabled algorithms, here you find more information about what algorithms are enabled by default.
Attention: Even more importantly, generating the keys at build time would result in all containers spawning from this image having the same host and identity keys, which would mean a severe security risk!
Defaults to oqs
. The docker file creates a non-root user during build. The purpose of this user is to be a login-user for incoming ssh connections. This docker image is designed to be used in a practical way (although not considered production ready, see Limitations in USAGE.md), and having root logging in for simply establishing a connection in a production environment is not considered practical.
Defaults to oqs.pw
. This is the password for the OQS_USER
. A password is needed to enable the authentication method 'password' for ssh.