Skip to content

Simulated KMS for a QKD Network. Supports both symmetric and oblivious keys.

License

Notifications You must be signed in to change notification settings

diogoftm/simulated-kms

 
 

Repository files navigation

build workflow

Description

This project provides a reference implementation to the ETSI GS QKD 014 v1.1.1 standard.

This fork - changes

This version changes the source code in order to simulate the creation of oblivious keys. Note that, in a multicast scenario, all the slave SAEs have different oblivious keys with a distinct relationship with the original key.

Installation

Reference OS

Ubuntu 22.04.1 LTS
Pop!_OS 22.04 LTS

This implementation has been developed and tested on Ubuntu 22.04.1 LTS and Pop!_OS 22.04 LTS. While no OS specific components are present in this implementation, no guarantees are made that it works on other OSs. If you encounter issues deploying this implementation on another OS, reach out and we will try our best to make it work on your setup.

Requirements

Running

make reqs

should install all requirements.

Required OS packages

The server requires the following packages to be installed:

  • pkg-config
  • libssl-dev

On Ubuntu, these can be installed using

sudo apt install pkg-config libssl-dev

Database management packages

The Diesel rust library is used to handle database operations, including migrations. Diesel has a dependency on the libpq library which needs to be installed before installing the diesel_cli utility. On Ubuntu, the libpq library can be installed using

sudo apt install libpq-dev

To install the diesel command line interface with support for PostgreSQL databases only, run the command

cargo install diesel_cli --no-default-features --features postgres

To confirm that installation was successful, run the command

diesel --version

The output should be similar to

diesel 2.0.0

Set up

Start database

Run

make db_start

This will create and launch a docker container running a postgres database running at DATABASE_URL.

Diesel migrations

To run the diesel migration SQL scripts and set-up the database, run the following command:

make db_migration

This command will execute the up.sql scripts in the migrations folder that have not yet been executed on the database.

ETSI QKD 014 Standard

The ETSI QKD 014 standard requires that mutual TLS (mTLS) authentication is performed. This requires both the server and the client to authenticate each other. Most commonly, only the server's certificate is authenticated by the client, with the server doing no such authentication. Due to the sensitivity of the application, mTLS is required.

Secure Application Entity (SAE)

The SAE, is referred to the client, because it is the entity that will be issuing the requests.

Key Management Entity (KME)

The KME, is the application that this server aims to emulate. It will be referred to as the server.

Certificates

A root CA will be generated and used to sign both the SAE (client) and KME (server) certificates. This is to emulate a certificate that is signed by a trusted Certificate Authority (CA).

Generate a self-signed certificate

The generation of a certificate involves the

  • Generation of a private key,
  • Generation of a certificate signing request, and
  • Signing of the certificate.

The generation of a private key and self-signed certificate can be done using a single command. The nodes option is set such that the private key is not passphrase protected.

openssl req -x509           \
    -newkey rsa:4096        \
    -days 3650              \
    -nodes                  \
    -keyout test.key        \
    -out test.crt           \
    -subj "/CN=test_123456" \
    -addext "subjectAltName=IP:127.0.0.1"

Certificate generation

All the below commands are part of the included makefile in the certs directory. Certificates can be generated by issuing the command

make certs

Root CA

Generate a password protected root certificate.

openssl req -x509                                            \
    -newkey rsa:4096                                         \
    -days 365                                                \
    -subj "/C=MT/CN=www.merqury.eu/O=Merqury\ Cybersecurity" \
    -keyout root.key                                         \
    -out root.crt

KME Certificate

Generate the KME private key and a Certificate Signing Request (CSR).

openssl req                                          \
    -newkey rsa:4096                                 \
    -nodes                                           \
    -days 365                                        \
    -subj "/C=MT/O=Key Management Ltd/CN=kme_123456" \
    -keyout kme.key                                  \
    -out kme.csr

Create an extensions file to specify the alternative names

echo "subjectAltName = IP:127.0.0.1" >> kme.ext

Sign the certificate using the root CA's key

openssl x509 -req    \
    -in kme.csr      \
    -CA root.crt     \
    -CAkey root.key  \
    -set_serial 01   \
    -days 365        \
    -extfile kme.ext \
    -out kme.crt

SAE Certificate

Generate the sae private key and a Certificate Signing Request (CSR).

openssl req                                              \
    -newkey rsa:4096                                     \
    -nodes                                               \
    -days 365                                            \
    -subj "/C=MT/O=Secure Application Ltd/CN=sae_123456" \
    -keyout sae.key                                      \
    -out sae.csr

Create an extensions file to specify the alternative names

echo "subjectAltName = IP:127.0.0.1" >> sae.ext

Sign the certificate using the root CA's key

openssl x509 -req    \
    -in sae.csr      \
    -CA root.crt     \
    -CAkey root.key  \
    -set_serial 01   \
    -days 365        \
    -extfile sae.ext \
    -out sae.crt

Utilities

To view the private key contents

openssl pkey -in test.key -text -noout

To extract the public key from the private key

openssl pkey -in test.key -pubout -out server-public.key

To view the Certificate Signing Request (CSR) contents

openssl req -text -in test.csr -noout

To examine the certificate

openssl x509 -text -in test.crt -noout

Environment variables

Variable name Description
ETSI_014_REF_IMPL_IP_ADDR Ip address the server will bind to.
ETSI_014_REF_IMPL_PORT_NUM The port number the server listens on.
ETSI_014_REF_IMPL_DB_URL Database URL.
ETSI_014_REF_IMPL_TLS_ROOT_CRT Root CA certificate.
ETSI_014_REF_IMPL_TLS_PRIVATE_KEY Private key.
ETSI_014_REF_IMPL_TLS_CER TLS certificate (public key).
ETSI_014_REF_IMPL_NUM_WORKER_THREADS Number of threads the server will use.

Examples

The examples folder contains multiple bash scripts that show the user how to launch and interact with the reference implementation. The enc_keys.sh and dec_keys.sh scripts send requests using curl to the web service. The run_server.sh script launches a server instance with the required environment variables.

The Makefile allows the user to run these scripts in a coordinated way.

make run_server

Runs the server using the same database created with make db_start.

make get_enc_key KEY_TYPE=X

Retrieves an encryption key. X!=1 for symmetric keys. X==1 for oblivious keys.

make post_enc_key KEY_TYPE=X

Retrieves 3 encryption keys. X!=1 for symmetric keys. X==1 for oblivious keys.

make get_dec_key KEY=XXX

Retrieves the decryption key with key-id XXX.

make post_get_key KEYS='XXX YYY ZZZ ...'

Retrieves the decryption keys with IDs XXX, YYY, ZZZ and so on.

License

© 2023 Merqury Cybersecurity Ltd.

This project is licensed under the GNU Affero General Public License v3.0 only. If you would like to use this product under a different license, kindly contact us on info@merqury.eu.

Acknowledgements

This software has been developed in the projects EQUO (European QUantum ecOsystems) which is funded by the European Commission in the Digital Europe Programme under the grant agreement No 101091561 and PRISM (Physical Security for Public Infrastructure in Malta) which is co-funded by the European Union under the Digital Europe Programme grant agreement number 101111875.

About

Simulated KMS for a QKD Network. Supports both symmetric and oblivious keys.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Rust 78.5%
  • Makefile 16.2%
  • PLpgSQL 3.2%
  • Dockerfile 2.1%