From 38b232a1652d2c396a8fd76fe61edbae61bb9a46 Mon Sep 17 00:00:00 2001 From: sgayangi Date: Mon, 7 Oct 2024 17:40:34 +0530 Subject: [PATCH] Fix null pointer in enforcer --- .../oasparser/model/adapter_internal_api.go | 49 +++++++++++++------ 1 file changed, 33 insertions(+), 16 deletions(-) diff --git a/adapter/internal/oasparser/model/adapter_internal_api.go b/adapter/internal/oasparser/model/adapter_internal_api.go index 27fcbad25..3dab4a249 100644 --- a/adapter/internal/oasparser/model/adapter_internal_api.go +++ b/adapter/internal/oasparser/model/adapter_internal_api.go @@ -753,17 +753,32 @@ func (adapterInternalAPI *AdapterInternalAPI) SetInfoHTTPRouteCR(httpRoute *gwap }) } case gwapiv1.HTTPRouteFilterRequestRedirect: + var requestRedirectEndpoint Endpoint hasRequestRedirectPolicy = true policyParameters := make(map[string]interface{}) - - policyParameters[constants.RedirectScheme] = *filter.RequestRedirect.Scheme - policyParameters[constants.RedirectHostname] = string(*filter.RequestRedirect.Hostname) - if filter.RequestRedirect.Port != nil { - policyParameters[constants.RedirectPort] = strconv.Itoa(int(*filter.RequestRedirect.Port)) + scheme := *filter.RequestRedirect.Scheme + host := string(*filter.RequestRedirect.Hostname) + port := filter.RequestRedirect.Port + code := filter.RequestRedirect.StatusCode + + policyParameters[constants.RedirectScheme] = scheme + requestRedirectEndpoint.URLType = scheme + policyParameters[constants.RedirectHostname] = host + requestRedirectEndpoint.Host = host + + if port != nil { + policyParameters[constants.RedirectPort] = strconv.Itoa(int(*port)) + requestRedirectEndpoint.Port = uint32(*port) + } else { + if requestRedirectEndpoint.URLType == "http" { + requestRedirectEndpoint.Port = 80 + } else if requestRedirectEndpoint.URLType == "https" { + requestRedirectEndpoint.Port = 443 + } } - if filter.RequestRedirect.StatusCode != nil { - policyParameters[constants.RedirectStatusCode] = *filter.RequestRedirect.StatusCode + if code != nil { + policyParameters[constants.RedirectStatusCode] = *code } switch filter.RequestRedirect.Path.Type { @@ -772,12 +787,14 @@ func (adapterInternalAPI *AdapterInternalAPI) SetInfoHTTPRouteCR(httpRoute *gwap case gwapiv1.PrefixMatchHTTPPathModifier: policyParameters[constants.RedirectPath] = backendBasePath + *filter.RequestRedirect.Path.ReplacePrefixMatch } + requestRedirectEndpoint.Basepath = policyParameters[constants.RedirectPath].(string) policies.Request = append(policies.Request, Policy{ PolicyName: string(gwapiv1.HTTPRouteFilterRequestRedirect), Action: constants.ActionRedirectRequest, Parameters: policyParameters, }) + endPoints = append(endPoints, requestRedirectEndpoint) case gwapiv1.HTTPRouteFilterRequestMirror: var mirrorTimeoutInMillis uint32 @@ -917,17 +934,17 @@ func (adapterInternalAPI *AdapterInternalAPI) SetInfoHTTPRouteCR(httpRoute *gwap matchID := getMatchID(httpRoute.Namespace, httpRoute.Name, ruleID, matchID) operations := getAllowedOperations(matchID, match.Method, policies, apiAuth, parseRateLimitPolicyToInternal(resourceRatelimitPolicy), scopes, mirrorEndpointClusters) - + resource := &Resource{ - path: resourcePath, - methods: operations, - pathMatchType: *match.Path.Type, - hasPolicies: true, - iD: uuid.New().String(), - hasRequestRedirectFilter: hasRequestRedirectPolicy, - enableBackendBasedAIRatelimit: enableBackendBasedAIRatelimit, + path: resourcePath, + methods: operations, + pathMatchType: *match.Path.Type, + hasPolicies: true, + iD: uuid.New().String(), + hasRequestRedirectFilter: hasRequestRedirectPolicy, + enableBackendBasedAIRatelimit: enableBackendBasedAIRatelimit, backendBasedAIRatelimitDescriptorValue: descriptorValue, - extractTokenFrom: extractTokenFrom, + extractTokenFrom: extractTokenFrom, } resource.endpoints = &EndpointCluster{