mukan-ignite/ignite/pkg/httpstatuschecker/httpstatuschecker.go
Mukan Erkin Törük 26b204bd04
Some checks are pending
Docs Deploy / build_and_deploy (push) Waiting to run
Generate Docs / cli (push) Waiting to run
Generate Config Doc / cli (push) Waiting to run
Go formatting / go-formatting (push) Waiting to run
Check links / markdown-link-check (push) Waiting to run
Integration / pre-test (push) Waiting to run
Integration / test on (push) Blocked by required conditions
Integration / status (push) Blocked by required conditions
Lint / Lint Go code (push) Waiting to run
Test / test (ubuntu-latest) (push) Waiting to run
feat: fork Ignite CLI v29 as Mukan Ignite — remove cosmos-sdk restrictions
2026-05-11 03:31:37 +03:00

60 lines
1.3 KiB
Go

// Package httpstatuschecker is a tool check health of http pages.
package httpstatuschecker
import (
"context"
"net/http"
)
type checker struct {
c *http.Client
addr string
method string
}
// Option used to customize checker.
type Option func(*checker)
// Method configures http method.
func Method(name string) Option {
return func(cr *checker) {
cr.method = name
}
}
// Client configures http client.
func Client(client *http.Client) Option {
return func(cr *checker) {
if client != nil {
cr.c = client
}
}
}
// Check checks if given http addr is alive by applying options.
func Check(ctx context.Context, addr string, options ...Option) (isAvailable bool, err error) {
cr := &checker{
c: http.DefaultClient,
addr: addr,
method: http.MethodGet,
}
for _, o := range options {
o(cr)
}
return cr.check(ctx)
}
func (c *checker) check(ctx context.Context) (bool, error) {
req, err := http.NewRequestWithContext(ctx, c.method, c.addr, nil)
if err != nil {
return false, err
}
res, err := c.c.Do(req)
if err != nil {
// ignore some errors like "connect: connection refused"
return false, nil
}
defer res.Body.Close()
isOKStatus := res.StatusCode >= http.StatusOK && res.StatusCode < http.StatusMultipleChoices
return isOKStatus, nil
}