-
-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathhttp_config.go
More file actions
53 lines (48 loc) · 1.57 KB
/
http_config.go
File metadata and controls
53 lines (48 loc) · 1.57 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package siat
import (
"net/http"
"github.com/ron86i/go-siat/internal/adapter/services"
)
// HTTPConfig es la configuración pública para personalizar el cliente HTTP del SDK.
// Permite que los usuarios customicen timeouts, connection pooling y TLS sin pasar su propio http.Client.
//
// Campos principales:
// - Timeout: Timeout total para solicitudes (default: 45s)
// - MaxIdleConns: Pool global de conexiones ociosas (default: 100)
// - MaxConnsPerHost: Conexiones simultáneas por host (default: 10)
// - TLSMinVersion: Versión mínima de TLS (default: TLS 1.2)
//
// Ejemplo:
//
// cfg := siat.HTTPConfig{
// Timeout: 60 * time.Second,
// MaxConnsPerHost: 5,
// }
// client := siat.NewHTTPClient(cfg)
// s, _ := siat.New(baseUrl, client)
type HTTPConfig = services.HTTPConfig
// DefaultHTTPConfig retorna la configuración HTTP recomendada para producción.
//
// Valores:
// - Timeout: 45 segundos
// - MaxIdleConns: 100
// - MaxConnsPerHost: 10
// - MaxIdleConnsPerHost: 5
// - TLSMinVersion: TLS 1.2
//
// Esta es la configuración usada por defecto si no pasas un http.Client a New().
func DefaultHTTPConfig() HTTPConfig {
return services.DefaultHTTPConfig()
}
// NewHTTPClient crea un cliente HTTP optimizado basado en HTTPConfig.
// Es útil para customizar la configuración sin reescribir todo el Transport.
//
// Ejemplo:
//
// cfg := siat.DefaultHTTPConfig()
// cfg.Timeout = 60 * time.Second
// client := siat.NewHTTPClient(cfg)
// s, err := siat.New(baseUrl, client)
func NewHTTPClient(cfg HTTPConfig) *http.Client {
return services.NewHTTPClient(cfg)
}