/
export_registration.go
77 lines (69 loc) · 1.91 KB
/
export_registration.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
package types
import (
"encoding/json"
"encoding/pem"
"github.com/stbuehler/go-acme-client/utils"
)
type RegistrationExport struct {
JsonPem []byte
SigningKeyPem []byte
Location string
Name string
}
type rawRegistrationExportJson struct {
Resource RegistrationResource
LinkTermsOfService string
RecoveryToken string
}
func (reg Registration) Export(password string) (*RegistrationExport, error) {
keyBlock, err := reg.SigningKey.EncryptPrivateKey(password, utils.PemDefaultCipher)
if nil != err {
return nil, err
}
jsonBytes, err := json.Marshal(rawRegistrationExportJson{
Resource: reg.Resource,
LinkTermsOfService: reg.LinkTermsOfService,
RecoveryToken: reg.RecoveryToken,
})
if nil != err {
return nil, err
}
jsonBlock := &pem.Block{
Type: pemTypeAcmeJsonRegistration,
Bytes: jsonBytes,
}
if err := utils.EncryptPemBlock(jsonBlock, password, utils.PemDefaultCipher); nil != err {
return nil, err
}
return &RegistrationExport{
JsonPem: pem.EncodeToMemory(jsonBlock),
SigningKeyPem: pem.EncodeToMemory(keyBlock),
Location: reg.Location,
Name: reg.Name,
}, nil
}
func (reg *Registration) Import(export RegistrationExport, prompt PasswordPrompt) error {
jsonBlock, err := importPem(export.JsonPem, prompt, pemTypeAcmeJsonRegistration)
if nil != err {
return err
}
keyBlock, err := importPem(export.SigningKeyPem, prompt, pemTypeEcPrivateKey, pemTypeRsaPrivateKey)
if nil != err {
return err
}
var rawReg rawRegistrationExportJson
if err := json.Unmarshal(jsonBlock.Bytes, &rawReg); nil != err {
return err
}
signingKey, err := LoadSigningKey(*keyBlock)
if nil != err {
return err
}
reg.Resource = rawReg.Resource
reg.SigningKey = signingKey
reg.Location = export.Location
reg.LinkTermsOfService = rawReg.LinkTermsOfService
reg.RecoveryToken = rawReg.RecoveryToken
reg.Name = export.Name
return nil
}