mirror of
https://github.com/nabbar/golib.git
synced 2025-10-20 22:39:51 +08:00
Package Config/component/LDAP:
- replace mutex by atomic - fix minor bugs & optimize code Package Size: - add function 'mul' allowing do a multiplaction on the size value by a float64 given value (could use another size.float64) - add function 'div' allowing do a division of the size value by a float64 given value (could use another size.float64) - add function 'add' allowing do an addtion of the size value with a uint64 given value (could use another size.uint64) - add function 'sub' allowing do an substraction of the size value with a uint64 given value (could use another size.uint64) Package Encoding: - rework completly crypt package to new package encoding - part aes of old crypt become new subpackage encoding/aes - part hex of old crypt (associated with aes) become new standalone subpackage encoding/hexa - adding new subpackage mux to use multiplexer/de-multiplexer of io stream - mux is different of multireader / multiwriter in way as io send from mux in one channel will be received only in the coresponding channel of de-mux - mux is encoding subpackage becauxse based on hex + cbor marshalling / unmarshalling - all subpackage can be used directly of by io reader / writer Package Socket/server - rework server to use as possible direct io to con - rework server to optimize & fix managment (context / shutdown...) - rework server to stop connection befor stopping server - rework server to not load incoming and send it to handler by allowing handler to manager io input/output directly - server not more used buff internally (less memory consuption) - adding counter of opened connection - adding some testing who's checking server & client for each protocol Package Socket/client - rework client to allow connect to server before reading/writing on io stream - rework client to allow consum direct io stream instead of reading locally / call function - rework client to allow having less memory consumption by removing internal buffer - rework client allowing to use root io function (bufio, io copy, ...) Package Socket/multi - adding new subpackage multi to simplfy using of 1 reader / x writer - if no writer is define, using an extended io discard - allowing asynch instancing, populate writer and calling main writer - allowing calling writer / reader to expose the main io reader / writer Package Socket/delim: - adding new subpackage delim to simplify using of bufio reader with delimiter - using 1 writer / 1 reader - allowing root io function like readwritecloser, writeto, ... - use local buffer to prevent race if reader and writer are not is same process Package PProf: - fix missing \n in message Package HttpServer: - fix bug with init TLS & http2 Other: - bump dependencies
This commit is contained in:
@@ -29,6 +29,7 @@ package ldap
|
||||
import (
|
||||
cfgtps "github.com/nabbar/golib/config/types"
|
||||
libctx "github.com/nabbar/golib/context"
|
||||
lbldap "github.com/nabbar/golib/ldap"
|
||||
liblog "github.com/nabbar/golib/logger"
|
||||
libver "github.com/nabbar/golib/version"
|
||||
libvpr "github.com/nabbar/golib/viper"
|
||||
@@ -55,17 +56,6 @@ func (o *componentLDAP) Type() string {
|
||||
}
|
||||
|
||||
func (o *componentLDAP) Init(key string, ctx libctx.FuncContext, get cfgtps.FuncCptGet, vpr libvpr.FuncViper, vrs libver.Version, log liblog.FuncLog) {
|
||||
o.m.Lock()
|
||||
defer o.m.Unlock()
|
||||
|
||||
if o.x == nil {
|
||||
o.x = libctx.NewConfig[uint8](ctx)
|
||||
} else {
|
||||
x := libctx.NewConfig[uint8](ctx)
|
||||
x.Merge(o.x)
|
||||
o.x = x
|
||||
}
|
||||
|
||||
o.x.Store(keyCptKey, key)
|
||||
o.x.Store(keyFctGetCpt, get)
|
||||
o.x.Store(keyFctViper, vpr)
|
||||
@@ -84,10 +74,17 @@ func (o *componentLDAP) RegisterFuncReload(before, after cfgtps.FuncCptEvent) {
|
||||
}
|
||||
|
||||
func (o *componentLDAP) IsStarted() bool {
|
||||
o.m.RLock()
|
||||
defer o.m.RUnlock()
|
||||
|
||||
return o != nil && o.l != nil
|
||||
if o == nil {
|
||||
return false
|
||||
} else if i := o.l.Load(); i == nil {
|
||||
return false
|
||||
} else if v, k := i.(*lbldap.HelperLDAP); !k {
|
||||
return false
|
||||
} else if v.Check() != nil {
|
||||
return false
|
||||
} else {
|
||||
return true
|
||||
}
|
||||
}
|
||||
|
||||
func (o *componentLDAP) IsRunning() bool {
|
||||
@@ -103,25 +100,20 @@ func (o *componentLDAP) Reload() error {
|
||||
}
|
||||
|
||||
func (o *componentLDAP) Stop() {
|
||||
o.m.Lock()
|
||||
defer o.m.Unlock()
|
||||
|
||||
o.l.Close()
|
||||
o.l = nil
|
||||
|
||||
return
|
||||
if i := o.l.Swap(&lbldap.HelperLDAP{}); i == nil {
|
||||
return
|
||||
} else if v, k := i.(*lbldap.HelperLDAP); !k {
|
||||
return
|
||||
} else {
|
||||
v.Close()
|
||||
}
|
||||
}
|
||||
|
||||
func (o *componentLDAP) Dependencies() []string {
|
||||
o.m.RLock()
|
||||
defer o.m.RUnlock()
|
||||
|
||||
var def = make([]string, 0)
|
||||
|
||||
if o == nil {
|
||||
return def
|
||||
} else if o.x == nil {
|
||||
return def
|
||||
} else if i, l := o.x.Load(keyCptDependencies); !l {
|
||||
return def
|
||||
} else if v, k := i.([]string); !k {
|
||||
@@ -134,12 +126,13 @@ func (o *componentLDAP) Dependencies() []string {
|
||||
}
|
||||
|
||||
func (o *componentLDAP) SetDependencies(d []string) error {
|
||||
o.m.RLock()
|
||||
defer o.m.RUnlock()
|
||||
|
||||
if o.x == nil {
|
||||
return ErrorComponentNotInitialized.Error(nil)
|
||||
} else {
|
||||
if d == nil {
|
||||
d = make([]string, 0)
|
||||
}
|
||||
|
||||
o.x.Store(keyCptDependencies, d)
|
||||
return nil
|
||||
}
|
||||
|
Reference in New Issue
Block a user