Skip to content
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 26 additions & 0 deletions pkg/errors/error.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,10 @@ package errors

import (
"context"
stderrors "errors"
"fmt"
"net/http"
"time"

"github.com/github/github-mcp-server/pkg/utils"
"github.com/google/go-github/v82/github"
Expand Down Expand Up @@ -159,6 +161,30 @@ func NewGitHubAPIErrorResponse(ctx context.Context, message string, resp *github
if ctx != nil {
_, _ = addGitHubAPIErrorToContext(ctx, apiErr) // Explicitly ignore error for graceful handling
}

var rateLimitErr *github.RateLimitError
if stderrors.As(err, &rateLimitErr) {
resetTime := rateLimitErr.Rate.Reset.Time
if !resetTime.IsZero() && resetTime.After(time.Now()) {
retryIn := time.Until(resetTime).Round(time.Second)
return utils.NewToolResultError(fmt.Sprintf(
"%s: GitHub API rate limit exceeded. Retry after %v.", message, retryIn))
Comment thread
danmoseley marked this conversation as resolved.
Outdated
}
return utils.NewToolResultError(fmt.Sprintf(
"%s: GitHub API rate limit exceeded. Wait before retrying.", message))
}

var abuseErr *github.AbuseRateLimitError
if stderrors.As(err, &abuseErr) {
if abuseErr.RetryAfter != nil && *abuseErr.RetryAfter > 0 {
return utils.NewToolResultError(fmt.Sprintf(
"%s: GitHub secondary rate limit exceeded. Retry after %v.",
message, abuseErr.RetryAfter.Round(time.Second)))
Comment thread
danmoseley marked this conversation as resolved.
Outdated
Comment thread
danmoseley marked this conversation as resolved.
Outdated
}
return utils.NewToolResultError(fmt.Sprintf(
"%s: GitHub secondary rate limit exceeded. Wait before retrying.", message))
}

return utils.NewToolResultErrorFromErr(message, err)
}

Expand Down
Loading
Loading