2019-08-20 07:01:01 +08:00
|
|
|
package tls
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
2022-08-09 19:36:47 +08:00
|
|
|
"sort"
|
|
|
|
|
"strings"
|
2019-08-20 07:01:01 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
// ParseCiphers returns a `[]uint16` by received `[]string` key that represents ciphers from crypto/tls.
|
|
|
|
|
// If some of ciphers in received list doesn't exists ParseCiphers returns nil with error
|
|
|
|
|
func ParseCiphers(ciphers []string) ([]uint16, error) {
|
|
|
|
|
suites := []uint16{}
|
|
|
|
|
|
|
|
|
|
for _, cipher := range ciphers {
|
2021-12-01 05:46:46 +08:00
|
|
|
v, ok := tlsCipherMap[cipher]
|
|
|
|
|
if !ok {
|
2019-08-20 07:01:01 +08:00
|
|
|
return nil, fmt.Errorf("unsupported cipher %q", cipher)
|
|
|
|
|
}
|
2021-12-01 05:46:46 +08:00
|
|
|
suites = append(suites, v)
|
2019-08-20 07:01:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return suites, nil
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ParseTLSVersion returns a `uint16` by received version string key that represents tls version from crypto/tls.
|
2020-05-14 15:41:58 +08:00
|
|
|
// If version isn't supported ParseTLSVersion returns 0 with error
|
2019-08-20 07:01:01 +08:00
|
|
|
func ParseTLSVersion(version string) (uint16, error) {
|
|
|
|
|
if v, ok := tlsVersionMap[version]; ok {
|
|
|
|
|
return v, nil
|
|
|
|
|
}
|
2022-08-09 19:36:47 +08:00
|
|
|
|
|
|
|
|
var available []string
|
|
|
|
|
for n := range tlsVersionMap {
|
|
|
|
|
available = append(available, n)
|
|
|
|
|
}
|
|
|
|
|
sort.Strings(available)
|
|
|
|
|
return 0, fmt.Errorf("unsupported version %q (available: %s)", version, strings.Join(available, ","))
|
2019-08-20 07:01:01 +08:00
|
|
|
}
|