Files
EdgeAdmin/internal/web/actions/default/servers/certs/updatePopup.go

163 lines
3.8 KiB
Go
Raw Normal View History

2020-11-24 17:36:42 +08:00
package certs
2020-09-30 17:46:38 +08:00
2020-10-02 17:22:24 +08:00
import (
"encoding/json"
2020-11-10 21:37:48 +08:00
"github.com/TeaOSLab/EdgeAdmin/internal/oplogs"
2020-10-02 17:22:24 +08:00
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/sslconfigs"
"github.com/iwind/TeaGo/actions"
timeutil "github.com/iwind/TeaGo/utils/time"
2020-10-02 17:22:24 +08:00
)
2020-09-30 17:46:38 +08:00
type UpdatePopupAction struct {
actionutils.ParentAction
}
func (this *UpdatePopupAction) Init() {
this.Nav("", "", "")
}
2020-10-02 17:22:24 +08:00
func (this *UpdatePopupAction) RunGet(params struct {
CertId int64
}) {
certConfigResp, err := this.RPC().SSLCertRPC().FindEnabledSSLCertConfig(this.AdminContext(), &pb.FindEnabledSSLCertConfigRequest{SslCertId: params.CertId})
2020-10-02 17:22:24 +08:00
if err != nil {
this.ErrorPage(err)
return
}
certConfigJSON := certConfigResp.SslCertJSON
2020-10-02 17:22:24 +08:00
if len(certConfigJSON) == 0 {
this.NotFound("cert", params.CertId)
return
}
certConfig := &sslconfigs.SSLCertConfig{}
err = json.Unmarshal(certConfigJSON, certConfig)
if err != nil {
this.ErrorPage(err)
return
}
this.Data["certConfig"] = certConfig
2020-09-30 17:46:38 +08:00
this.Show()
}
2020-10-02 17:22:24 +08:00
func (this *UpdatePopupAction) RunPost(params struct {
CertId int64
TextMode bool
2020-10-02 17:22:24 +08:00
Name string
IsCA bool
Description string
IsOn bool
CertFile *actions.File
KeyFile *actions.File
CertText string
KeyText string
2020-10-02 17:22:24 +08:00
Must *actions.Must
}) {
2020-11-10 21:37:48 +08:00
// 创建日志
2020-11-20 15:32:42 +08:00
defer this.CreateLog(oplogs.LevelInfo, "修改SSL证书 %d", params.CertId)
2020-11-10 21:37:48 +08:00
2020-10-02 17:22:24 +08:00
// 查询Cert
certConfigResp, err := this.RPC().SSLCertRPC().FindEnabledSSLCertConfig(this.AdminContext(), &pb.FindEnabledSSLCertConfigRequest{SslCertId: params.CertId})
2020-10-02 17:22:24 +08:00
if err != nil {
this.ErrorPage(err)
return
}
2022-04-19 11:14:40 +08:00
var certConfigJSON = certConfigResp.SslCertJSON
2020-10-02 17:22:24 +08:00
if len(certConfigJSON) == 0 {
this.NotFound("cert", params.CertId)
return
}
2022-04-19 11:14:40 +08:00
var certConfig = &sslconfigs.SSLCertConfig{}
2020-10-02 17:22:24 +08:00
err = json.Unmarshal(certConfigJSON, certConfig)
if err != nil {
this.ErrorPage(err)
return
}
// 校验参数
params.Must.
Field("name", params.Name).
Require("请输入证书说明")
if params.TextMode {
if len(params.CertText) > 0 {
certConfig.CertData = []byte(params.CertText)
2020-10-02 17:22:24 +08:00
}
if !params.IsCA {
if len(params.KeyText) > 0 {
certConfig.KeyData = []byte(params.KeyText)
}
}
} else {
if params.CertFile != nil {
certConfig.CertData, err = params.CertFile.Read()
2020-10-02 17:22:24 +08:00
if err != nil {
this.FailField("certFile", "读取证书文件内容错误,请重新上传")
}
}
if !params.IsCA {
if params.KeyFile != nil {
certConfig.KeyData, err = params.KeyFile.Read()
if err != nil {
this.FailField("keyFile", "读取私钥文件内容错误,请重新上传")
}
2020-10-02 17:22:24 +08:00
}
}
}
// 校验
certConfig.IsCA = params.IsCA
err = certConfig.Init()
if err != nil {
if params.IsCA {
this.Fail("证书校验错误:" + err.Error())
} else {
this.Fail("证书或密钥校验错误:" + err.Error())
}
}
if len(timeutil.Format("Y", certConfig.TimeEnd())) != 4 {
this.Fail("证书格式错误:无法读取到证书有效期")
}
2022-04-19 11:14:40 +08:00
if certConfig.TimeBeginAt < 0 {
this.Fail("证书校验错误有效期开始时间过小不能小于1970年1月1日")
}
if certConfig.TimeEndAt < 0 {
this.Fail("证书校验错误有效期结束时间过小不能小于1970年1月1日")
}
2020-10-02 17:22:24 +08:00
// 保存
_, err = this.RPC().SSLCertRPC().UpdateSSLCert(this.AdminContext(), &pb.UpdateSSLCertRequest{
SslCertId: params.CertId,
2020-10-02 17:22:24 +08:00
IsOn: params.IsOn,
Name: params.Name,
Description: params.Description,
ServerName: "",
IsCA: params.IsCA,
CertData: certConfig.CertData,
KeyData: certConfig.KeyData,
TimeBeginAt: certConfig.TimeBeginAt,
TimeEndAt: certConfig.TimeEndAt,
DnsNames: certConfig.DNSNames,
CommonNames: certConfig.CommonNames,
})
if err != nil {
this.ErrorPage(err)
return
}
this.Success()
}