1
0
Fork 0
mirror of https://github.com/kyverno/policy-reporter.git synced 2024-12-15 17:50:58 +00:00
policy-reporter/cmd/send/violations.go
Frank Jogeleit 78f24497fa
Policy Reporter v3 (#482)
Policy Reporter v3

Signed-off-by: Frank Jogeleit <frank.jogeleit@web.de>
2024-10-07 11:10:46 +02:00

125 lines
2.9 KiB
Go

package send
import (
"strings"
"sync"
"github.com/spf13/cobra"
"go.uber.org/zap"
"k8s.io/client-go/rest"
"k8s.io/client-go/tools/clientcmd"
"github.com/kyverno/policy-reporter/pkg/config"
"github.com/kyverno/policy-reporter/pkg/email/violations"
)
func NewViolationsCMD() *cobra.Command {
cmd := &cobra.Command{
Use: "violations",
Short: "Send a violations e-mail to the configured emails",
RunE: func(cmd *cobra.Command, args []string) error {
c, err := config.Load(cmd)
if err != nil {
return err
}
var k8sConfig *rest.Config
if c.K8sClient.Kubeconfig != "" {
k8sConfig, err = clientcmd.BuildConfigFromFlags("", c.K8sClient.Kubeconfig)
} else {
k8sConfig, err = rest.InClusterConfig()
}
if err != nil {
return err
}
resolver := config.NewResolver(c, k8sConfig)
logger, err := resolver.Logger()
if err != nil {
return err
}
generator, err := resolver.ViolationsGenerator()
if err != nil {
return err
}
data, err := generator.GenerateData(cmd.Context())
if err != nil {
logger.Error("failed to generate report data", zap.Error(err))
return err
}
reporter := resolver.ViolationsReporter()
wg := &sync.WaitGroup{}
wg.Add(1 + len(c.EmailReports.Violations.Channels))
go func() {
defer wg.Done()
if len(c.EmailReports.Violations.To) == 0 {
logger.Info("skipped - no email configured")
return
}
report, err := reporter.Report(data, c.EmailReports.Violations.Format)
if err != nil {
logger.Error("failed to create report", zap.Error(err))
return
}
err = resolver.EmailClient().Send(report, c.EmailReports.Violations.To)
if err != nil {
logger.Error("failed to send report", zap.Error(err))
return
}
logger.Sugar().Infof("email sent to %s\n", strings.Join(c.EmailReports.Violations.To, ", "))
}()
nsclient, err := resolver.NamespaceClient()
if err != nil {
logger.Error("failed to get namespace client", zap.Error(err))
return err
}
for _, ch := range c.EmailReports.Violations.Channels {
go func(channel config.EmailReport) {
defer wg.Done()
if len(channel.To) == 0 {
logger.Info("skipped - no channel email configured")
return
}
sources := violations.FilterSources(data, config.EmailReportFilterFromConfig(nsclient, channel.Filter), !channel.Filter.DisableClusterReports)
if len(sources) == 0 {
logger.Info("skip email - no results to send")
return
}
report, err := reporter.Report(sources, channel.Format)
if err != nil {
logger.Error("failed to create report", zap.Error(err))
return
}
err = resolver.EmailClient().Send(report, channel.To)
if err != nil {
logger.Error("failed to send report", zap.Error(err))
return
}
logger.Sugar().Infof("email sent to %s\n", strings.Join(channel.To, ", "))
}(ch)
}
wg.Wait()
return nil
},
}
return cmd
}