Add configurable timeouts and cache validity to ESI and SSO components
This commit is contained in:
@@ -9,6 +9,8 @@ import (
|
||||
"net/http"
|
||||
"time"
|
||||
|
||||
"go-eve-pi/options"
|
||||
|
||||
logger "git.site.quack-lab.dev/dave/cylogger"
|
||||
)
|
||||
|
||||
@@ -105,9 +107,16 @@ type DirectESI struct {
|
||||
|
||||
// NewDirectESI creates a new DirectESI instance
|
||||
func NewDirectESI() *DirectESI {
|
||||
// Parse HTTP timeout ONCE at initialization
|
||||
httpTimeout, err := time.ParseDuration(options.GlobalOptions.HTTPTimeout)
|
||||
if err != nil {
|
||||
logger.Warning("Invalid HTTP timeout duration %s, using 30s default: %v", options.GlobalOptions.HTTPTimeout, err)
|
||||
httpTimeout = 30 * time.Second
|
||||
}
|
||||
|
||||
return &DirectESI{
|
||||
httpClient: &http.Client{
|
||||
Timeout: 30 * time.Second,
|
||||
Timeout: httpTimeout,
|
||||
},
|
||||
}
|
||||
}
|
||||
@@ -127,8 +136,7 @@ func (d *DirectESI) GetCharacterPlanets(ctx context.Context, characterID int, ac
|
||||
req.Header.Set("Authorization", "Bearer "+accessToken)
|
||||
req.Header.Set("Accept", "application/json")
|
||||
|
||||
client := &http.Client{Timeout: 30 * time.Second}
|
||||
resp, err := client.Do(req)
|
||||
resp, err := d.httpClient.Do(req)
|
||||
if err != nil {
|
||||
logger.Error("Failed to fetch character planets: %v", err)
|
||||
return nil, err
|
||||
@@ -166,8 +174,7 @@ func (d *DirectESI) GetPlanetDetails(ctx context.Context, characterID, planetID
|
||||
req.Header.Set("Authorization", "Bearer "+accessToken)
|
||||
req.Header.Set("Accept", "application/json")
|
||||
|
||||
client := &http.Client{Timeout: 30 * time.Second}
|
||||
resp, err := client.Do(req)
|
||||
resp, err := d.httpClient.Do(req)
|
||||
if err != nil {
|
||||
logger.Error("Failed to fetch planet details: %v", err)
|
||||
return nil, err
|
||||
|
||||
Reference in New Issue
Block a user