Package HTTP Client:

- Add DNS Mapper to force destination for a fqdn source
- Allow wildcard and multi wildcard for fqdn source
- DNS Mapper create Transport, Dialer & http client
- DNS Mapper allow a config input to customize timeout, limit and TLS config
- DNS Mapper use a gloabl transport connection poller
- DNS Mapper implement DialContext & Dial method for transport
- DNS Mapper use cache to accelerate process
- DNS Mapper cache is only dnsmapper, not DNS cache
- Replace old helper for http client with DNSMapper
- Add default DNSMapper into the main lib of http client
- Allow to overide the default DNS Mapper with a new one
- Add ticker to force clean idle connection every given duration
- "Compatible" with old config, as the default config will be used instead of old client build
- Clean code and fix minor bugs
- Add config component to allow use a global config
- Config Component httpcli can overide default httpcli dns mapper when updated

Package Certificates
- Add function type to impose function that return a slice of rootCA string
- update config/component/tls by replacing mutex with atomic
- optimize some code

Package Config
- expand errors code index to add component httpcli

Package Config/component:
- database: add new validation, that config key existing into viper
- head: add new validation, that config key existing into viper
- http: add new validation, that config key existing into viper
- ldap: add new validation, that config key existing into viper
- log: add new validation, that config key existing into viper
- mail: add new validation, that config key existing into viper
- smtp: add new validation, that config key existing into viper

Package AWS:
- update package following update of httpcli
- use interface for http cli that implement the Do function
- update following the config/component/aws
- rework config/component/aws to use atomic instead of mutex
- update test unit following change

Package Request:
- update following http client update
- use interface of HTTP Client that implement DO function, instead of http client struct pointer
- update config & code following
- apply same modification into config/component/request
- update config/component/request by replacing mutex to atomic

Package Server
- add function Uptime to model to expose the duration since last start

Package Semaphore
- apply change name of constant following bump of lib associated

Package Crypt
- fix bug into reader to remove suffix of EOF if prevent

Package Errors:
- expand index module to add DNS Mapper client

Package HTTP Server:
- update monitor to apply changes

Package Socket:
- add additional check if reading error: if buffer has data, send it to handler before break run

Other:
- bump dependencies
This commit is contained in:
Nicolas JUHEL
2024-02-16 14:09:54 +01:00
parent eaf88e00b7
commit ae0a6b62c9
84 changed files with 2103 additions and 816 deletions

View File

@@ -29,10 +29,9 @@ package httpserver
import (
"sync"
liblog "github.com/nabbar/golib/logger"
libctx "github.com/nabbar/golib/context"
srvtps "github.com/nabbar/golib/httpserver/types"
liblog "github.com/nabbar/golib/logger"
montps "github.com/nabbar/golib/monitor/types"
libsrv "github.com/nabbar/golib/server"
libver "github.com/nabbar/golib/version"

View File

@@ -30,14 +30,15 @@ import (
"context"
"errors"
"fmt"
"net"
"runtime"
logent "github.com/nabbar/golib/logger/entry"
loglvl "github.com/nabbar/golib/logger/level"
libmon "github.com/nabbar/golib/monitor"
moninf "github.com/nabbar/golib/monitor/info"
montps "github.com/nabbar/golib/monitor/types"
libptc "github.com/nabbar/golib/network/protocol"
libver "github.com/nabbar/golib/version"
)
@@ -90,9 +91,16 @@ func (o *srv) runAndHealthy(ctx context.Context) error {
return errNotRunning
} else if e := o.PortNotUse(ctx, o.GetBindable()); e != nil {
return e
} else {
d := &net.Dialer{}
co, ce := d.DialContext(ctx, libptc.NetworkTCP.Code(), o.GetBindable())
defer func() {
if co != nil {
_ = co.Close()
}
}()
return ce
}
return nil
}
func (o *srv) MonitorName() string {

View File

@@ -28,6 +28,7 @@ package pool
import (
"context"
"time"
libhtp "github.com/nabbar/golib/httpserver"
)
@@ -106,3 +107,17 @@ func (o *pool) IsRunning() bool {
return run
}
func (o *pool) Uptime() time.Duration {
var res time.Duration
o.Walk(func(name string, val libhtp.Server) bool {
if dur := val.Uptime(); res < dur {
res = dur
}
return true
})
return res
}

View File

@@ -31,6 +31,7 @@ import (
"fmt"
"net"
"net/http"
"time"
srvtps "github.com/nabbar/golib/httpserver/types"
loglvl "github.com/nabbar/golib/logger/level"
@@ -227,3 +228,14 @@ func (o *srv) runFuncStop(ctx context.Context) (err error) {
return err
}
func (o *srv) Uptime() time.Duration {
o.m.RLock()
defer o.m.RUnlock()
if o.r != nil {
return o.r.Uptime()
}
return 0
}