36 Star 396 Fork 71

GVPrancher / rancher

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
tls.go 1.23 KB
一键复制 编辑 原始数据 按行查看 历史
Darren Shepherd 提交于 2018-06-19 13:05 . Make dynamic TLS reusable
package tls
import (
"fmt"
"io/ioutil"
"github.com/rancher/types/apis/management.cattle.io/v3"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
func ReadTLSConfig(acmeDomains []string) (*v3.ListenConfig, error) {
var err error
lc := &v3.ListenConfig{
TypeMeta: metav1.TypeMeta{
Kind: "ListenConfig",
APIVersion: "management.cattle.io/v3",
},
ObjectMeta: metav1.ObjectMeta{
Name: "cli-config",
},
Enabled: true,
}
lc.CACerts, err = readPEM("/etc/rancher/ssl/cacerts.pem")
if err != nil {
return nil, err
}
lc.Key, err = readPEM("/etc/rancher/ssl/key.pem")
if err != nil {
return nil, err
}
lc.Cert, err = readPEM("/etc/rancher/ssl/cert.pem")
if err != nil {
return nil, err
}
lc.Mode = "https"
if len(acmeDomains) > 0 {
lc.Mode = "acme"
lc.Domains = acmeDomains
}
valid := false
if lc.Key != "" && lc.Cert != "" {
valid = true
} else if lc.Key == "" && lc.Cert == "" {
valid = true
}
if !valid {
return nil, fmt.Errorf("invalid SSL configuration found, please set cert/key, cert/key/cacerts, cacerts only, or none")
}
return lc, nil
}
func readPEM(path string) (string, error) {
content, err := ioutil.ReadFile(path)
if err != nil {
return "", nil
}
return string(content), nil
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/rancher/rancher.git
git@gitee.com:rancher/rancher.git
rancher
rancher
rancher
v2.0.7-rc4

搜索帮助

344bd9b3 5694891 D2dac590 5694891