Skip to content

Commit

Permalink
feat: add support for saml encrypted assertions (#1752)
Browse files Browse the repository at this point in the history
By setting the `GOTRUE_SAML_ALLOW_ENCRYPTED_ASSERTIONS` to `true` the
SAML private key will be advertised as usable with encryption too.

Encrypted assertions are fairly rare these days because:

- They make it very hard to debug what's going on.
- HTTPS is the default protocol on the web for over 10 years, including
in intranets.

**Why not use a separate key?**

The underlying library [does not support
it](https://pkg.go.dev/github.com/crewjam/[email protected]/samlsp#Options)
and there are no significant cryptological issues using the same RSA key
for signatures and encryption, especially in a limited setting like
this.
  • Loading branch information
hf authored Sep 2, 2024
1 parent bf276ab commit c5480ef
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 4 deletions.
6 changes: 2 additions & 4 deletions internal/api/saml.go
Original file line number Diff line number Diff line change
Expand Up @@ -80,16 +80,14 @@ func (a *API) SAMLMetadata(w http.ResponseWriter, r *http.Request) error {
}
}

// don't advertize the encryption keys as it makes it much difficult to debug
// requests / responses, and does not increase security since assertions are
// not "private" and not necessary to be hidden from the browser
for i := range metadata.SPSSODescriptors {
spd := &metadata.SPSSODescriptors[i]

var keyDescriptors []saml.KeyDescriptor

for _, kd := range spd.KeyDescriptors {
if kd.Use == "signing" {
// only advertize key as usable for encryption if allowed
if kd.Use == "signing" || (a.config.SAML.AllowEncryptedAssertions && kd.Use == "encryption") {
keyDescriptors = append(keyDescriptors, kd)
}
}
Expand Down
5 changes: 5 additions & 0 deletions internal/conf/saml.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import (
type SAMLConfiguration struct {
Enabled bool `json:"enabled"`
PrivateKey string `json:"-" split_words:"true"`
AllowEncryptedAssertions bool `json:"allow_encrypted_assertions" split_words:"true"`
RelayStateValidityPeriod time.Duration `json:"relay_state_validity_period" split_words:"true"`

RSAPrivateKey *rsa.PrivateKey `json:"-"`
Expand Down Expand Up @@ -111,6 +112,10 @@ func (c *SAMLConfiguration) PopulateFields(externalURL string) error {
},
}

if c.AllowEncryptedAssertions {
certTemplate.KeyUsage = certTemplate.KeyUsage | x509.KeyUsageDataEncipherment
}

certDer, err := x509.CreateCertificate(nil, certTemplate, certTemplate, c.RSAPublicKey, c.RSAPrivateKey)
if err != nil {
return err
Expand Down

0 comments on commit c5480ef

Please sign in to comment.