2020-11-24 17:36:42 +08:00
|
|
|
package acme
|
|
|
|
|
|
2020-11-25 21:19:07 +08:00
|
|
|
import (
|
|
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
|
|
|
"github.com/iwind/TeaGo/maps"
|
2020-11-26 16:39:01 +08:00
|
|
|
timeutil "github.com/iwind/TeaGo/utils/time"
|
2020-11-25 21:19:07 +08:00
|
|
|
)
|
2020-11-24 17:36:42 +08:00
|
|
|
|
|
|
|
|
type IndexAction struct {
|
|
|
|
|
actionutils.ParentAction
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *IndexAction) Init() {
|
2020-11-25 21:19:07 +08:00
|
|
|
this.Nav("", "", "task")
|
|
|
|
|
this.SecondMenu("list")
|
2020-11-24 17:36:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *IndexAction) RunGet(params struct{}) {
|
2020-11-25 21:19:07 +08:00
|
|
|
countResp, err := this.RPC().ACMETaskRPC().CountAllEnabledACMETasks(this.AdminContext(), &pb.CountAllEnabledACMETasksRequest{
|
|
|
|
|
AdminId: this.AdminId(),
|
|
|
|
|
UserId: 0,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
count := countResp.Count
|
|
|
|
|
page := this.NewPage(count)
|
|
|
|
|
this.Data["page"] = page.AsHTML()
|
|
|
|
|
|
|
|
|
|
tasksResp, err := this.RPC().ACMETaskRPC().ListEnabledACMETasks(this.AdminContext(), &pb.ListEnabledACMETasksRequest{
|
|
|
|
|
AdminId: this.AdminId(),
|
|
|
|
|
UserId: 0,
|
|
|
|
|
Offset: page.Offset,
|
|
|
|
|
Size: page.Size,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
taskMaps := []maps.Map{}
|
|
|
|
|
for _, task := range tasksResp.AcmeTasks {
|
|
|
|
|
if task.AcmeUser == nil || task.DnsProvider == nil {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-26 17:26:26 +08:00
|
|
|
// 证书
|
2020-11-25 21:19:07 +08:00
|
|
|
var certMap maps.Map = nil
|
|
|
|
|
if task.SslCert != nil {
|
|
|
|
|
certMap = maps.Map{
|
2020-11-26 16:39:01 +08:00
|
|
|
"id": task.SslCert.Id,
|
|
|
|
|
"name": task.SslCert.Name,
|
|
|
|
|
"beginTime": timeutil.FormatTime("Y-m-d", task.SslCert.TimeBeginAt),
|
|
|
|
|
"endTime": timeutil.FormatTime("Y-m-d", task.SslCert.TimeEndAt),
|
2020-11-25 21:19:07 +08:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-26 17:26:26 +08:00
|
|
|
// 日志
|
|
|
|
|
var logMap maps.Map = nil
|
|
|
|
|
if task.LatestACMETaskLog != nil {
|
|
|
|
|
logMap = maps.Map{
|
|
|
|
|
"id": task.LatestACMETaskLog.Id,
|
|
|
|
|
"isOk": task.LatestACMETaskLog.IsOk,
|
|
|
|
|
"error": task.LatestACMETaskLog.Error,
|
|
|
|
|
"createdTime": timeutil.FormatTime("m-d", task.CreatedAt),
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-25 21:19:07 +08:00
|
|
|
taskMaps = append(taskMaps, maps.Map{
|
|
|
|
|
"id": task.Id,
|
|
|
|
|
"acmeUser": maps.Map{
|
|
|
|
|
"id": task.AcmeUser.Id,
|
|
|
|
|
"email": task.AcmeUser.Email,
|
|
|
|
|
},
|
|
|
|
|
"dnsProvider": maps.Map{
|
|
|
|
|
"id": task.DnsProvider.Id,
|
|
|
|
|
"name": task.DnsProvider.Name,
|
|
|
|
|
},
|
|
|
|
|
"dnsDomain": task.DnsDomain,
|
|
|
|
|
"domains": task.Domains,
|
|
|
|
|
"autoRenew": task.AutoRenew,
|
|
|
|
|
"cert": certMap,
|
2020-11-26 17:26:26 +08:00
|
|
|
"log": logMap,
|
2020-11-25 21:19:07 +08:00
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
this.Data["tasks"] = taskMaps
|
|
|
|
|
|
2020-11-24 17:36:42 +08:00
|
|
|
this.Show()
|
|
|
|
|
}
|