2020-12-30 16:03:01 +00:00
|
|
|
package audit
|
|
|
|
|
2021-01-26 17:42:07 +00:00
|
|
|
import "crypto/tls"
|
2020-12-30 16:03:01 +00:00
|
|
|
|
2021-01-02 16:24:06 +00:00
|
|
|
var (
|
|
|
|
tlsToEntity = map[uint16]TLSVersion{
|
|
|
|
tls.VersionSSL30: TLSVersion_SSLv30,
|
|
|
|
tls.VersionTLS10: TLSVersion_TLS10,
|
|
|
|
tls.VersionTLS11: TLSVersion_TLS11,
|
|
|
|
tls.VersionTLS12: TLSVersion_TLS12,
|
|
|
|
tls.VersionTLS13: TLSVersion_TLS13,
|
|
|
|
}
|
2020-12-30 16:03:01 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type TLSDetails struct {
|
2021-01-26 17:42:07 +00:00
|
|
|
Version string
|
|
|
|
CipherSuite string
|
2020-12-30 16:03:01 +00:00
|
|
|
ServerName string
|
|
|
|
}
|
|
|
|
|
2021-01-26 17:42:07 +00:00
|
|
|
func TLSVersionToEntity(version uint16) TLSVersion {
|
|
|
|
if v, known := tlsToEntity[version]; known {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
return TLSVersion_SSLv30
|
|
|
|
}
|
|
|
|
|
2021-01-02 16:24:06 +00:00
|
|
|
func NewTLSDetailsFromProto(entity *TLSDetailsEntity) *TLSDetails {
|
|
|
|
if entity == nil {
|
|
|
|
return nil
|
|
|
|
}
|
2020-12-30 16:03:01 +00:00
|
|
|
|
2021-01-02 16:24:06 +00:00
|
|
|
return &TLSDetails{
|
2021-01-26 17:42:07 +00:00
|
|
|
Version: entity.GetVersion().String(),
|
|
|
|
CipherSuite: entity.GetCipherSuite(),
|
2021-01-02 16:24:06 +00:00
|
|
|
ServerName: entity.GetServerName(),
|
2020-12-30 16:03:01 +00:00
|
|
|
}
|
2021-01-02 16:24:06 +00:00
|
|
|
}
|
2020-12-30 16:03:01 +00:00
|
|
|
|
2021-01-02 16:24:06 +00:00
|
|
|
func (d TLSDetails) ProtoMessage() *TLSDetailsEntity {
|
2020-12-30 16:03:01 +00:00
|
|
|
return &TLSDetailsEntity{
|
2021-01-26 17:42:07 +00:00
|
|
|
Version: TLSVersion(TLSVersion_value[d.Version]),
|
|
|
|
CipherSuite: d.CipherSuite,
|
2020-12-30 16:03:01 +00:00
|
|
|
ServerName: d.ServerName,
|
|
|
|
}
|
|
|
|
}
|