From 6578f1467937df61d39c25850470740b62b1614c Mon Sep 17 00:00:00 2001 From: CrowleyRajapakse Date: Sun, 31 Mar 2024 11:08:08 +0530 Subject: [PATCH] adding retry to ratelimit initial policy fetcher --- .../synchronizer/ratelimit_policy_fetcher.go | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/apim-apk-agent/internal/synchronizer/ratelimit_policy_fetcher.go b/apim-apk-agent/internal/synchronizer/ratelimit_policy_fetcher.go index c017f9a2..6b2ab378 100644 --- a/apim-apk-agent/internal/synchronizer/ratelimit_policy_fetcher.go +++ b/apim-apk-agent/internal/synchronizer/ratelimit_policy_fetcher.go @@ -29,6 +29,7 @@ import ( "net/http" "strconv" "strings" + "time" "github.com/wso2/product-apim-tooling/apim-apk-agent/config" k8sclient "github.com/wso2/product-apim-tooling/apim-apk-agent/internal/k8sClient" @@ -113,7 +114,7 @@ func FetchRateLimitPoliciesOnEvent(ratelimitName string, organization string, c var errorMsg string if err != nil { errorMsg = "Error occurred while calling the REST API: " + policiesEndpoint - go retryFetchData(conf, errorMsg, err, c) + go retryRLPFetchData(conf, errorMsg, err, c) return } responseBytes, err := ioutil.ReadAll(resp.Body) @@ -121,7 +122,7 @@ func FetchRateLimitPoliciesOnEvent(ratelimitName string, organization string, c if err != nil { errorMsg = "Error occurred while reading the response received for: " + policiesEndpoint - go retryFetchData(conf, errorMsg, err, c) + go retryRLPFetchData(conf, errorMsg, err, c) return } @@ -151,6 +152,18 @@ func FetchRateLimitPoliciesOnEvent(ratelimitName string, organization string, c } else { errorMsg = "Failed to fetch data! " + policiesEndpoint + " responded with " + strconv.Itoa(resp.StatusCode) - go retryFetchData(conf, errorMsg, err, c) + go retryRLPFetchData(conf, errorMsg, err, c) + } +} + +func retryRLPFetchData(conf *config.Config, errorMessage string, err error, c client.Client) { + logger.LoggerSynchronizer.Debugf("Time Duration for retrying: %v", + conf.ControlPlane.RetryInterval*time.Second) + time.Sleep(conf.ControlPlane.RetryInterval * time.Second) + FetchRateLimitPoliciesOnEvent("", "", c) + retryAttempt++ + if retryAttempt >= retryCount { + logger.LoggerSynchronizer.Errorf(errorMessage, err) + return } }