mirror of
https://github.com/usual2970/certimate.git
synced 2025-06-07 21:19:51 +00:00
83 lines
2.0 KiB
Go
83 lines
2.0 KiB
Go
package nodeprocessor
|
|
|
|
import (
|
|
"context"
|
|
"log/slog"
|
|
|
|
"github.com/usual2970/certimate/internal/domain"
|
|
"github.com/usual2970/certimate/internal/notify"
|
|
"github.com/usual2970/certimate/internal/repository"
|
|
)
|
|
|
|
type notifyNode struct {
|
|
node *domain.WorkflowNode
|
|
*nodeProcessor
|
|
*nodeOutputer
|
|
|
|
settingsRepo settingsRepository
|
|
}
|
|
|
|
func NewNotifyNode(node *domain.WorkflowNode) *notifyNode {
|
|
return ¬ifyNode{
|
|
node: node,
|
|
nodeProcessor: newNodeProcessor(node),
|
|
nodeOutputer: newNodeOutputer(),
|
|
|
|
settingsRepo: repository.NewSettingsRepository(),
|
|
}
|
|
}
|
|
|
|
func (n *notifyNode) Process(ctx context.Context) error {
|
|
n.logger.Info("ready to send notification ...")
|
|
|
|
nodeConfig := n.node.GetConfigForNotify()
|
|
|
|
if nodeConfig.Provider == "" {
|
|
// Deprecated: v0.4.x 将废弃
|
|
// 兼容旧版本的通知渠道
|
|
n.logger.Warn("WARNING! you are using the notification channel from global settings, which will be deprecated in the future")
|
|
|
|
// 获取通知配置
|
|
settings, err := n.settingsRepo.GetByName(ctx, "notifyChannels")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// 获取通知渠道
|
|
channelConfig, err := settings.GetNotifyChannelConfig(nodeConfig.Channel)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// 发送通知
|
|
if err := notify.SendToChannel(nodeConfig.Subject, nodeConfig.Message, nodeConfig.Channel, channelConfig); err != nil {
|
|
n.logger.Warn("failed to send notification", slog.String("channel", nodeConfig.Channel))
|
|
return err
|
|
}
|
|
|
|
n.logger.Info("notification completed")
|
|
return nil
|
|
}
|
|
|
|
// 初始化通知器
|
|
deployer, err := notify.NewWithWorkflowNode(notify.NotifierWithWorkflowNodeConfig{
|
|
Node: n.node,
|
|
Logger: n.logger,
|
|
Subject: nodeConfig.Subject,
|
|
Message: nodeConfig.Message,
|
|
})
|
|
if err != nil {
|
|
n.logger.Warn("failed to create notifier provider")
|
|
return err
|
|
}
|
|
|
|
// 推送通知
|
|
if err := deployer.Notify(ctx); err != nil {
|
|
n.logger.Warn("failed to send notification")
|
|
return err
|
|
}
|
|
|
|
n.logger.Info("notification completed")
|
|
return nil
|
|
}
|