This document will walk you through one way to generate a CA and self-signed certificate for use with Steward.
Two-way trust must be established between Steward and the Strategy Provider client for each request. To accomplish this, both the Server and Client will need TLS certificates and the CA certificate of the other party (Steward needs the client's CA, and the client needs Steward's CA). To make generating Steward's certificates easier, we've provided a convenience script called gen-certs.sh
which can be found here. The script takes one optional flag for the output location of the certificates and their signing keys. The client CA will be set by default to Seven Seas' CA for now.
- Ensure you have OpenSSL installed.
This script requires OpenSSL to be installed; it will not work with LibreSSL.
Note that LibreSSL still uses the binary name openssl
. You'll know if you have the wrong binary if openssl version
says "LibreSSL". This script was tested against version OpenSSL 1.1.1n
.
- Run the following command from the root of this repository
./gen-certs.sh -o some/output/location/
If you don't set the output path flag, certificates and keys will be created in the current working directory.
- Fill out the Server CA information
After running this command you run through a series of prompts. The first will be for information pertaining to the certificate authority like geographical location, email, etc. Set your CN to your domain name, and optionally set the OU for identification purposes. The rest of the fields can be safely left blank.
- Fill out the Server Certificate information
A similar set of prompts will ask for the same information for the Server (Steward) certificate which will be signed by the CA. As before, set your CN to your domain name, and optionally set the OU for identification purposes. Please leave the password blank. The rest of the fields can also be safely left blank.
- Provide your domain name
The final two prompts will ask for the domain name where Steward will be publically hosted. At least one of these MUST be set for Steward to start up with the certificate. Please do not use an IP address.
- (Optional) View your signed certificate
You can view your certificate plaintext with the following command:
openssl x509 -text -in <output_path>/server.crt
Valid TLS certificates will have "Version 3" near the top of the certificate plaintext. You should also see your domain name as a Subject Alternative Name.
- Test Steward with your certificate
You can use the test client certificates included in this repo to simulate a client connection to Steward. You'll need to create a TOML config file with the [server]
section containing the paths to your generated artifacts. See the configuration reference for more info. Your file will need to look something like this:
[server]
client_ca_cert_path = "integration_tests/tls/client/test_client_ca.crt"
server_cert_path = "<output_path>/server.crt"
server_key_path = "<output_path>/server_key_pkcs8.pem"
You'll then need to start Steward and then send a gRPC request to it.
To start steward run
steward -c <config_toml_path> start
If you see something like the following log messages, so far so good:
INFO steward::commands::cosmos_mode: Starting application
INFO steward::commands::cosmos_mode: listening on 0.0.0.0:5734
Then you'll need to send a gRPC request to the endpoint (in the case above, 0.0.0.0:5734).
You can use your client of preference. Here is an example using grpcurl
with the test client certs from this repo:
grpcurl -cert integration_tests/tls/client/test_client.crt \
-key integration_tests/tls/client/test_client_key_pkcs8.pem \
-cacert <output_path>/server_ca.crt \
-d '' \
<fqdn_of_server>:5734 \
steward.v1.ContractCall/Submit
When you send this request, if you get an error to establishing a connection, there is probably something wrong with your configuration or your certificates. If you get an error internal to the business logic of Steward, you know it's working.
An error like this one means the connection was established successfully:
# steward log
ERROR steward::cork: cork query client connection failed: transport error: error trying to connect: tcp connect error: Connection refused (os error 61)
# this is steward failing to connect to the Sommelier chain, which it would not be attempting
# if your client connection wasn't working.
# client log
ERROR:
Code: Internal
Message: failed to query chain to validate cellar id
- Provide your CA to the Strategy Provider
Add your information to the Steward Registry by following the steps outlined in the README there.