go-client

command
v4.1.4+incompatible Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 5, 2019 License: Apache-2.0 Imports: 8 Imported by: 0

README

Teleport Auth Go Client

Introduction

Teleport Auth Server has an API which hasn't been officially documented (yet). Both tctl and tsh use the Auth API to:

  • Request certificates (tsh login or tctl auth sign)
  • Add nodes and users (tctl users and tctl nodes)
  • Manipulate cluster state (tctl resources)

API Authentication

Auth API clients must perform two-way authentication using x509 certificates:

  1. They have to validate the auth server x509 certificate to make sure the API endpoint can be trusted.
  2. They must offer their x509 certificate, which has been previously issued by the auth sever.

Demo

This little program demonstrates how to:

  1. Authenticate against the Auth API using two certificates.
  2. Makes an API call to issue a server join token, i.e. an equivalent of tctl node add

Before running it, you have to use tctl to issue an API certificate, i.e. on the auth server:

$ tctl auth export --type=tls > /var/lib/teleport/ca.cert

This should work as long as you execute it on the same auth server:

$ go get github.com/gravitational/teleport/lib/auth
$ go run main.go

TODO

This Auth server API allows clients to "jump" to API endpoints of all trusted clusters connected to it. We need to add a snippet how to enumerate trusted clusters and connect to their API endpoints later.

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL