/
conversion.go
114 lines (91 loc) · 3.88 KB
/
conversion.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
Copyright 2020 The cert-manager Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package v1alpha3
import (
"k8s.io/apimachinery/pkg/conversion"
"github.com/jetstack/cert-manager/pkg/apis/certmanager/v1alpha3"
"github.com/jetstack/cert-manager/pkg/internal/apis/certmanager"
)
func Convert_v1alpha3_CertificateSpec_To_certmanager_CertificateSpec(in *v1alpha3.CertificateSpec, out *certmanager.CertificateSpec, s conversion.Scope) error {
if err := autoConvert_v1alpha3_CertificateSpec_To_certmanager_CertificateSpec(in, out, s); err != nil {
return err
}
if in.KeyAlgorithm != "" || in.KeyEncoding != "" || in.KeySize != 0 {
if out.PrivateKey == nil {
out.PrivateKey = &certmanager.CertificatePrivateKey{}
}
switch in.KeyAlgorithm {
case v1alpha3.ECDSAKeyAlgorithm:
out.PrivateKey.Algorithm = certmanager.ECDSAKeyAlgorithm
case v1alpha3.RSAKeyAlgorithm:
out.PrivateKey.Algorithm = certmanager.RSAKeyAlgorithm
default:
out.PrivateKey.Algorithm = certmanager.PrivateKeyAlgorithm(in.KeyAlgorithm)
}
switch in.KeyEncoding {
case v1alpha3.PKCS1:
out.PrivateKey.Encoding = certmanager.PKCS1
case v1alpha3.PKCS8:
out.PrivateKey.Encoding = certmanager.PKCS8
default:
out.PrivateKey.Encoding = certmanager.PrivateKeyEncoding(in.KeyEncoding)
}
out.PrivateKey.Size = in.KeySize
}
return nil
}
func Convert_certmanager_CertificateSpec_To_v1alpha3_CertificateSpec(in *certmanager.CertificateSpec, out *v1alpha3.CertificateSpec, s conversion.Scope) error {
if err := autoConvert_certmanager_CertificateSpec_To_v1alpha3_CertificateSpec(in, out, s); err != nil {
return err
}
if in.PrivateKey != nil {
switch in.PrivateKey.Algorithm {
case certmanager.ECDSAKeyAlgorithm:
out.KeyAlgorithm = v1alpha3.ECDSAKeyAlgorithm
case certmanager.RSAKeyAlgorithm:
out.KeyAlgorithm = v1alpha3.RSAKeyAlgorithm
default:
out.KeyAlgorithm = v1alpha3.KeyAlgorithm(in.PrivateKey.Algorithm)
}
switch in.PrivateKey.Encoding {
case certmanager.PKCS1:
out.KeyEncoding = v1alpha3.PKCS1
case certmanager.PKCS8:
out.KeyEncoding = v1alpha3.PKCS8
default:
out.KeyEncoding = v1alpha3.KeyEncoding(in.PrivateKey.Encoding)
}
out.KeySize = in.PrivateKey.Size
}
return nil
}
func Convert_certmanager_X509Subject_To_v1alpha3_X509Subject(in *certmanager.X509Subject, out *v1alpha3.X509Subject, s conversion.Scope) error {
return autoConvert_certmanager_X509Subject_To_v1alpha3_X509Subject(in, out, s)
}
func Convert_certmanager_CertificatePrivateKey_To_v1alpha3_CertificatePrivateKey(in *certmanager.CertificatePrivateKey, out *v1alpha3.CertificatePrivateKey, s conversion.Scope) error {
return autoConvert_certmanager_CertificatePrivateKey_To_v1alpha3_CertificatePrivateKey(in, out, s)
}
func Convert_v1alpha3_CertificateRequestSpec_To_certmanager_CertificateRequestSpec(in *v1alpha3.CertificateRequestSpec, out *certmanager.CertificateRequestSpec, s conversion.Scope) error {
if err := autoConvert_v1alpha3_CertificateRequestSpec_To_certmanager_CertificateRequestSpec(in, out, s); err != nil {
return err
}
out.Request = in.CSRPEM
return nil
}
func Convert_certmanager_CertificateRequestSpec_To_v1alpha3_CertificateRequestSpec(in *certmanager.CertificateRequestSpec, out *v1alpha3.CertificateRequestSpec, s conversion.Scope) error {
if err := autoConvert_certmanager_CertificateRequestSpec_To_v1alpha3_CertificateRequestSpec(in, out, s); err != nil {
return err
}
out.CSRPEM = in.Request
return nil
}