Skip to content

Commit

Permalink
Add display name to SSO MFA device; Add SSO MFA device to SSO challenge.
Browse files Browse the repository at this point in the history
  • Loading branch information
Joerger committed Oct 22, 2024
1 parent f3801d7 commit 7fe308a
Show file tree
Hide file tree
Showing 9 changed files with 2,573 additions and 2,431 deletions.
1,306 changes: 684 additions & 622 deletions api/client/proto/authservice.pb.go

Large diffs are not rendered by default.

2 changes: 2 additions & 0 deletions api/proto/teleport/legacy/client/proto/authservice.proto
Original file line number Diff line number Diff line change
Expand Up @@ -1251,6 +1251,8 @@ message SSOChallenge {
string request_id = 1;
// RedirectUrl is an IdP redirect URL to initate the SSO MFA flow.
string redirect_url = 2;
// Device is the SSO device corresponding to the challenge.
types.SSOMFADevice device = 3;
}

// SSOResponse is a response to SSOChallenge.
Expand Down
2 changes: 2 additions & 0 deletions api/proto/teleport/legacy/types/types.proto
Original file line number Diff line number Diff line change
Expand Up @@ -3808,6 +3808,8 @@ message SSOMFADevice {
string connector_id = 1;
// connector_type is the type of the SSO connector.
string connector_type = 2;
// display_name is the display name of the SSO connector
string display_name = 3;
}

// WebauthnLocalAuth holds settings necessary for local webauthn use.
Expand Down
3,656 changes: 1,851 additions & 1,805 deletions api/types/types.pb.go

Large diffs are not rendered by default.

5 changes: 4 additions & 1 deletion lib/auth/sso_mfa.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,10 @@ import (

// beginSSOMFAChallenge creates a new SSO MFA auth request and session data for the given user and sso device.
func (a *Server) beginSSOMFAChallenge(ctx context.Context, user string, sso *types.SSOMFADevice, ssoClientRedirectURL string, ext *mfav1.ChallengeExtensions) (*proto.SSOChallenge, error) {
chal := new(proto.SSOChallenge)
chal := &proto.SSOChallenge{
Device: sso,
}

switch sso.ConnectorType {
case constants.SAML:
resp, err := a.CreateSAMLAuthRequestForMFA(ctx, types.SAMLAuthRequest{
Expand Down
28 changes: 27 additions & 1 deletion lib/client/weblogin.go
Original file line number Diff line number Diff line change
Expand Up @@ -460,7 +460,33 @@ type MFAAuthenticateChallenge struct {
// TOTPChallenge specifies whether TOTP is supported for this user.
TOTPChallenge bool `json:"totp_challenge"`
// SSOChallenge is an SSO MFA challenge.
SSOChallenge *proto.SSOChallenge `json:"sso_challenge"`
SSOChallenge *SSOChallenge `json:"sso_challenge"`
}

// SSOChallenge is a json compatible [proto.SSOChallenge].
type SSOChallenge struct {
RequestID string `json:"request_id,omitempty"`
RedirectURL string `json:"redirect_url,omitempty"`
Device *SSOMFADevice `json:"device"`
}

// SSOMFADevice is a json compatible [proto.SSOMFADevice].
type SSOMFADevice struct {
ConnectorID string `json:"connector_id,omitempty"`
ConnectorType string `json:"connector_type,omitempty"`
DisplayName string `json:"display_name,omitempty"`
}

func SSOChallengeFromProto(ssoChal *proto.SSOChallenge) *SSOChallenge {
return &SSOChallenge{
RequestID: ssoChal.RequestId,
RedirectURL: ssoChal.RedirectUrl,
Device: &SSOMFADevice{
ConnectorID: ssoChal.Device.ConnectorId,
ConnectorType: ssoChal.Device.ConnectorType,
DisplayName: ssoChal.Device.DisplayName,
},
}
}

// MFARegisterChallenge is an MFA register challenge sent on new MFA register.
Expand Down
1 change: 1 addition & 0 deletions lib/services/local/users.go
Original file line number Diff line number Diff line change
Expand Up @@ -1489,6 +1489,7 @@ func (s *IdentityService) getSSOMFADevice(ctx context.Context, user string) (*ty
Sso: &types.SSOMFADevice{
ConnectorId: cb.Connector.ID,
ConnectorType: cb.Connector.Type,
DisplayName: mfaConnector.GetDisplay(),
},
})
}
Expand Down
2 changes: 1 addition & 1 deletion lib/web/mfa.go
Original file line number Diff line number Diff line change
Expand Up @@ -488,7 +488,7 @@ func makeAuthenticateChallenge(protoChal *proto.MFAAuthenticateChallenge) *clien
chal.WebauthnChallenge = wantypes.CredentialAssertionFromProto(protoChal.WebauthnChallenge)
}
if protoChal.GetSSOChallenge() != nil {
chal.SSOChallenge = protoChal.GetSSOChallenge()
chal.SSOChallenge = client.SSOChallengeFromProto(protoChal.GetSSOChallenge())
}
return chal
}
2 changes: 1 addition & 1 deletion lib/web/terminal.go
Original file line number Diff line number Diff line change
Expand Up @@ -632,7 +632,7 @@ func newMFAPrompt(stream *terminal.WSStream) mfa.Prompt {
challenge.WebauthnChallenge = wantypes.CredentialAssertionFromProto(chal.WebauthnChallenge)
}
if chal.SSOChallenge != nil {
challenge.SSOChallenge = chal.SSOChallenge
challenge.SSOChallenge = client.SSOChallengeFromProto(chal.SSOChallenge)
}

if chal.WebauthnChallenge == nil && chal.SSOChallenge == nil {
Expand Down

0 comments on commit 7fe308a

Please sign in to comment.