Skip to content

Commit

Permalink
perf: improve the usage of certificates (#475)
Browse files Browse the repository at this point in the history
we need to specify the usage of certificates of yurt-tunnel components clearly.

Refs #410
  • Loading branch information
ke-jobs authored Sep 17, 2021
1 parent 1aa9f4b commit 427972f
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 10 deletions.
25 changes: 18 additions & 7 deletions pkg/yurttunnel/pki/certmanager/certmanager.go
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,13 @@ func NewYurttunnelServerCertManager(
fmt.Sprintf(constants.YurttunnelServerCertDir, projectinfo.GetServerName()),
constants.YurttunneServerCSRCN,
[]string{constants.YurttunneServerCSROrg, constants.YurttunnelCSROrg},
dnsNames, ips)
dnsNames,
[]certificates.KeyUsage{
certificates.UsageKeyEncipherment,
certificates.UsageDigitalSignature,
certificates.UsageServerAuth,
},
ips)
}

// NewYurttunnelAgentCertManager creates a certificate manager for
Expand All @@ -109,6 +115,11 @@ func NewYurttunnelAgentCertManager(
constants.YurttunnelAgentCSRCN,
[]string{constants.YurttunnelCSROrg},
[]string{os.Getenv("NODE_NAME")},
[]certificates.KeyUsage{
certificates.UsageKeyEncipherment,
certificates.UsageDigitalSignature,
certificates.UsageClientAuth,
},
[]net.IP{net.ParseIP(nodeIP)})
}

Expand All @@ -120,7 +131,9 @@ func newCertManager(
certDir,
commonName string,
organizations,
dnsNames []string, ipAddrs []net.IP) (certificate.Manager, error) {
dnsNames []string,
keyUsages []certificates.KeyUsage,
ipAddrs []net.IP) (certificate.Manager, error) {
certificateStore, err :=
store.NewFileStoreWrapper(componentName, certDir, certDir, "", "")
if err != nil {
Expand All @@ -142,11 +155,9 @@ func newCertManager(
ClientFn: func(current *tls.Certificate) (clicert.CertificateSigningRequestInterface, error) {
return clientset.CertificatesV1beta1().CertificateSigningRequests(), nil
},
SignerName: certificates.LegacyUnknownSignerName,
GetTemplate: getTemplate,
Usages: []certificates.KeyUsage{
certificates.UsageAny,
},
SignerName: certificates.LegacyUnknownSignerName,
GetTemplate: getTemplate,
Usages: keyUsages,
CertificateStore: certificateStore,
})
if err != nil {
Expand Down
4 changes: 2 additions & 2 deletions pkg/yurttunnel/pki/pki.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ import (
"k8s.io/client-go/util/certificate"
)

// GenTGenTLSConfigUseCertMgrAndCertPool generates a TLS configuration
// GenTLSConfigUseCertMgrAndCertPool generates a TLS configuration
// using the given certificate manager and x509 CertPool
func GenTLSConfigUseCertMgrAndCertPool(
m certificate.Manager,
Expand Down Expand Up @@ -110,7 +110,7 @@ func GenRootCertPool(kubeConfig, caFile string) (*x509.CertPool, error) {
return GenCertPoolUseCA(caFile)
}

// GenTGenTLSConfigUseCertMgrAndCA generates a TLS configuration based on the
// GenTLSConfigUseCertMgrAndCA generates a TLS configuration based on the
// given certificate manager and the CA file
func GenTLSConfigUseCertMgrAndCA(
m certificate.Manager,
Expand Down
2 changes: 1 addition & 1 deletion test/e2e/yurt/yurt.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ func Register() {
spec := apiv1.PodSpec{}
container := apiv1.Container{}
spec.HostNetwork = true
spec.NodeSelector = map[string]string{"alibabacloud.com/is-edge-worker": "true"}
spec.NodeSelector = map[string]string{"openyurt.io/is-edge-worker": "true"}
container.Name = "yurt-test-busybox"
container.Image = "busybox"
container.Command = []string{"sleep", "3600"}
Expand Down

0 comments on commit 427972f

Please sign in to comment.