-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* Update TAG version to 1.11.0 * Add a guide for deploying TAG using Helm * Fix prose lint * Add auto-generated reference for TAG Helm chart * Apply suggestions from code review * Update TAG example role to v7 * Fix link to TAG Helm guide * Pin TAG Helm chart version Pins to the same version as TAG itself, Helm chart and TAG are versioned in lockstep * Call out the teleport Helm chart more explicitly * Bump TAG version to 1.13.0 Expecting it to be released by the time these docs go live. * Replace teleport-cluster parameters with Vars * Elaborate trust of the TAG CA in Teleport * Fix the marker style * Fix the link to teleport-cluster reference --------- Co-authored-by: Paul Gottschling <paul.gottschling@goteleport.com>
- Loading branch information
Showing
6 changed files
with
422 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
229 changes: 229 additions & 0 deletions
229
docs/pages/access-controls/access-graph/self-hosted-helm.mdx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,229 @@ | ||
--- | ||
title: Run Teleport Access Graph on Self-Hosted Clusters with Helm | ||
--- | ||
|
||
Using Access Graph with a self-hosted Teleport cluster requires | ||
setting up the Teleport Access Graph (TAG) service. | ||
TAG is a dedicated service which uses PostgreSQL as its backing storage | ||
and communicates with Auth Service and Proxy Service | ||
to collect information about resources and access. | ||
|
||
This guide will help you set up the TAG service | ||
in a Kubernetes cluster using a Helm Chart, | ||
and enable the Access Graph feature in your Teleport cluster. | ||
|
||
The full listing of supported parameters can be found in the [`teleport-access-graph` Helm chart reference](../../reference/helm-reference/teleport-access-graph.mdx). | ||
|
||
Teleport Access Graph is enabled by default for Teleport Team users. | ||
You can skip the setup process and start using Access Graph right away | ||
by signing up for a [Teleport Team trial](https://goteleport.com/signup/). | ||
|
||
## Prerequisites | ||
|
||
- Kubernetes >= v1.21 | ||
- Helm >= (=helm.version=) | ||
- A running Teleport Enterprise cluster v14.3.4 or later. | ||
- For the purposes of this guide, we assume that the Teleport cluster is set up | ||
[using the `teleport-cluster` Helm chart](../../deploy-a-cluster/helm-deployments.mdx) | ||
in the same Kubernetes cluster that will be used to deploy Teleport Access Graph . | ||
- An updated `license.pem` with Teleport Policy enabled. | ||
- A PostgreSQL database server v14 or later. | ||
- Access Graph needs a dedicated [database](https://www.postgresql.org/docs/current/sql-createdatabase.html) to store its data. | ||
The user that TAG connects to the database with needs to be the owner of this database, or have similar broad permissions: | ||
at least the `CREATE TABLE` privilege on the `public` schema, and the `CREATE SCHEMA` privilege. | ||
- Amazon RDS for PostgreSQL is supported. | ||
- A TLS certificate for the Access Graph service | ||
- The TLS certificate must be issued for "server authentication" key usage, | ||
and must contain a X.509 v3 `subjectAltName` extension with the Kubernetes service name for TAG | ||
(<span style="white-space: nowrap;">`teleport-access-graph.teleport-access-graph.svc.cluster.local`</span> by default). | ||
|
||
|
||
## Step 1/4. Add the Teleport Helm chart repository | ||
|
||
(!docs/pages/kubernetes-access/helm/includes/helm-repo-add.mdx!) | ||
|
||
## Step 2/4. Set up the Teleport Access Graph service | ||
|
||
You will need a copy of your Teleport cluster's host certificate authority (CA). | ||
TAG requires incoming connections to be authenticated via host certificates that the host CA issues to the Auth Service and Proxy Service. | ||
|
||
The host CA can be retrieved in one of the following ways: | ||
|
||
<Tabs> | ||
<TabItem label="Via curl"> | ||
```code | ||
$ curl 'https://<Var name="teleport.example.com" />/webapi/auth/export?type=tls-host' | ||
-----BEGIN CERTIFICATE----- | ||
MIIDqjCCApKgAwIBAgIQMIK8/WiQ/rUOrjlmB0IHVTANBgkqhkiG9w0BAQsFADBv | ||
<...> | ||
-----END CERTIFICATE----- | ||
``` | ||
</TabItem> | ||
|
||
<TabItem label="Via tctl"> | ||
```code | ||
$ tsh login --proxy=<Var name="teleport.example.com" /> | ||
$ tctl get cert_authorities --format=json \ | ||
| jq -r '.[] | select(.spec.type == "host") | .spec.active_keys.tls[].cert' \ | ||
| base64 -d | ||
-----BEGIN CERTIFICATE----- | ||
MIIDqjCCApKgAwIBAgIQMIK8/WiQ/rUOrjlmB0IHVTANBgkqhkiG9w0BAQsFADBv | ||
<...> | ||
-----END CERTIFICATE----- | ||
``` | ||
</TabItem> | ||
</Tabs> | ||
|
||
Then, create the namespace and required secrets for the TAG deployment. | ||
You can skip the final command if you are instead using cert-manager to issue the certificate, | ||
or otherwise have already provisioned the TLS certificate for Teleport Access Graph in your Kubernetes cluster. | ||
|
||
```code | ||
$ kubectl create namespace teleport-access-graph | ||
$ kubectl -n teleport-access-graph create secret generic teleport-access-graph-postgres \ | ||
--from-literal uri="postgres://access_graph_user:my_password@db.example.com:5432/access_graph_db?sslmode=require" | ||
$ kubectl -n teleport-access-graph create secret tls teleport-access-graph-tls --cert=./certs/cert.crt --key=./certs/cert.key | ||
``` | ||
|
||
The above commands assume that you have the TLS certificate and private key for the TAG server stored under the `./certs` directory. | ||
|
||
<Details title="Generating TLS certificates for development"> | ||
The following script can be used to quickly generate a certificate authority and server TLS certificate for deploying TAG. | ||
|
||
```sh | ||
#!/usr/bin/env bash | ||
|
||
set -e | ||
|
||
mkdir -p ./certs | ||
cd ./certs | ||
|
||
openssl genrsa -aes256 -out ca.key 4096 | ||
openssl req -x509 -new -key ca.key -sha256 -days 3652 -out ca.crt -subj '/CN=root' | ||
openssl req -new -out cert.csr -newkey rsa:4096 -nodes -keyout cert.key -subj '/CN=Access Graph' | ||
openssl x509 -req -in cert.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out cert.crt -days 3652 -sha256 \ | ||
-extfile <(printf 'extendedKeyUsage = serverAuth, clientAuth\nsubjectAltName = DNS:teleport-access-graph.teleport-access-graph.svc.cluster.local') | ||
|
||
echo "Certificates issued successfully" | ||
``` | ||
|
||
The script will ask to input the same password 4 times: | ||
twice to create and confirm the password to encrypt the CA private key material with, | ||
then once to use the private key to self-sign the CA certificate, | ||
and finally once to use for signing the TAG server certificate. | ||
|
||
Please note that this script is only provided for proof-of-concept deployments, | ||
and may not follow the best security practices. | ||
</Details> | ||
|
||
After provisioning the secrets, create the following file named `tag-values.yaml` file for the TAG deployment, | ||
replacing the value under the `clusterHostCAs` key with the Teleport Host CA certificate retrieved previously. | ||
|
||
```yaml | ||
postgres: | ||
secretName: "teleport-access-graph-postgres" | ||
|
||
tls: | ||
# You may need to change this value if using cert-manager or other means | ||
# to provision TLS certificates for your Kubernetes workloads. | ||
existingSecretName: "teleport-access-graph-tls" | ||
|
||
clusterHostCAs: | ||
# Replace this with the certificate retrieved in Step 1. | ||
# `clusterHostCAs` is an array of multiline YAML strings, `- |` must not be removed, and the indentation must be kept. | ||
- | | ||
-----BEGIN CERTIFICATE----- | ||
MIIDqjCCApKgAwIBAgIQMIK8/WiQ/rUOrjlmB0IHVTANBgkqhkiG9w0BAQsFADBv | ||
<...> | ||
-----END CERTIFICATE----- | ||
``` | ||
Finally, deploy the TAG service using Helm: | ||
```code | ||
$ helm install -n teleport-access-graph -f tag-values.yaml --version (=access_graph.version=) teleport-access-graph teleport/teleport-access-graph | ||
$ kubectl -n teleport-access-graph rollout status deployment/teleport-access-graph # Wait for the deployment to succeed | ||
``` | ||
|
||
## Step 3/4. Update the Teleport Auth Service configuration | ||
|
||
To enable connectivity between the Teleport Auth Service and the Teleport Access Graph Service, | ||
the Auth Service configuration needs to be updated with: | ||
- The TAG service address | ||
- The path to the CA which issued the TAG service TLS certificate. | ||
- This path must refer to a volume containing the CA, mounted on the Teleport pods. | ||
- Specifying the CA certificate file can be skipped if you are using a CA that is already trusted by the Teleport cluster | ||
(e.g. via the [`tls.existingCASecretName` option](../../reference/helm-reference/teleport-cluster.mdx#tlsexistingcasecretname)), | ||
or if the certificate was issued by a CA included in the [Mozilla CA Certificate List](https://wiki.mozilla.org/CA/Included_Certificates). | ||
|
||
Create a ConfigMap containing the CA certificate as follows: | ||
|
||
```code | ||
$ kubectl -n <Var name="teleport-cluster-namespace" /> create configmap teleport-access-graph-ca \ | ||
--from-file=ca.pem=./certs/ca.crt | ||
``` | ||
|
||
Then, update the values for the deployment of the `teleport-cluster` Helm chart as follows: | ||
|
||
```yaml | ||
auth: | ||
teleportConfig: | ||
# <...> | ||
|
||
# Add a section for configuring the Teleport Access Graph connection. | ||
access_graph: | ||
enabled: true | ||
endpoint: teleport-access-graph.teleport-access-graph.svc.cluster.local:443 | ||
# Omit the `ca` key if your Teleport cluster already trusts the issuing CA. | ||
ca: /var/run/access-graph/ca.pem | ||
|
||
# Provide the TAG CA to the Teleport Auth Service as a volume. | ||
# Omit all of the below if your Teleport cluster already trusts the issuing CA. | ||
extraVolumes: | ||
- name: tag-ca | ||
configMap: | ||
name: teleport-access-graph-ca | ||
|
||
extraVolumeMounts: | ||
- name: tag-ca | ||
mountPath: /var/run/access-graph | ||
``` | ||
If not using the `teleport-cluster` Helm chart, you will need to do the equivalent changes to your Teleport cluster deployment: | ||
- Add the `access_graph:` section at the top-level of the YAML config file for the Teleport Auth Service. | ||
- Mount the created ConfigMap as a volume so that the Auth Service can read the CA certificate. | ||
|
||
Finally, redeploy the Helm chart (assuming the values are stored in `values-teleport.yaml`). | ||
Once the Auth Service changes succeed, restart the Proxy Service. | ||
|
||
```code | ||
$ helm upgrade -n <Var name="teleport-cluster-namespace" /> -f values-teleport.yaml \ | ||
--version <version> <Var name="teleport-cluster-deployment-name" /> teleport/teleport-cluster | ||
$ kubectl -n <Var name="teleport-cluster-namespace" /> rollout status deployment/teleport-auth # Wait for the deployment to succeed | ||
$ kubectl -n <Var name="teleport-cluster-namespace" /> rollout restart deployment/teleport-proxy | ||
$ kubectl -n <Var name="teleport-cluster-namespace" /> rollout status deployment/teleport-proxy # Wait for the deployment to succeed | ||
``` | ||
|
||
## Step 4/4. View the Access Graph in the Web UI | ||
|
||
You can find the Access Graph in the "Access Management" tab in the Web UI. | ||
![Access Management menu item](../../../img/access-graph/menu-item.png) | ||
|
||
To access the interface, your user must have a role that allows `list` and `read` verbs on the `access_graph` resource, e.g.: | ||
|
||
```yaml | ||
kind: role | ||
version: v7 | ||
metadata: | ||
name: my-role | ||
spec: | ||
allow: | ||
rules: | ||
- resources: | ||
- access_graph | ||
verbs: | ||
- list | ||
- read | ||
``` | ||
|
||
The preset `editor` role has the required permissions by default. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.