From fb7f57a8dff77edcaea1271d79943c6cd17f69df Mon Sep 17 00:00:00 2001 From: max furman Date: Wed, 27 Jul 2022 23:30:00 -0700 Subject: [PATCH] Add attribute to disable SSH Hosts list API --- authority/config/config.go | 21 +++++++++++---------- authority/ssh.go | 3 +++ 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/authority/config/config.go b/authority/config/config.go index c764e8f9..71f92830 100644 --- a/authority/config/config.go +++ b/authority/config/config.go @@ -92,16 +92,17 @@ type ASN1DN struct { // cas.Options. type AuthConfig struct { *cas.Options - AuthorityID string `json:"authorityId,omitempty"` - DeploymentType string `json:"deploymentType,omitempty"` - Provisioners provisioner.List `json:"provisioners,omitempty"` - Admins []*linkedca.Admin `json:"-"` - Template *ASN1DN `json:"template,omitempty"` - Claims *provisioner.Claims `json:"claims,omitempty"` - Policy *policy.Options `json:"policy,omitempty"` - DisableIssuedAtCheck bool `json:"disableIssuedAtCheck,omitempty"` - Backdate *provisioner.Duration `json:"backdate,omitempty"` - EnableAdmin bool `json:"enableAdmin,omitempty"` + AuthorityID string `json:"authorityId,omitempty"` + DeploymentType string `json:"deploymentType,omitempty"` + Provisioners provisioner.List `json:"provisioners,omitempty"` + Admins []*linkedca.Admin `json:"-"` + Template *ASN1DN `json:"template,omitempty"` + Claims *provisioner.Claims `json:"claims,omitempty"` + Policy *policy.Options `json:"policy,omitempty"` + DisableIssuedAtCheck bool `json:"disableIssuedAtCheck,omitempty"` + Backdate *provisioner.Duration `json:"backdate,omitempty"` + EnableAdmin bool `json:"enableAdmin,omitempty"` + DisableSSHHostsListAPI bool `json:"disableSSHHostsListAPI,omitempty"` } // init initializes the required fields in the AuthConfig if they are not diff --git a/authority/ssh.go b/authority/ssh.go index 1fd7f2e8..04f9c2ac 100644 --- a/authority/ssh.go +++ b/authority/ssh.go @@ -602,6 +602,9 @@ func (a *Authority) CheckSSHHost(ctx context.Context, principal, token string) ( // GetSSHHosts returns a list of valid host principals. func (a *Authority) GetSSHHosts(ctx context.Context, cert *x509.Certificate) ([]config.Host, error) { + if a.GetConfig().AuthorityConfig.DisableSSHHostsListAPI { + return nil, errs.New(http.StatusNotFound, "ssh hosts list api disabled") + } if a.sshGetHostsFunc != nil { hosts, err := a.sshGetHostsFunc(ctx, cert) return hosts, errs.Wrap(http.StatusInternalServerError, err, "getSSHHosts")