mirror of
https://gitea.com/gitea/gitea-mcp.git
synced 2025-08-23 14:23:05 +00:00
- Refactor HTTP client initialization to always create a custom http.Client - Move TLS config modification into the default HTTP client when insecure flag is set - Ensure the HTTP client is always included in client options Signed-off-by: appleboy <appleboy.tw@gmail.com> Reviewed-on: https://gitea.com/gitea/gitea-mcp/pulls/47 Co-authored-by: appleboy <appleboy.tw@gmail.com> Co-committed-by: appleboy <appleboy.tw@gmail.com>
49 lines
867 B
Go
49 lines
867 B
Go
package gitea
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"net/http"
|
|
"sync"
|
|
|
|
"gitea.com/gitea/gitea-mcp/pkg/flag"
|
|
"gitea.com/gitea/gitea-mcp/pkg/log"
|
|
|
|
"code.gitea.io/sdk/gitea"
|
|
)
|
|
|
|
var (
|
|
client *gitea.Client
|
|
clientOnce sync.Once
|
|
)
|
|
|
|
func Client() *gitea.Client {
|
|
clientOnce.Do(func() {
|
|
var err error
|
|
if client != nil {
|
|
return
|
|
}
|
|
|
|
httpClient := &http.Client{
|
|
Transport: http.DefaultTransport,
|
|
}
|
|
|
|
opts := []gitea.ClientOption{
|
|
gitea.SetToken(flag.Token),
|
|
}
|
|
if flag.Insecure {
|
|
httpClient.Transport.(*http.Transport).TLSClientConfig = &tls.Config{
|
|
InsecureSkipVerify: true,
|
|
}
|
|
}
|
|
opts = append(opts, gitea.SetHTTPClient(httpClient))
|
|
if flag.Debug {
|
|
opts = append(opts, gitea.SetDebugMode())
|
|
}
|
|
client, err = gitea.NewClient(flag.Host, opts...)
|
|
if err != nil {
|
|
log.Fatalf("create gitea client err: %v", err)
|
|
}
|
|
})
|
|
return client
|
|
}
|