mirror of
https://github.com/kyverno/kyverno.git
synced 2025-03-31 03:45:17 +00:00
fix(generate): use JSON patch for GenerateRequests status updates (#3000)
Signed-off-by: prateekpandey14 <prateekpandey14@gmail.com> Co-authored-by: shuting <shutting06@gmail.com>
This commit is contained in:
parent
b6447e0649
commit
421e6d9622
2 changed files with 75 additions and 22 deletions
|
@ -1,13 +1,9 @@
|
|||
package generate
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
kyverno "github.com/kyverno/kyverno/api/kyverno/v1"
|
||||
kyvernoclient "github.com/kyverno/kyverno/pkg/client/clientset/versioned"
|
||||
"github.com/kyverno/kyverno/pkg/config"
|
||||
"k8s.io/apimachinery/pkg/api/errors"
|
||||
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"sigs.k8s.io/controller-runtime/pkg/log"
|
||||
)
|
||||
|
||||
|
@ -25,29 +21,45 @@ type StatusControl struct {
|
|||
|
||||
//Failed sets gr status.state to failed with message
|
||||
func (sc StatusControl) Failed(gr kyverno.GenerateRequest, message string, genResources []kyverno.ResourceSpec) error {
|
||||
gr.Status.State = kyverno.Failed
|
||||
gr.Status.Message = message
|
||||
// Update Generated Resources
|
||||
gr.Status.GeneratedResources = genResources
|
||||
_, err := sc.client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).UpdateStatus(context.TODO(), &gr, v1.UpdateOptions{})
|
||||
patch := []PatchOp{
|
||||
{
|
||||
Op: "replace",
|
||||
Path: "/status",
|
||||
Value: &kyverno.GenerateRequestStatus{
|
||||
State: kyverno.Failed,
|
||||
Message: message,
|
||||
GeneratedResources: genResources, // Update Generated Resources
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
_, err := PatchGenerateRequest(&gr, patch, sc.client, "status")
|
||||
if err != nil && !errors.IsNotFound(err) {
|
||||
log.Log.Error(err, "failed to update generate request status", "name", gr.Name)
|
||||
log.Log.Error(err, "failed to patch generate request status", "name", gr.Name)
|
||||
return err
|
||||
}
|
||||
|
||||
log.Log.V(3).Info("updated generate request status", "name", gr.Name, "status", string(kyverno.Failed))
|
||||
return nil
|
||||
}
|
||||
|
||||
// Success sets the gr status.state to completed and clears message
|
||||
func (sc StatusControl) Success(gr kyverno.GenerateRequest, genResources []kyverno.ResourceSpec) error {
|
||||
gr.Status.State = kyverno.Completed
|
||||
gr.Status.Message = ""
|
||||
// Update Generated Resources
|
||||
gr.Status.GeneratedResources = genResources
|
||||
patch := []PatchOp{
|
||||
{
|
||||
Op: "replace",
|
||||
Path: "/status",
|
||||
Value: &kyverno.GenerateRequestStatus{
|
||||
State: kyverno.Completed,
|
||||
Message: "",
|
||||
GeneratedResources: genResources, // Update Generated Resources
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
_, err := sc.client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).UpdateStatus(context.TODO(), &gr, v1.UpdateOptions{})
|
||||
_, err := PatchGenerateRequest(&gr, patch, sc.client, "status")
|
||||
if err != nil && !errors.IsNotFound(err) {
|
||||
log.Log.Error(err, "failed to update generate request status", "name", gr.Name)
|
||||
log.Log.Error(err, "failed to patch generate request status", "name", gr.Name)
|
||||
return err
|
||||
}
|
||||
|
||||
|
@ -57,14 +69,21 @@ func (sc StatusControl) Success(gr kyverno.GenerateRequest, genResources []kyver
|
|||
|
||||
// Success sets the gr status.state to completed and clears message
|
||||
func (sc StatusControl) Skip(gr kyverno.GenerateRequest, genResources []kyverno.ResourceSpec) error {
|
||||
gr.Status.State = kyverno.Skip
|
||||
gr.Status.Message = ""
|
||||
// Update Generated Resources
|
||||
gr.Status.GeneratedResources = genResources
|
||||
patch := []PatchOp{
|
||||
{
|
||||
Op: "replace",
|
||||
Path: "/status",
|
||||
Value: &kyverno.GenerateRequestStatus{
|
||||
State: kyverno.Skip,
|
||||
Message: "",
|
||||
GeneratedResources: genResources, // Update Generated Resources
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
_, err := sc.client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).UpdateStatus(context.TODO(), &gr, v1.UpdateOptions{})
|
||||
_, err := PatchGenerateRequest(&gr, patch, sc.client, "status")
|
||||
if err != nil && !errors.IsNotFound(err) {
|
||||
log.Log.Error(err, "failed to update generate request status", "name", gr.Name)
|
||||
log.Log.Error(err, "failed to patch generate request status", "name", gr.Name)
|
||||
return err
|
||||
}
|
||||
|
||||
|
|
34
pkg/generate/util.go
Normal file
34
pkg/generate/util.go
Normal file
|
@ -0,0 +1,34 @@
|
|||
package generate
|
||||
|
||||
import (
|
||||
"context"
|
||||
"encoding/json"
|
||||
|
||||
kyverno "github.com/kyverno/kyverno/api/kyverno/v1"
|
||||
kyvernoclient "github.com/kyverno/kyverno/pkg/client/clientset/versioned"
|
||||
"github.com/kyverno/kyverno/pkg/config"
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/types"
|
||||
)
|
||||
|
||||
// PatchOp represents a json patch operation
|
||||
type PatchOp struct {
|
||||
Op string `json:"op"`
|
||||
Path string `json:"path"`
|
||||
Value interface{} `json:"value,omitempty"`
|
||||
}
|
||||
|
||||
// PatchGenerateRequest patches a generate request object
|
||||
func PatchGenerateRequest(gr *kyverno.GenerateRequest, patch []PatchOp, client kyvernoclient.Interface, subresources ...string) (*kyverno.GenerateRequest, error) {
|
||||
data, err := json.Marshal(patch)
|
||||
if nil != err {
|
||||
return gr, err
|
||||
}
|
||||
|
||||
newGR, err := client.KyvernoV1().GenerateRequests(config.KyvernoNamespace).Patch(context.TODO(), gr.Name, types.JSONPatchType, data, metav1.PatchOptions{}, subresources...)
|
||||
if err != nil {
|
||||
return gr, err
|
||||
}
|
||||
|
||||
return newGR, nil
|
||||
}
|
Loading…
Add table
Reference in a new issue