in tools/eksDistroBuildToolingOpsTools/pkg/issueManager/issueManager.go [97:130]
func (p *IssueManager) GetIssue(ctx context.Context, opts *GetIssueOpts) (*gogithub.Issue, error) {
var issue *gogithub.Issue
var resp *gogithub.Response
var err error
issue, resp, err = p.client.Issues.Get(ctx, opts.Owner, opts.Repo, opts.Issue)
if resp != nil {
if resp.StatusCode == github.SecondaryRateLimitStatusCode {
b, err := io.ReadAll(resp.Body)
if err != nil {
return nil, fmt.Errorf("reading Github response body: %v", err)
}
if strings.Contains(string(b), github.SecondaryRateLimitResponse) {
logger.V(4).Info("rate limited while attempting to get github issue")
return nil, fmt.Errorf("rate limited while attempting to get github issues: %v", err)
}
}
if resp.StatusCode == github.ResourceGoneStatusCode {
_, err := io.ReadAll(resp.Body)
if err != nil {
return nil, fmt.Errorf("reading Github response body: %v", err)
}
}
}
if err != nil {
logger.V(4).Error(err, "getting Github issue", "response", resp)
return nil, fmt.Errorf("getting Github issue: %v; resp: %v", err, resp)
}
logger.V(4).Info("get issue response", "response", resp.Response.StatusCode)
logger.V(1).Info("Github issue received", "issue URL", issue.GetHTMLURL())
logger.V(4).Info("sleeping after Issue request to avoid secondary rate limiting by Github content API")
time.Sleep(time.Second * 1)
return issue, nil
}