Skip to content

Commit

Permalink
lazily PrecomputeKeys everywhere
Browse files Browse the repository at this point in the history
  • Loading branch information
nklaassen committed Sep 6, 2024
1 parent e093a2a commit c3d894b
Show file tree
Hide file tree
Showing 4 changed files with 14 additions and 16 deletions.
3 changes: 0 additions & 3 deletions lib/auth/auth.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,6 @@ import (
"github.com/gravitational/teleport/entitlements"
"github.com/gravitational/teleport/lib/auth/authclient"
"github.com/gravitational/teleport/lib/auth/keystore"
"github.com/gravitational/teleport/lib/auth/native"
"github.com/gravitational/teleport/lib/auth/userloginstate"
wanlib "github.com/gravitational/teleport/lib/auth/webauthn"
wantypes "github.com/gravitational/teleport/lib/auth/webauthntypes"
Expand Down Expand Up @@ -375,8 +374,6 @@ func NewServer(cfg *InitConfig, opts ...ServerOption) (*Server, error) {
if !modules.GetModules().Features().GetEntitlement(entitlements.HSM).Enabled {
return nil, fmt.Errorf("AWS KMS support requires a license with the HSM feature enabled: %w", ErrRequiresEnterprise)
}
} else {
native.PrecomputeKeys()
}
keyStore, err := keystore.NewManager(context.Background(), &cfg.KeyStoreConfig, keystoreOpts)
if err != nil {
Expand Down
10 changes: 10 additions & 0 deletions lib/auth/sessions.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ package auth
import (
"context"
"crypto"
"crypto/rsa"
"time"

"github.com/gravitational/trace"
Expand All @@ -36,6 +37,7 @@ import (
apievents "github.com/gravitational/teleport/api/types/events"
"github.com/gravitational/teleport/api/utils/keys"
"github.com/gravitational/teleport/entitlements"
"github.com/gravitational/teleport/lib/auth/native"
"github.com/gravitational/teleport/lib/cryptosuites"
"github.com/gravitational/teleport/lib/defaults"
dtconfig "github.com/gravitational/teleport/lib/devicetrust/config"
Expand Down Expand Up @@ -253,6 +255,14 @@ func (a *Server) newWebSession(
if err != nil {
return nil, nil, trace.Wrap(err)
}
if _, isRSA := sshKey.Public().(*rsa.PublicKey); isRSA {
// Ensure the native package is precomputing RSA keys if we ever
// generate one. [native.PrecomputeKeys] is idempotent.
// Doing this lazily easily handles changing signature algorithm
// suites and won't start precomputing keys if they are never needed
// (a major benefit in tests).
native.PrecomputeKeys()
}
}

sessionTTL := req.SessionTTL
Expand Down
9 changes: 4 additions & 5 deletions lib/reversetunnel/cache.go
Original file line number Diff line number Diff line change
Expand Up @@ -142,11 +142,10 @@ func (c *certificateCache) generateHostCert(ctx context.Context, principals []st

if _, isRSA := hostKey.Public().(*rsa.PublicKey); isRSA {
// Ensure the native package is precomputing RSA keys if we ever
// generate one. [native.PrecomputeKeys] is idempotent. Do this here
// instead of in newHostCertificateCache for 2 reasons:
// 1. This will handle changes to the configured algorithm suite.
// 2. This won't start precomputing keys if a host key is never actually
// needed, which can be a major benefit in tests.
// generate one. [native.PrecomputeKeys] is idempotent.
// Doing this lazily easily handles changing signature algorithm suites
// and won't start precomputing keys if they are never needed (a major
// benefit in tests).
native.PrecomputeKeys()
}

Expand Down
8 changes: 0 additions & 8 deletions lib/service/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,6 @@ import (
"github.com/gravitational/teleport/lib/auth/authclient"
"github.com/gravitational/teleport/lib/auth/keygen"
"github.com/gravitational/teleport/lib/auth/machineid/machineidv1"
"github.com/gravitational/teleport/lib/auth/native"
"github.com/gravitational/teleport/lib/auth/state"
"github.com/gravitational/teleport/lib/auth/storage"
"github.com/gravitational/teleport/lib/authz"
Expand Down Expand Up @@ -1053,13 +1052,6 @@ func waitAndReload(ctx context.Context, sigC <-chan os.Signal, cfg servicecfg.Co
func NewTeleport(cfg *servicecfg.Config) (*TeleportProcess, error) {
var err error

// auth and proxy benefit from precomputing keys since they can experience spikes in key
// generation due to web session creation and recorded session creation respectively.
// for all other agents precomputing keys consumes excess resources.
if cfg.Auth.Enabled || cfg.Proxy.Enabled {
native.PrecomputeKeys()
}

// Before we do anything reset the SIGINT handler back to the default.
system.ResetInterruptSignalHandler()

Expand Down

0 comments on commit c3d894b

Please sign in to comment.