1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- package credentials
- import (
- "crypto/tls"
- "net/url"
- "google.golang.org/grpc/grpclog"
- )
- func SPIFFEIDFromState(state tls.ConnectionState) *url.URL {
- if len(state.PeerCertificates) == 0 || len(state.PeerCertificates[0].URIs) == 0 {
- return nil
- }
- var spiffeID *url.URL
- for _, uri := range state.PeerCertificates[0].URIs {
- if uri == nil || uri.Scheme != "spiffe" || uri.Opaque != "" || (uri.User != nil && uri.User.Username() != "") {
- continue
- }
-
- if len(uri.String()) > 2048 {
- grpclog.Warning("invalid SPIFFE ID: total ID length larger than 2048 bytes")
- return nil
- }
- if len(uri.Host) == 0 || len(uri.RawPath) == 0 || len(uri.Path) == 0 {
- grpclog.Warning("invalid SPIFFE ID: domain or workload ID is empty")
- return nil
- }
- if len(uri.Host) > 255 {
- grpclog.Warning("invalid SPIFFE ID: domain length larger than 255 characters")
- return nil
- }
-
- if len(state.PeerCertificates[0].URIs) > 1 {
- grpclog.Warning("invalid SPIFFE ID: multiple URI SANs")
- return nil
- }
- spiffeID = uri
- }
- return spiffeID
- }
|