2020-01-07 10:33:28 -08:00
|
|
|
package generate
|
|
|
|
|
|
|
|
import (
|
2020-11-09 11:26:12 -08:00
|
|
|
"context"
|
|
|
|
|
2020-10-07 11:12:31 -07:00
|
|
|
kyverno "github.com/kyverno/kyverno/pkg/api/kyverno/v1"
|
|
|
|
kyvernoclient "github.com/kyverno/kyverno/pkg/client/clientset/versioned"
|
|
|
|
"github.com/kyverno/kyverno/pkg/config"
|
2020-11-13 17:44:34 -08:00
|
|
|
"k8s.io/apimachinery/pkg/api/errors"
|
2020-11-09 11:26:12 -08:00
|
|
|
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
2020-03-17 16:25:34 -07:00
|
|
|
"sigs.k8s.io/controller-runtime/pkg/log"
|
2020-01-07 10:33:28 -08:00
|
|
|
)
|
|
|
|
|
2020-01-24 12:05:53 -08:00
|
|
|
//StatusControlInterface provides interface to update status subresource
|
2020-01-07 10:33:28 -08:00
|
|
|
type StatusControlInterface interface {
|
2020-01-07 15:13:57 -08:00
|
|
|
Failed(gr kyverno.GenerateRequest, message string, genResources []kyverno.ResourceSpec) error
|
|
|
|
Success(gr kyverno.GenerateRequest, genResources []kyverno.ResourceSpec) error
|
2020-01-07 10:33:28 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// StatusControl is default implementaation of GRStatusControlInterface
|
|
|
|
type StatusControl struct {
|
|
|
|
client kyvernoclient.Interface
|
|
|
|
}
|
|
|
|
|
2020-01-24 12:05:53 -08:00
|
|
|
//Failed sets gr status.state to failed with message
|
2020-01-07 15:13:57 -08:00
|
|
|
func (sc StatusControl) Failed(gr kyverno.GenerateRequest, message string, genResources []kyverno.ResourceSpec) error {
|
2020-01-07 10:33:28 -08:00
|
|
|
gr.Status.State = kyverno.Failed
|
|
|
|
gr.Status.Message = message
|
2020-01-07 15:13:57 -08:00
|
|
|
// Update Generated Resources
|
|
|
|
gr.Status.GeneratedResources = genResources
|
2020-11-26 16:07:06 -08:00
|
|
|
_, err := sc.client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).UpdateStatus(context.TODO(), &gr, v1.UpdateOptions{})
|
2020-11-13 17:44:34 -08:00
|
|
|
if err != nil && !errors.IsNotFound(err) {
|
2020-03-17 16:25:34 -07:00
|
|
|
log.Log.Error(err, "failed to update generate request status", "name", gr.Name)
|
2020-01-07 10:33:28 -08:00
|
|
|
return err
|
|
|
|
}
|
2020-11-13 17:44:34 -08:00
|
|
|
log.Log.V(3).Info("updated generate request status", "name", gr.Name, "status", string(kyverno.Failed))
|
2020-01-07 10:33:28 -08:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-01-24 12:05:53 -08:00
|
|
|
// Success sets the gr status.state to completed and clears message
|
2020-01-07 15:13:57 -08:00
|
|
|
func (sc StatusControl) Success(gr kyverno.GenerateRequest, genResources []kyverno.ResourceSpec) error {
|
2020-01-07 10:33:28 -08:00
|
|
|
gr.Status.State = kyverno.Completed
|
|
|
|
gr.Status.Message = ""
|
2020-01-07 15:13:57 -08:00
|
|
|
// Update Generated Resources
|
|
|
|
gr.Status.GeneratedResources = genResources
|
2020-01-07 10:33:28 -08:00
|
|
|
|
2020-11-26 16:07:06 -08:00
|
|
|
_, err := sc.client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).UpdateStatus(context.TODO(), &gr, v1.UpdateOptions{})
|
2020-11-13 17:44:34 -08:00
|
|
|
if err != nil && !errors.IsNotFound(err) {
|
2020-03-17 16:25:34 -07:00
|
|
|
log.Log.Error(err, "failed to update generate request status", "name", gr.Name)
|
2020-01-07 10:33:28 -08:00
|
|
|
return err
|
|
|
|
}
|
2020-11-13 17:44:34 -08:00
|
|
|
log.Log.V(3).Info("updated generate request status", "name", gr.Name, "status", string(kyverno.Completed))
|
2020-01-07 10:33:28 -08:00
|
|
|
return nil
|
|
|
|
}
|