mirror of https://github.com/allinssl/allinssl
138 lines
3.9 KiB
Go
138 lines
3.9 KiB
Go
package workflow
|
||
|
||
import (
|
||
"ALLinSSL/backend/internal/cert"
|
||
certApply "ALLinSSL/backend/internal/cert/apply"
|
||
certDeploy "ALLinSSL/backend/internal/cert/deploy"
|
||
"ALLinSSL/backend/internal/report"
|
||
"ALLinSSL/backend/public"
|
||
"errors"
|
||
"fmt"
|
||
"strconv"
|
||
)
|
||
|
||
// var executors map[string]func(map[string]any) (any, error)
|
||
//
|
||
// func RegistExector(executorName string, executor func(map[string]any) (any, error)) {
|
||
// executors[executorName] = executor
|
||
// }
|
||
|
||
func Executors(exec string, params map[string]any) (any, error) {
|
||
switch exec {
|
||
case "apply":
|
||
return apply(params)
|
||
case "deploy":
|
||
return deploy(params)
|
||
case "upload":
|
||
return upload(params)
|
||
case "notify":
|
||
return notify(params)
|
||
default:
|
||
return nil, nil
|
||
}
|
||
}
|
||
|
||
func apply(params map[string]any) (any, error) {
|
||
logger := params["logger"].(*public.Logger)
|
||
|
||
logger.Info("=============申请证书=============")
|
||
certificate, err := certApply.Apply(params, logger)
|
||
if err != nil {
|
||
logger.Error(err.Error())
|
||
logger.Info("=============申请失败=============")
|
||
return nil, err
|
||
}
|
||
logger.Info("=============申请成功=============")
|
||
return certificate, nil
|
||
}
|
||
|
||
func deploy(params map[string]any) (any, error) {
|
||
logger := params["logger"].(*public.Logger)
|
||
logger.Info("=============部署证书=============")
|
||
certificate := params["certificate"]
|
||
if certificate == nil {
|
||
logger.Error("证书不存在")
|
||
logger.Info("=============部署失败=============")
|
||
return nil, errors.New("证书不存在")
|
||
}
|
||
err := certDeploy.Deploy(params, logger)
|
||
if err != nil {
|
||
logger.Error(err.Error())
|
||
logger.Info("=============部署失败=============")
|
||
} else {
|
||
logger.Info("=============部署成功=============")
|
||
}
|
||
return nil, err
|
||
}
|
||
|
||
func upload(params map[string]any) (any, error) {
|
||
logger := params["logger"].(*public.Logger)
|
||
logger.Info("=============上传证书=============")
|
||
// 判断证书id走本地还是走旧上传,应在之后的迭代中移除旧代码
|
||
if params["cert_id"] == nil {
|
||
keyStr, ok := params["key"].(string)
|
||
if !ok {
|
||
logger.Error("上传的密钥有误")
|
||
logger.Info("=============上传失败=============")
|
||
return nil, errors.New("上传的密钥有误")
|
||
}
|
||
certStr, ok := params["cert"].(string)
|
||
if !ok {
|
||
logger.Error("上传的证书有误")
|
||
logger.Info("=============上传失败=============")
|
||
return nil, errors.New("上传的证书有误")
|
||
}
|
||
_, err := cert.UploadCert(keyStr, certStr)
|
||
if err != nil {
|
||
logger.Error(err.Error())
|
||
logger.Info("=============上传失败=============")
|
||
return nil, err
|
||
}
|
||
logger.Info("=============上传成功=============")
|
||
|
||
return params, nil
|
||
} else {
|
||
certId := ""
|
||
switch v := params["cert_id"].(type) {
|
||
case float64:
|
||
certId = strconv.Itoa(int(v))
|
||
case string:
|
||
certId = v
|
||
default:
|
||
logger.Info("=============上传证书获取失败=============")
|
||
return nil, errors.New("证书 ID 类型错误")
|
||
}
|
||
result := map[string]any{}
|
||
certObj, err := cert.GetCert(certId)
|
||
if err != nil {
|
||
logger.Error(err.Error())
|
||
logger.Info("=============上传证书获取失败=============")
|
||
return nil, err
|
||
}
|
||
if certObj == nil {
|
||
logger.Error("证书不存在")
|
||
logger.Info("=============上传证书获取失败=============")
|
||
return nil, errors.New("证书不存在")
|
||
}
|
||
logger.Debug(fmt.Sprintf("证书 ID: %s", certId))
|
||
result["cert"] = certObj["cert"]
|
||
result["key"] = certObj["key"]
|
||
return result, nil
|
||
}
|
||
}
|
||
|
||
func notify(params map[string]any) (any, error) {
|
||
// fmt.Println("通知:", params)
|
||
logger := params["logger"].(*public.Logger)
|
||
logger.Info("=============发送通知=============")
|
||
logger.Debug(fmt.Sprintf("发送通知:%s", params["subject"].(string)))
|
||
err := report.Notify(params)
|
||
if err != nil {
|
||
logger.Error(err.Error())
|
||
logger.Info("=============发送失败=============")
|
||
return nil, err
|
||
}
|
||
logger.Info("=============发送成功=============")
|
||
return fmt.Sprintf("通知到: %s", params["message"]), nil
|
||
}
|