diff --git a/pkg/controllers/resources/ingresses/syncer_test.go b/pkg/controllers/resources/ingresses/syncer_test.go index 91e97507f4..25b9286d15 100644 --- a/pkg/controllers/resources/ingresses/syncer_test.go +++ b/pkg/controllers/resources/ingresses/syncer_test.go @@ -368,7 +368,7 @@ func TestSync(t *testing.T) { Labels: baseIngress.Labels, Annotations: map[string]string{ "nginx.ingress.kubernetes.io/auth-secret": "my-secret", - "alb.ingress.kubernetes.io/actions.testservice": "{\"forwardConfig\":{\"targetGroups\":[{\"serviceName\":\"nginx-service\",\"servicePort\":\"80\",\"weight\":100}]}}", + "alb.ingress.kubernetes.io/actions.testservice": `{"forwardConfig":{"targetGroups":[{"serviceName":"nginx-service","servicePort":"80","weight":100}]}}`, "alb.ingress.kubernetes.io/actions.ssl-redirect": `{"type": "redirect", "redirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}`, }, }, @@ -391,7 +391,7 @@ func TestSync(t *testing.T) { Namespace: baseIngress.Namespace, Labels: baseIngress.Labels, Annotations: map[string]string{ - "alb.ingress.kubernetes.io/actions.testservice": "{\"forwardConfig\":{\"targetGroups\":[{\"serviceName\":\"nginx-service\",\"servicePort\":\"80\",\"weight\":100}]}}", + "alb.ingress.kubernetes.io/actions.testservice": `{"forwardConfig":{"targetGroups":[{"serviceName":"nginx-service","servicePort":"80","weight":100}]}}`, "alb.ingress.kubernetes.io/actions.ssl-redirect": `{"type": "redirect", "redirectConfig": { "Protocol": "HTTPS", "Port": "443", "StatusCode": "HTTP_301"}}`, "nginx.ingress.kubernetes.io/auth-secret": "my-secret", }, @@ -412,7 +412,7 @@ func TestSync(t *testing.T) { "vcluster.loft.sh/object-name": baseIngress.Name, "vcluster.loft.sh/object-namespace": baseIngress.Namespace, translate.UIDAnnotation: "", - "alb.ingress.kubernetes.io/actions.testservice-x-test-x-suffix": "{\"forwardConfig\":{\"targetGroups\":[{\"serviceName\":\"nginx-service-x-test-x-suffix\",\"servicePort\":\"80\",\"weight\":100}]}}", + "alb.ingress.kubernetes.io/actions.testservice-x-test-x-suffix": `{"forwardConfig":{"targetGroups":[{"serviceName":"nginx-service-x-test-x-suffix","servicePort":"80","weight":100}]}}`, "alb.ingress.kubernetes.io/actions.ssl-redirect-x-test-x-suffix": `{"type":"redirect","forwardConfig":{},"redirectConfig":{"Port":"443","Protocol":"HTTPS","StatusCode":"HTTP_301"}}`, }, }, diff --git a/pkg/controllers/resources/ingresses/util/util.go b/pkg/controllers/resources/ingresses/util/util.go index ef9d11ace8..c8f1a507d9 100644 --- a/pkg/controllers/resources/ingresses/util/util.go +++ b/pkg/controllers/resources/ingresses/util/util.go @@ -24,8 +24,10 @@ func getActionOrConditionValue(annotation, actionOrCondition string) string { // ref https://github.com/kubernetes-sigs/aws-load-balancer-controller/blob/main/pkg/ingress/config_types.go type actionPayload struct { - Type string `json:"type,omitempty"` - ForwardConfig struct { + Type string `json:"type,omitempty"` + TargetGroupARN *string `json:"targetGroupARN,omitempty"` + FixedResponseConfig map[string]interface{} `json:"fixedResponseConfig,omitempty"` + ForwardConfig struct { TargetGroups []map[string]interface{} `json:"targetGroups,omitempty"` TargetGroupStickinessConfig map[string]interface{} `json:"targetGroupStickinessConfig,omitempty"` } `json:"forwardConfig,omitempty"`