2022-11-11 17:41:39 +08:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
2022-11-16 10:31:35 +08:00
|
|
|
"context"
|
|
|
|
"crypto/x509"
|
2022-11-17 17:39:33 +08:00
|
|
|
"encoding/pem"
|
2022-11-11 17:41:39 +08:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
2022-11-16 10:31:35 +08:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/model"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/utils/ssl"
|
|
|
|
"path"
|
|
|
|
"strings"
|
2022-11-11 17:41:39 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
type WebSiteSSLService struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (w WebSiteSSLService) Page(search dto.PageInfo) (int64, []dto.WebsiteSSLDTO, error) {
|
|
|
|
total, sslList, err := websiteSSLRepo.Page(search.Page, search.PageSize, commonRepo.WithOrderBy("created_at desc"))
|
|
|
|
var sslDTOs []dto.WebsiteSSLDTO
|
|
|
|
for _, ssl := range sslList {
|
|
|
|
sslDTOs = append(sslDTOs, dto.WebsiteSSLDTO{
|
|
|
|
WebSiteSSL: ssl,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
return total, sslDTOs, err
|
|
|
|
}
|
|
|
|
|
2022-11-16 10:31:35 +08:00
|
|
|
func (w WebSiteSSLService) Create(create dto.WebsiteSSLCreate) (dto.WebsiteSSLCreate, error) {
|
|
|
|
|
|
|
|
var res dto.WebsiteSSLCreate
|
|
|
|
acmeAccount, err := websiteAcmeRepo.GetFirst(commonRepo.WithByID(create.AcmeAccountID))
|
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
2022-11-17 17:39:33 +08:00
|
|
|
|
2022-11-16 10:31:35 +08:00
|
|
|
client, err := ssl.NewPrivateKeyClient(acmeAccount.Email, acmeAccount.PrivateKey)
|
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
|
2022-11-17 17:39:33 +08:00
|
|
|
switch create.Provider {
|
|
|
|
case dto.DNSAccount:
|
|
|
|
dnsAccount, err := websiteDnsRepo.GetFirst(commonRepo.WithByID(create.DnsAccountID))
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
|
2022-11-16 10:31:35 +08:00
|
|
|
if err := client.UseDns(ssl.DnsType(dnsAccount.Type), dnsAccount.Authorization); err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
2022-11-17 17:39:33 +08:00
|
|
|
case dto.Http:
|
|
|
|
case dto.DnsManual:
|
|
|
|
|
2022-11-16 10:31:35 +08:00
|
|
|
}
|
|
|
|
|
2022-11-17 17:39:33 +08:00
|
|
|
domains := []string{create.PrimaryDomain}
|
|
|
|
otherDomainArray := strings.Split(create.OtherDomains, "\n")
|
|
|
|
if create.OtherDomains != "" {
|
|
|
|
domains = append(otherDomainArray, domains...)
|
|
|
|
}
|
|
|
|
resource, err := client.ObtainSSL(domains)
|
2022-11-16 10:31:35 +08:00
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
var websiteSSL model.WebSiteSSL
|
2022-11-17 17:39:33 +08:00
|
|
|
websiteSSL.DnsAccountID = create.DnsAccountID
|
|
|
|
websiteSSL.AcmeAccountID = acmeAccount.ID
|
|
|
|
websiteSSL.Provider = string(create.Provider)
|
|
|
|
websiteSSL.Domains = strings.Join(otherDomainArray, ",")
|
|
|
|
websiteSSL.PrimaryDomain = create.PrimaryDomain
|
2022-11-16 10:31:35 +08:00
|
|
|
websiteSSL.PrivateKey = string(resource.PrivateKey)
|
|
|
|
websiteSSL.Pem = string(resource.Certificate)
|
|
|
|
websiteSSL.CertURL = resource.CertURL
|
2022-11-17 17:39:33 +08:00
|
|
|
certBlock, _ := pem.Decode(resource.Certificate)
|
|
|
|
cert, err := x509.ParseCertificate(certBlock.Bytes)
|
2022-11-16 10:31:35 +08:00
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteSSLCreate{}, err
|
|
|
|
}
|
|
|
|
websiteSSL.ExpireDate = cert.NotAfter
|
|
|
|
websiteSSL.StartDate = cert.NotBefore
|
|
|
|
websiteSSL.Type = cert.Issuer.CommonName
|
2022-11-17 17:39:33 +08:00
|
|
|
websiteSSL.Organization = cert.Issuer.Organization[0]
|
2022-11-16 10:31:35 +08:00
|
|
|
|
2022-11-17 17:39:33 +08:00
|
|
|
//if err := createPemFile(websiteSSL); err != nil {
|
|
|
|
// return dto.WebsiteSSLCreate{}, err
|
|
|
|
//}
|
2022-11-16 10:31:35 +08:00
|
|
|
|
|
|
|
if err := websiteSSLRepo.Create(context.TODO(), &websiteSSL); err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return create, nil
|
|
|
|
}
|
|
|
|
|
2022-11-17 17:39:33 +08:00
|
|
|
func (w WebSiteSSLService) Renew(sslId uint) error {
|
|
|
|
|
|
|
|
websiteSSL, err := websiteSSLRepo.GetFirst(commonRepo.WithByID(sslId))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
acmeAccount, err := websiteAcmeRepo.GetFirst(commonRepo.WithByID(websiteSSL.AcmeAccountID))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
client, err := ssl.NewPrivateKeyClient(acmeAccount.Email, acmeAccount.PrivateKey)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
switch websiteSSL.Provider {
|
|
|
|
case dto.DNSAccount:
|
|
|
|
dnsAccount, err := websiteDnsRepo.GetFirst(commonRepo.WithByID(websiteSSL.DnsAccountID))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := client.UseDns(ssl.DnsType(dnsAccount.Type), dnsAccount.Authorization); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
case dto.Http:
|
|
|
|
case dto.DnsManual:
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
resource, err := client.RenewSSL(websiteSSL.CertURL)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
websiteSSL.PrivateKey = string(resource.PrivateKey)
|
|
|
|
websiteSSL.Pem = string(resource.Certificate)
|
|
|
|
websiteSSL.CertURL = resource.CertURL
|
|
|
|
certBlock, _ := pem.Decode(resource.Certificate)
|
|
|
|
cert, err := x509.ParseCertificate(certBlock.Bytes)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
websiteSSL.ExpireDate = cert.NotAfter
|
|
|
|
websiteSSL.StartDate = cert.NotBefore
|
|
|
|
websiteSSL.Type = cert.Issuer.CommonName
|
|
|
|
websiteSSL.Organization = cert.Issuer.Organization[0]
|
|
|
|
|
|
|
|
return websiteSSLRepo.Save(websiteSSL)
|
|
|
|
}
|
|
|
|
|
2022-11-16 10:31:35 +08:00
|
|
|
func (w WebSiteSSLService) Apply(apply dto.WebsiteSSLApply) (dto.WebsiteSSLApply, error) {
|
|
|
|
websiteSSL, err := websiteSSLRepo.GetFirst(commonRepo.WithByID(apply.SSLID))
|
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteSSLApply{}, err
|
|
|
|
}
|
|
|
|
website, err := websiteRepo.GetFirst(commonRepo.WithByID(apply.WebsiteID))
|
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteSSLApply{}, err
|
|
|
|
}
|
|
|
|
if err := createPemFile(websiteSSL); err != nil {
|
|
|
|
return dto.WebsiteSSLApply{}, err
|
|
|
|
}
|
|
|
|
nginxParams := getNginxParamsFromStaticFile(dto.SSL)
|
|
|
|
for i, param := range nginxParams {
|
|
|
|
if param.Name == "ssl_certificate" {
|
2022-11-17 17:39:33 +08:00
|
|
|
nginxParams[i].Params = []string{path.Join("/etc/nginx/ssl", websiteSSL.PrimaryDomain, "fullchain.pem")}
|
2022-11-16 10:31:35 +08:00
|
|
|
}
|
|
|
|
if param.Name == "ssl_certificate_key" {
|
2022-11-17 17:39:33 +08:00
|
|
|
nginxParams[i].Params = []string{path.Join("/etc/nginx/ssl", websiteSSL.PrimaryDomain, "privkey.pem")}
|
2022-11-16 10:31:35 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if err := updateNginxConfig(website, nginxParams, dto.SSL); err != nil {
|
|
|
|
return dto.WebsiteSSLApply{}, err
|
|
|
|
}
|
|
|
|
website.WebSiteSSLID = websiteSSL.ID
|
|
|
|
if err := websiteRepo.Save(context.TODO(), &website); err != nil {
|
|
|
|
return dto.WebsiteSSLApply{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return apply, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (w WebSiteSSLService) GetDNSResolve(req dto.WebsiteDNSReq) (dto.WebsiteDNSRes, error) {
|
|
|
|
acmeAccount, err := websiteAcmeRepo.GetFirst(commonRepo.WithByID(req.AcmeAccountID))
|
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteDNSRes{}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
client, err := ssl.NewPrivateKeyClient(acmeAccount.Email, acmeAccount.PrivateKey)
|
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteDNSRes{}, err
|
|
|
|
}
|
|
|
|
re, err := client.UseManualDns(req.Domains)
|
|
|
|
if err != nil {
|
|
|
|
return dto.WebsiteDNSRes{}, err
|
|
|
|
}
|
|
|
|
var res dto.WebsiteDNSRes
|
|
|
|
res.Key = re.Key
|
|
|
|
res.Value = re.Value
|
|
|
|
res.Type = "TXT"
|
|
|
|
return res, nil
|
|
|
|
}
|
2022-11-11 17:41:39 +08:00
|
|
|
|
2022-11-17 17:39:33 +08:00
|
|
|
func (w WebSiteSSLService) GetWebsiteSSL(websiteId uint) (dto.WebsiteSSLDTO, error) {
|
|
|
|
var res dto.WebsiteSSLDTO
|
|
|
|
website, err := websiteRepo.GetFirst(commonRepo.WithByID(websiteId))
|
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
websiteSSL, err := websiteSSLRepo.GetFirst(commonRepo.WithByID(website.WebSiteSSLID))
|
|
|
|
if err != nil {
|
|
|
|
return res, err
|
|
|
|
}
|
|
|
|
res.WebSiteSSL = websiteSSL
|
|
|
|
return res, nil
|
|
|
|
}
|
|
|
|
|
2022-11-11 17:41:39 +08:00
|
|
|
func (w WebSiteSSLService) Delete(id uint) error {
|
|
|
|
return websiteSSLRepo.DeleteBy(commonRepo.WithByID(id))
|
|
|
|
}
|