2018-11-01 07:46:13 +00:00
# Step Certificates
2020-07-20 21:10:36 +00:00
`step-ca` is an online certificate authority for secure, automated certificate management. It's the server counterpart to the [`step` CLI tool ](https://github.com/smallstep/cli ).
2019-02-19 00:00:16 +00:00
2020-07-09 01:42:43 +00:00
You can use it to:
2020-07-20 21:10:36 +00:00
- Issue X.509 certificates for your internal infrastructure:
- HTTPS certificates that [work in browsers ](https://smallstep.com/blog/step-v0-8-6-valid-HTTPS-certificates-for-dev-pre-prod.html ) ([RFC5280](https://tools.ietf.org/html/rfc5280) and [CA/Browser Forum ](https://cabforum.org/baseline-requirements-documents/ ) compliance)
- TLS certificates for VMs, containers, APIs, mobile clients, database connections, printers, wifi networks, toaster ovens...
- Client certificates to [enable mutual TLS (mTLS) ](https://smallstep.com/hello-mtls ) in your infra. mTLS is an optional feature in TLS where both client and server authenticate each other. Why add the complexity of a VPN when you can safely use mTLS over the public internet?
- Issue SSH certificates:
- For people, in exchange for single sign-on ID tokens
- For hosts, in exchange for cloud instance identity documents
- Easily automate certificate management:
- It's an ACME v2 server
- It has a JSON API
- It comes with a [Go wrapper ](./examples#user-content-basic-client-usage )
- ... and there's a [command-line client ](https://github.com/smallstep/cli ) you can use in scripts!
Whatever your use case, `step-ca` is easy to use and hard to misuse, thanks to [safe, sane defaults ](./docs/defaults.md ).
2019-08-28 18:58:53 +00:00
**Questions? Find us [on gitter ](https://gitter.im/smallstep/community ).**
2020-07-09 01:42:43 +00:00
[Website ](https://smallstep.com/certificates ) |
2019-04-30 00:50:30 +00:00
[Documentation ](#documentation ) |
2019-02-19 00:00:16 +00:00
[Installation Guide ](#installation-guide ) |
2020-07-20 21:10:36 +00:00
[Quickstart ](#quickstart ) |
2019-02-19 00:00:16 +00:00
[Getting Started ](./docs/GETTING_STARTED.md ) |
[Contribution Guide ](./docs/CONTRIBUTING.md )
2020-07-20 21:10:36 +00:00
[![GitHub release ](https://img.shields.io/github/release/smallstep/certificates.svg )](https://github.com/smallstep/certificates/releases/latest)
2019-02-19 00:00:16 +00:00
[![CA Image ](https://images.microbadger.com/badges/image/smallstep/step-ca.svg )](https://microbadger.com/images/smallstep/step-ca)
[![Go Report Card ](https://goreportcard.com/badge/github.com/smallstep/certificates )](https://goreportcard.com/report/github.com/smallstep/certificates)
[![Build Status ](https://travis-ci.com/smallstep/certificates.svg?branch=master )](https://travis-ci.com/smallstep/certificates)
[![License ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
[![CLA assistant ](https://cla-assistant.io/readme/badge/smallstep/certificates )](https://cla-assistant.io/smallstep/certificates)
2018-11-01 07:46:13 +00:00
2019-02-16 01:47:20 +00:00
[![GitHub stars ](https://img.shields.io/github/stars/smallstep/certificates.svg?style=social )](https://github.com/smallstep/certificates/stargazers)
[![Twitter followers ](https://img.shields.io/twitter/follow/smallsteplabs.svg?label=Follow&style=social )](https://twitter.com/intent/follow?screen_name=smallsteplabs)
2019-08-28 18:58:53 +00:00
## Features
2020-07-20 21:10:36 +00:00
### 🦾 A fast, stable, flexible private CA
Setting up a *public key infrastructure* (PKI) is out of reach for many small teams. `step-ca` makes it easier.
2019-08-28 18:58:53 +00:00
2020-07-20 21:10:36 +00:00
- Choose key types (RSA, ECDSA, EdDSA) and lifetimes to suit your needs
- [Short-lived certificates ](https://smallstep.com/blog/passive-revocation.html ) with automated enrollment, renewal, and passive revocation
2020-07-09 01:42:43 +00:00
- Capable of high availability (HA) deployment using [root federation ](https://smallstep.com/blog/step-v0.8.3-federation-root-rotation.html ) and/or multiple intermediaries
2020-07-20 21:10:36 +00:00
- Can operate as [an online intermediate CA ](./docs/questions.md#i-already-have-pki-in-place-can-i-use-this-with-my-own-root-certificate ) for an existing root CA
- [Badger, BoltDB, and MySQL database backends ](https://github.com/smallstep/certificates/blob/master/docs/database.md )
2019-08-28 18:58:53 +00:00
2020-07-20 21:10:36 +00:00
### ⚙️ Many ways to automate
2019-08-28 18:58:53 +00:00
2020-07-20 21:10:36 +00:00
There are several ways to authorize a request with the CA and establish a chain of trust that suits your flow.
2020-07-09 01:42:43 +00:00
2020-07-20 21:10:36 +00:00
You can issue certificates in exchange for:
- [ACME challenge responses ](#your-own-private-acme-server ) from any ACMEv2 client
- [OAuth OIDC single sign-on tokens ](https://smallstep.com/blog/easily-curl-services-secured-by-https-tls.html ), eg:
- ID tokens from Okta, GSuite, Azure AD, Auth0.
- ID tokens from an OAuth OIDC service that you host, like [Keycloak ](https://www.keycloak.org/ ) or [Dex ](https://github.com/dexidp/dex )
- [Cloud instance identity documents ](https://smallstep.com/blog/embarrassingly-easy-certificates-on-aws-azure-gcp/ ), for VMs on AWS, GCP, and Azure
2020-07-09 01:42:43 +00:00
- [Single-use, short-lived JWK tokens ](https://smallstep.com/docs/design-document/#jwk-provisioner ) issued by your CD tool — Puppet, Chef, Ansible, Terraform, etc.
2020-07-20 21:10:36 +00:00
- A trusted X.509 certificate (X5C provisioner)
- Expiring SSH host certificates needing rotation (the SSHPOP provisioner)
- Learn more in our [provisioner documentation ](./docs/provisioners.md )
2019-09-17 16:52:36 +00:00
2020-07-20 21:10:36 +00:00
### 🏔 Your own private ACME server
2020-07-09 01:42:43 +00:00
2020-07-20 21:10:36 +00:00
ACME is the protocol used by Let's Encrypt to automate the issuance of HTTPS certificates. It's _super easy_ to issue certificates to any ACMEv2 ([RFC8555](https://tools.ietf.org/html/rfc8555)) client.
2020-07-09 01:42:43 +00:00
- [Use ACME in development & pre-production ](https://smallstep.com/blog/private-acme-server/#local-development--pre-production )
2020-07-13 16:28:46 +00:00
- Supports the most popular [ACME challenge types ](https://letsencrypt.org/docs/challenge-types/ ):
- For `http-01` , place a token at a well-known URL to prove that you control the web server
- For `dns-01` , add a `TXT` record to prove that you control the DNS record set
- For `tls-alpn-01` , respond to the challenge at the TLS layer ([as Caddy does](https://caddy.community/t/caddy-supports-the-acme-tls-alpn-challenge/4860)) to prove that you control the web server
2020-07-09 01:42:43 +00:00
- Works with any ACME client. We've written examples for:
- [certbot ](https://smallstep.com/blog/private-acme-server/#certbotuploadsacme-certbotpng-certbot-example )
- [acme.sh ](https://smallstep.com/blog/private-acme-server/#acmeshuploadsacme-acme-shpng-acmesh-example )
- [Caddy ](https://smallstep.com/blog/private-acme-server/#caddyuploadsacme-caddypng-caddy-example )
- [Traefik ](https://smallstep.com/blog/private-acme-server/#traefikuploadsacme-traefikpng-traefik-example )
- [Apache ](https://smallstep.com/blog/private-acme-server/#apacheuploadsacme-apachepng-apache-example )
- [nginx ](https://smallstep.com/blog/private-acme-server/#nginxuploadsacme-nginxpng-nginx-example )
- Get certificates programmatically using ACME, using these libraries:
- [`lego` ](https://github.com/go-acme/lego ) for Golang ([example usage](https://smallstep.com/blog/private-acme-server/#golanguploadsacme-golangpng-go-example))
- certbot's [`acme` module ](https://github.com/certbot/certbot/tree/master/acme ) for Python ([example usage](https://smallstep.com/blog/private-acme-server/#pythonuploadsacme-pythonpng-python-example))
- [`acme-client` ](https://github.com/publishlab/node-acme-client ) for Node.js ([example usage](https://smallstep.com/blog/private-acme-server/#nodejsuploadsacme-node-jspng-nodejs-example))
2020-07-13 16:28:46 +00:00
- Our own [`step` CLI tool ](github.com/smallstep/cli ) is also an ACME client!
2020-07-09 01:42:43 +00:00
- See our [ACME docs ](https://smallstep.com/blog/private-acme-server/ ) for more
2019-08-28 18:58:53 +00:00
2020-07-20 21:10:36 +00:00
### 👩🏽💻 An online SSH Certificate Authority
2019-09-16 04:27:04 +00:00
2020-07-20 21:10:36 +00:00
- Delegate SSH authentication to `step-ca` by using [SSH certificates ](https://smallstep.com/blog/use-ssh-certificates/ ) instead of public keys and `authorized_keys` files
- For user certificates, [connect SSH to your single sign-on provider ](https://smallstep.com/blog/diy-single-sign-on-for-ssh/ ), to improve security with short-lived certificates and MFA (or other security policies) via any OAuth OIDC provider.
- For host certificates, improve security, [eliminate TOFU warnings ](https://smallstep.com/blog/use-ssh-certificates/ ), and set up automated host certificate renewal.
2019-09-16 04:27:04 +00:00
2020-07-20 21:10:36 +00:00
### 🤓 A general purpose PKI tool, via [`step` CLI](https://github.com/smallstep/cli) [integration](https://smallstep.com/docs/cli/ca/)
2019-08-28 18:58:53 +00:00
- Generate key pairs where they're needed so private keys are never transmitted across the network
2020-07-20 21:10:36 +00:00
- [Authenticate and obtain a certificate ](https://smallstep.com/docs/cli/ca/certificate/ ) using any provisioner supported by `step-ca`
2019-08-28 18:58:53 +00:00
- Securely [distribute root certificates ](https://smallstep.com/docs/cli/ca/root/ ) and [bootstrap ](https://smallstep.com/docs/cli/ca/bootstrap/ ) PKI relying parties
- [Renew ](https://smallstep.com/docs/cli/ca/renew/ ) and [revoke ](https://smallstep.com/docs/cli/ca/revoke/ ) certificates issued by `step-ca`
2020-07-20 21:10:36 +00:00
- [Install root certificates ](https://smallstep.com/docs/cli/certificate/install/ ) on your machine and browsers, so your CA is trusted
2019-08-28 18:58:53 +00:00
- [Inspect ](https://smallstep.com/docs/cli/certificate/inspect/ ) and [lint ](https://smallstep.com/docs/cli/certificate/lint/ ) certificates
2019-02-19 00:00:16 +00:00
## Installation Guide
2018-11-01 07:46:13 +00:00
2019-02-19 00:00:16 +00:00
These instructions will install an OS specific version of the `step-ca` binary on
2018-11-01 07:46:13 +00:00
your local machine.
2019-02-19 00:00:16 +00:00
### Mac OS
2018-11-01 07:46:13 +00:00
2020-07-20 21:10:36 +00:00
Install `step` and `step-ca` together, via [Homebrew ](https://brew.sh/ ):
2018-11-01 07:46:13 +00:00
2020-07-09 01:42:43 +00:00
```
$ brew install step
```
2018-11-01 07:46:13 +00:00
2019-02-19 00:00:16 +00:00
### Linux
2018-11-21 03:46:22 +00:00
2020-07-20 21:10:36 +00:00
> **Note:** Though it's not required, you will probably also want the [`step` CLI tool](https://github.com/smallstep/cli#installation-guide).
2020-07-09 01:42:43 +00:00
2019-04-11 23:02:13 +00:00
#### Debian
2019-08-28 18:58:53 +00:00
1. [Optional] Install `step` .
2018-11-21 03:46:22 +00:00
2020-07-09 01:42:43 +00:00
Download the Debian package from the
[latest `step` release ](https://github.com/smallstep/cli/releases/latest ):
2018-11-21 03:46:22 +00:00
2019-02-19 00:00:16 +00:00
```
2019-10-24 07:53:30 +00:00
$ wget https://github.com/smallstep/cli/releases/download/vX.Y.Z/step-cli_X.Y.Z_amd64.deb
2019-02-19 00:00:16 +00:00
```
2018-11-21 03:46:22 +00:00
2019-02-19 00:00:16 +00:00
Install the Debian package:
2018-11-21 03:46:22 +00:00
2018-11-21 06:30:13 +00:00
```
2019-10-24 07:53:30 +00:00
$ sudo dpkg -i step-cli_X.Y.Z_amd64.deb
2018-11-21 06:30:13 +00:00
```
2018-11-21 03:46:22 +00:00
2019-08-28 18:58:53 +00:00
2. Install `step-ca` .
2018-11-21 03:46:22 +00:00
2020-07-09 01:42:43 +00:00
Download the Debian package from the [latest `step-ca` release ](https://github.com/smallstep/certificates/releases/latest ):
2018-11-21 03:46:22 +00:00
2018-11-21 06:30:13 +00:00
```
2019-10-24 07:53:30 +00:00
$ wget https://github.com/smallstep/certificates/releases/download/vX.Y.Z/step-certificates_X.Y.Z_amd64.deb
2018-11-21 06:30:13 +00:00
```
2018-11-21 03:46:22 +00:00
2019-02-19 00:00:16 +00:00
Install the Debian package:
2018-11-21 03:46:22 +00:00
2018-11-21 06:30:13 +00:00
```
2019-02-19 00:00:16 +00:00
$ sudo dpkg -i step-certificates_X.Y.Z_amd64.deb
2018-11-21 06:30:13 +00:00
```
2018-11-21 03:46:22 +00:00
2019-04-11 23:02:13 +00:00
#### Arch Linux
We are using the [Arch User Repository ](https://aur.archlinux.org ) to distribute
`step` binaries for Arch Linux.
2019-08-28 18:58:53 +00:00
* [Optional] The `step` binary tarball can be found [here ](https://aur.archlinux.org/packages/step-cli-bin/ ).
2019-04-11 23:02:13 +00:00
* The `step-ca` binary tarball can be found [here ](https://aur.archlinux.org/packages/step-ca-bin/ ).
You can use [pacman ](https://www.archlinux.org/pacman/ ) to install the packages.
2020-06-03 13:57:35 +00:00
#### RHEL/CentOS
2020-06-16 03:19:44 +00:00
1. [Optional] Install `step` .
2020-06-03 13:57:35 +00:00
2020-07-09 01:42:43 +00:00
Download the Linux tarball from the
[latest `step` release ](https://github.com/smallstep/cli/releases/latest ):
2020-06-03 13:57:35 +00:00
```
2020-06-16 03:19:44 +00:00
$ wget -O step-cli.tar.gz https://github.com/smallstep/cli/releases/download/vX.Y.Z/step_linux_X.Y.Z_amd64.tar.gz
2020-06-03 13:57:35 +00:00
```
2020-06-16 03:19:44 +00:00
Install `step` by unzipping and copying the executable over to `/usr/bin` :
2020-06-03 13:57:35 +00:00
```
2020-06-16 03:19:44 +00:00
$ tar -xf step-cli.tar.gz
$ sudo cp step_X.Y.Z/bin/step /usr/bin
2020-06-03 13:57:35 +00:00
```
2. Install `step-ca` .
2020-07-09 01:42:43 +00:00
Download the Linux package from the [latest `step-ca` release ](https://github.com/smallstep/certificates/releases/latest ):
2020-06-03 13:57:35 +00:00
```
$ wget -O step-ca.tar.gz https://github.com/smallstep/cli/releases/download/vX.Y.Z/step_linux_X.Y.Z_amd64.tar.gz
```
2020-06-16 03:19:44 +00:00
Install `step-ca` by unzipping and copying the executable over to `/usr/bin` :
2020-06-03 13:57:35 +00:00
```
$ tar -xf step-ca.tar.gz
2020-06-16 03:19:44 +00:00
$ sudo cp step-certificates_X.Y.Z/bin/step-ca /usr/bin
2020-06-03 13:57:35 +00:00
```
2020-06-16 03:19:44 +00:00
See the [`systemctl` setup section ](./docs/GETTING_STARTED.md#systemctl ) for a
guide on configuring `step-ca` as a daemon.
2020-06-03 13:57:35 +00:00
2019-08-28 18:58:53 +00:00
### Kubernetes
We publish [helm charts ](https://hub.helm.sh/charts/smallstep/step-certificates ) for easy installation on kubernetes:
```
helm install step-certificates
```
> <a href="https://github.com/smallstep/autocert"><img width="25%" src="https://raw.githubusercontent.com/smallstep/autocert/master/autocert-logo.png"></a>
>
> If you're using Kubernetes, make sure you [check out
> autocert](https://github.com/smallstep/autocert): a kubernetes add-on that builds on `step
> certificates` to automatically inject TLS/HTTPS certificates into your containers.
2020-07-20 21:10:36 +00:00
### Docker
See our [Docker getting started guide ](./docs/docker.md )
2019-04-11 23:02:13 +00:00
### Test
2018-11-01 07:46:13 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ step version< / b >
2019-08-28 18:58:53 +00:00
Smallstep CLI/0.10.0 (darwin/amd64)
Release Date: 2019-04-30 19:01 UTC
2019-04-11 23:04:40 +00:00
< b > $ step-ca version< / b >
2019-08-28 18:58:53 +00:00
Smallstep CA/0.10.0 (darwin/amd64)
2019-08-31 00:58:52 +00:00
Release Date: 2019-04-30 19:02 UTC< / code > < / pre >
2018-11-13 20:47:07 +00:00
2019-02-19 00:00:16 +00:00
## Quickstart
2018-11-13 20:47:07 +00:00
2019-02-19 00:00:16 +00:00
In the following guide we'll run a simple `hello` server that requires clients
2019-08-28 18:58:53 +00:00
to connect over an authorized and encrypted channel using HTTPS. `step-ca`
will issue certificates to our server, allowing it to authenticate and encrypt
2020-07-20 21:10:36 +00:00
communication.
![Animated terminal showing step certificates in practice ](https://github.com/smallstep/certificates/raw/master/docs/images/step-ca-2-legged.gif )
Let's get started!
2018-11-12 22:19:30 +00:00
2019-02-19 00:00:16 +00:00
### Prerequisites
2018-11-12 22:19:30 +00:00
2019-02-19 00:00:16 +00:00
* [`step` ](#installation-guide )
* [golang ](https://golang.org/doc/install )
2018-11-12 22:19:30 +00:00
2019-02-19 00:00:16 +00:00
### Let's get started!
2018-11-12 22:19:30 +00:00
2019-08-28 18:58:53 +00:00
#### 1. Run `step ca init` to create your CA's keys & certificates and configure `step-ca`:
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ step ca init< / b >
2019-08-28 18:58:53 +00:00
✔ What would you like to name your new PKI? (e.g. Smallstep): < b > Example Inc.< / b >
✔ What DNS names or IP addresses would you like to add to your new CA? (e.g. ca.smallstep.com[,1.1.1.1,etc.]): < b > localhost< / b >
✔ What address will your new CA listen at? (e.g. :443): < b > 127.0.0.1:8080< / b >
✔ What would you like to name the first provisioner for your new CA? (e.g. you@smallstep.com): < b > bob@example.com< / b >
✔ What do you want your password to be? [leave empty and we'll generate one]: < b > abc123< / b >
Generating root certificate...
all done!
Generating intermediate certificate...
all done!
✔ Root certificate: /Users/bob/src/github.com/smallstep/step/.step/certs/root_ca.crt
✔ Root private key: /Users/bob/src/github.com/smallstep/step/.step/secrets/root_ca_key
✔ Root fingerprint: 702a094e239c9eec6f0dcd0a5f65e595bf7ed6614012825c5fe3d1ae1b2fd6ee
✔ Intermediate certificate: /Users/bob/src/github.com/smallstep/step/.step/certs/intermediate_ca.crt
✔ Intermediate private key: /Users/bob/src/github.com/smallstep/step/.step/secrets/intermediate_ca_key
✔ Default configuration: /Users/bob/src/github.com/smallstep/step/.step/config/defaults.json
✔ Certificate Authority configuration: /Users/bob/src/github.com/smallstep/step/.step/config/ca.json
2019-08-31 00:58:52 +00:00
Your PKI is ready to go. To generate certificates for individual services see 'step help ca'.< / code > < / pre >
2018-11-13 20:47:07 +00:00
2019-08-28 18:58:53 +00:00
This command will:
2018-11-12 22:19:30 +00:00
2019-08-28 18:58:53 +00:00
- Generate [password protected ](https://github.com/smallstep/certificates/blob/master/docs/GETTING_STARTED.md#passwords ) private keys for your CA to sign certificates
- Generate a root and [intermediate signing certificate ](https://security.stackexchange.com/questions/128779/why-is-it-more-secure-to-use-intermediate-ca-certificates ) for your CA
- Create a JSON configuration file for `step-ca` (see [getting started ](./docs/GETTING_STARTED.md ) for details)
2018-11-12 22:19:30 +00:00
2019-08-28 18:58:53 +00:00
You can find these artifacts in `$STEPPATH` (or `~/.step` by default).
2018-11-12 22:19:30 +00:00
2019-08-28 18:58:53 +00:00
#### 2. Start `step-ca`:
2018-11-12 22:19:30 +00:00
2019-08-28 18:58:53 +00:00
You'll be prompted for your password from the previous step, to decrypt the CA's private signing key:
2018-11-12 22:19:30 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ step-ca $(step path)/config/ca.json< / b >
2019-08-28 18:58:53 +00:00
Please enter the password to decrypt /Users/bob/src/github.com/smallstep/step/.step/secrets/intermediate_ca_key: < b > abc123< / b >
2019-08-31 00:58:52 +00:00
2019/02/18 13:28:58 Serving HTTPS on 127.0.0.1:8080 ...< / code > < / pre >
2018-11-01 07:46:13 +00:00
2019-08-28 18:58:53 +00:00
#### 3. Copy our `hello world` golang server.
2018-11-13 20:47:07 +00:00
2019-08-28 18:58:53 +00:00
```
$ cat > srv.go < < EOF
package main
import (
"net/http"
"log"
)
func HiHandler(w http.ResponseWriter, req *http.Request) {
w.Header().Set("Content-Type", "text/plain")
w.Write([]byte("Hello, world!\n"))
}
func main() {
http.HandleFunc("/hi", HiHandler)
err := http.ListenAndServeTLS(":8443", "srv.crt", "srv.key", nil)
if err != nil {
log.Fatal(err)
}
}
EOF
```
2018-11-13 20:47:07 +00:00
2019-08-28 18:58:53 +00:00
#### 4. Get an identity for your server from the Step CA.
2018-11-13 20:47:07 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ step ca certificate localhost srv.crt srv.key< / b >
2019-08-28 18:58:53 +00:00
✔ Key ID: rQxROEr7Kx9TNjSQBTETtsu3GKmuW9zm02dMXZ8GUEk (bob@example.com)
✔ Please enter the password to decrypt the provisioner key: abc123
✔ CA: https://localhost:8080/1.0/sign
✔ Certificate: srv.crt
✔ Private Key: srv.key
< b > $ step certificate inspect --bundle srv.crt< / b >
Certificate:
Data:
Version: 3 (0x2)
Serial Number: 140439335711218707689123407681832384336 (0x69a7a1d7f6f22f68059d2d9088307750)
Signature Algorithm: ECDSA-SHA256
Issuer: CN=Example Inc. Intermediate CA
Validity
Not Before: Feb 18 21:32:35 2019 UTC
Not After : Feb 19 21:32:35 2019 UTC
Subject: CN=localhost
...
Certificate:
Data:
Version: 3 (0x2)
Serial Number: 207035091234452090159026162349261226844 (0x9bc18217bd560cf07db23178ed90835c)
Signature Algorithm: ECDSA-SHA256
Issuer: CN=Example Inc. Root CA
Validity
Not Before: Feb 18 21:27:21 2019 UTC
Not After : Feb 15 21:27:21 2029 UTC
Subject: CN=Example Inc. Intermediate CA
2019-08-31 00:58:52 +00:00
...< / code > < / pre >
2018-11-13 20:47:07 +00:00
2019-08-28 18:58:53 +00:00
Note that `step` and `step-ca` handle details like [certificate bundling ](https://smallstep.com/blog/everything-pki.html#intermediates-chains-and-bundling ) for you.
2018-11-01 07:46:13 +00:00
2019-08-28 18:58:53 +00:00
#### 5. Run the simple server.
2018-11-01 07:46:13 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ go run srv.go & < / b > < / code > < / pre >
2018-11-21 06:30:13 +00:00
2019-08-28 18:58:53 +00:00
#### 6. Get the root certificate from the Step CA.
2019-02-19 00:00:16 +00:00
2019-08-28 18:58:53 +00:00
In a new Terminal window:
2019-02-19 00:00:16 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ step ca root root.crt< / b >
The root certificate has been saved in root.crt.< / code > < / pre >
2019-02-19 00:00:16 +00:00
2019-08-28 18:58:53 +00:00
#### 7. Make an authenticated, encrypted curl request to your server using HTTP over TLS.
2018-11-21 06:30:13 +00:00
2019-08-31 00:58:52 +00:00
< pre > < code > < b > $ curl --cacert root.crt https://localhost:8443/hi< / b >
Hello, world!< / code > < / pre >
2019-02-19 00:00:16 +00:00
*All Done!*
Check out the [Getting Started ](./docs/GETTING_STARTED.md ) guide for more examples
and best practices on running Step CA in production.
2018-11-21 06:30:13 +00:00
2019-02-19 00:00:16 +00:00
## Documentation
2018-11-21 06:30:13 +00:00
2019-04-30 00:50:30 +00:00
Documentation can be found in a handful of different places:
2018-11-21 06:30:13 +00:00
2019-04-30 00:51:35 +00:00
1. The [docs ](./docs/README.md ) sub-repo has an index of documentation and tutorials.
2018-11-21 06:30:13 +00:00
2020-02-08 11:31:49 +00:00
2. On the command line with `step help ca xxx` where `xxx` is the subcommand
you are interested in. Ex: `step help ca provisioner list` .
2018-11-21 06:30:13 +00:00
2019-04-30 00:50:30 +00:00
3. On the web at https://smallstep.com/docs/certificates.
2019-06-11 15:28:43 +00:00
4. On your browser by running `step help --http=:8080 ca` from the command line
2019-04-30 00:50:30 +00:00
and visiting http://localhost:8080.
2018-11-21 06:30:13 +00:00
2019-06-11 15:28:43 +00:00
2020-07-20 21:10:36 +00:00
## Feedback?
2018-11-21 06:30:13 +00:00
* Tell us what you like and don't like about managing your PKI - we're eager to
help solve problems in this space.
2020-07-20 21:10:36 +00:00
* Tell us about a feature you'd like to see - open an issue, [ask on gitter ](https://gitter.im/smallstep/community ), or hit us up on [Twitter ](https://twitter.com/smallsteplabs ).