Skip to content

Commit

Permalink
feat: PRT - change populator behavior to be completely concurrent
Browse files Browse the repository at this point in the history
  • Loading branch information
ranlavanet committed Jan 7, 2025
1 parent 5431ee0 commit ca0d42d
Showing 1 changed file with 50 additions and 53 deletions.
103 changes: 50 additions & 53 deletions ecosystem/cache_populator/command.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,65 +67,62 @@ func executeRequest(config CacheConfig, request Request) {
client := &http.Client{}
ticker := time.NewTicker(config.Interval)
defer ticker.Stop()
for range ticker.C {
go func() {
// Create context with timeout
ctx, cancel := context.WithTimeout(context.Background(), config.ContextTimeout)

// Generate new GUID for this request cycle
guid := utils.GenerateUniqueIdentifier()

// Create request based on type
var httpReq *http.Request
var err error

switch request.Type {
case "GET":
httpReq, err = http.NewRequestWithContext(ctx, http.MethodGet,
config.ServerAddress+request.Path, nil)
case "POST":
httpReq, err = http.NewRequestWithContext(ctx, http.MethodPost,
config.ServerAddress+request.Path, bytes.NewBufferString(request.Body))
default:
utils.LavaFormatError("unsupported request type", fmt.Errorf("type: %s", request.Type), utils.Attribute{Key: "guid", Value: guid})
cancel()
return
}

for {
// Create context with timeout
ctx, cancel := context.WithTimeout(context.Background(), config.ContextTimeout)

// Generate new GUID for this request cycle
guid := utils.GenerateUniqueIdentifier()

// Create request based on type
var httpReq *http.Request
var err error

switch request.Type {
case "GET":
httpReq, err = http.NewRequestWithContext(ctx, http.MethodGet,
config.ServerAddress+request.Path, nil)
case "POST":
httpReq, err = http.NewRequestWithContext(ctx, http.MethodPost,
config.ServerAddress+request.Path, bytes.NewBufferString(request.Body))
default:
utils.LavaFormatError("unsupported request type", fmt.Errorf("type: %s", request.Type), utils.Attribute{Key: "guid", Value: guid})
cancel()
continue
}
if err != nil {
utils.LavaFormatError("failed to create request", err, utils.Attribute{Key: "guid", Value: guid})
cancel()
return
}

if err != nil {
utils.LavaFormatError("failed to create request", err, utils.Attribute{Key: "guid", Value: guid})
cancel()
continue
}
// Add headers to the request
for key, value := range request.Headers {
httpReq.Header.Set(key, value)
}

// Add headers to the request
for key, value := range request.Headers {
httpReq.Header.Set(key, value)
}
// Execute request
utils.LavaFormatDebug("request ", utils.Attribute{Key: "path", Value: request.Path}, utils.Attribute{Key: "body", Value: request.Body}, utils.Attribute{Key: "guid", Value: guid})

// Execute request
utils.LavaFormatDebug("request ", utils.Attribute{Key: "path", Value: request.Path}, utils.Attribute{Key: "body", Value: request.Body}, utils.Attribute{Key: "guid", Value: guid})
resp, err := client.Do(httpReq)
if err != nil {
utils.LavaFormatError("failed to execute request", err, utils.Attribute{Key: "guid", Value: guid})
cancel()
// Wait for next tick before retrying
return
}

if resp.StatusCode >= 400 {
utils.LavaFormatError("request failed",
fmt.Errorf("status code: %d, path: %s", resp.StatusCode, request.Path), utils.Attribute{Key: "guid", Value: guid})
}

resp, err := client.Do(httpReq)
if err != nil {
utils.LavaFormatError("failed to execute request", err, utils.Attribute{Key: "guid", Value: guid})
resp.Body.Close()
utils.LavaFormatDebug("response", utils.Attribute{Key: "status_code", Value: resp.StatusCode}, utils.Attribute{Key: "path", Value: request.Path}, utils.Attribute{Key: "guid", Value: guid}, utils.Attribute{Key: "body", Value: request.Body})
cancel()
// Wait for next tick before retrying
<-ticker.C
continue
}

if resp.StatusCode >= 400 {
utils.LavaFormatError("request failed",
fmt.Errorf("status code: %d, path: %s", resp.StatusCode, request.Path), utils.Attribute{Key: "guid", Value: guid})
}

resp.Body.Close()
utils.LavaFormatDebug("response", utils.Attribute{Key: "status_code", Value: resp.StatusCode}, utils.Attribute{Key: "path", Value: request.Path}, utils.Attribute{Key: "guid", Value: guid}, utils.Attribute{Key: "body", Value: request.Body})
cancel()

// Wait for next tick before making the next request
<-ticker.C
}()
}
}

Expand Down

0 comments on commit ca0d42d

Please sign in to comment.